社区
界面
帖子详情
如何让Dos控制台停留?
simonhappy
2005-07-19 06:00:56
如果是在Explore中点击程序,利用printf输出的信息会打开一个Dos控制台输出,但是这个控制台会马上关闭。如何让这个控制台停留呢?
...全文
168
3
打赏
收藏
如何让Dos控制台停留?
如果是在Explore中点击程序,利用printf输出的信息会打开一个Dos控制台输出,但是这个控制台会马上关闭。如何让这个控制台停留呢?
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
3 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
Lonelywolf1899
2005-07-20
打赏
举报
回复
程序最后来一句:
getchar();
AntonlioX
2005-07-19
打赏
举报
回复
system("PAUSE");
masterz
2005-07-19
打赏
举报
回复
system("pause");
python基础教程-包含数据库编程 共41页.pdf
python基础教程-包含数据库编程 共41页.pdf
Linux操作系统基础教程
Linux 操作系统基础教程 清华大学信息学院计算机系 目 录 前言..................................................................................................................................................2 第一讲 Linux基础...........................................................................................................................2 一.什么是Linux?.................................................................................................................2 二.安装Linux的好处?.........................................................................................................3 三.如何得到Linux?.............................................................................................................3 四.如何得到Linux的最新消息?.........................................................................................3 五.Linux操作系统上有什么应用?.....................................................................................4 六.在那里可以找到讨论区?..............................................................................................5 七.安装过程..........................................................................................................................5 第二讲 Linux基础进阶...................................................................................................................5 一.Linux的文件系统结构.....................................................................................................6 二. 文件类型...........................................................................................................................7 三.Linux基本操作命令............................................................................................................8 四.基本的系统管理命令.......................................................................................................14 五.关於 Process 处理的指令...............................................................................................16 六. 关於字串处理的指令.....................................................................................................17 七. 网路上查询状况的指令.................................................................................................17 八. 网路指令.........................................................................................................................18 九. 关於通讯用的指令.........................................................................................................21 十. 编译器( Compiler )..........................................................................................................22 十一. 有关列印的指令.........................................................................................................22 第三讲 Linux下的网络服务,配置问题和常用工具.................................................................24 一.Linux下的网络服务.......................................................................................................24 二.几种重要的配置文件.......................................................................................................26 三.Linux下常用的工具软件..................................................................................................28 尾语................................................................................................................................................31 前言 Linux 是在 1991 年发展起来的与 UNIX兼容的操作系统,可以免费使用,它的源代码 可以自由传播且可任人修改、充实、发展,开发者的初衷是要共同创造一个完美、理想并 可以免费使用的操作系统。 我们并不能使同学们通过这次系列讲座成为一个 UNIX 类操作系统的高手,这次系列 讲座的目的就是在同学们中间普及 Linux 基础知识,为今后我们更加接近的了解 Linux 做一 个好的开端。 第一讲 Linux基础 在这一讲中,我们主要是了解一下 Linux 的概况,以及对 Linux 有一个初步的感性认识。 一.什么是Linux? Linux 是一个以 Intel 系列 CPU(CYRIX,AMD 的 CPU也可以)为硬件平台,完全免费的 UNIX 兼容系统,完全适用于个人的 PC。它本身就是一个完整的 32 位的多用户多任务操作 系统,因此不需要先安装
DOS
或其他的操作系统(MS Windows, OS2, MINIX..)就可以进 行直接的安装。 Linux的最早起源是在1991年10月5日由一位芬兰的大学生Linux Torvalds (Torvalds@kruuna.helsinki.fi)写了 Linux核心程序的 0.02 版开始的,但其后的发展却几乎都 是由互联网上的 Linux社团(Linux Community)互通交流而完成的。Linux 不属于任何一 家公司或个人,任何人都可以免费取得甚至修改它的源代码(source code)。Linux 上的大部 分软件都是由 GNU倡导发展起来的,所以软件通常都会在附着 GNU Public License(GPL) 的情况下被自由传播。GPL 是一种可以使你免费获得自由软件的许可证,因此 Linux 使用 者的使用活动基本不受限制(只要你不将它用于商业目的),而不必像使用微软产品是那样, 2需要为购满许可证付出高价还要受到系统安装数量的限制。我在讲义的最后面附有 GPL 的 非官方中文译稿。目前 Linux 中国的发行版本(Linux Distribution)主要有 Red Hat (红帽子) , Slackware, Caldera, Debian, Red Flag (红旗) , Blue Point (蓝点) , Xteam Linux (冲浪) , Happy Linux(幸福Linux), Xlinux 等若干种,我推荐同学们使用的发行版本是 Red Hat(事实标 准)和 Xlinux(安装最容易)。 二.安装Linux的好处? Linux的核心具有 Windows 无法比拟的稳定性和高效率,在不使用 X Windows 的情况 下,它占用系统资源较少,可以使一台 Intel486摇身一变成为高效工作站。对于想要学习 UNIX的用户来说,使他们熟悉 UNIX 操作环境,通往"骨灰级"高手境界的一大捷径。最重 要的是,Linux 上有公认的 C 语言世界最好的编译器 gcc,如果你想得到一个效率更高的开 发环境(并不一定是最友好的,但一定是最强大的),我建议你一定要好好的熟悉一下 Linux。 三.如何得到Linux? 据我所知,大多数的 Linux 发行版本(Linux distribution)和核心(Kernel)都是可以 从网上下载的,但是我不推荐易用这种方法得到 Linux,因为仅仅核心就有几十个 Mbit 的 数据量,而一个完整的发行版本大概都是 1Gbit 左右的数据量,你自己可以估计一下得用多 少时间来下载它们?我建议你最好去软件商店买光盘来,因为 Linux 的产品光盘是非常便宜 的,连带许可证 GPL 在内你大概支付 50 元人民币就可以,而具有同样功能的 Windows NT 4.0 你至少得付出 17000元人民币(有一点需要声明:在你购买光盘时 GPL 许可证你是不会 肉眼看到的)。直接到商店去买,可以省去你很多麻烦,因为从网上下载的 Linux有很多它 还是要求你有光盘刻录工具将安装文件刻到光盘上。 四.如何得到Linux的最新消息? 关于 Linux 的站点现在到处都是,我这里向大家推荐的是一个关于 Linux 核心最新消息 的一个网站,你可以得到核心(Kernel)发展情况的最新信息。网址如下: http://www.kernel.org 另外还有一个非常著名的讨论组,你也可以去看看:http://www.linuxforum.net 另外还有一 个我常去的讨论组,这个讨论组是有高手专门维护的,而且回应贴子的速度很快: http://www.coventive.com.cn/club/default.htm在我这份讲义快写完的时候,又有一个非常好的 自由软件团体出现了,那就是 AKA,大家可以到他们的网页上去看看,里面有许多很实用的 3信息:http://www.aka.org.cn 五.Linux操作系统上有什么应用? Linux 上有丰富的的应用软件,在这里我给大家做一个简单的介绍,具体它们是什么样 子我会在讲座上为大家一一演示。 文本处理方面(
控制台
界面,X Window界面在后面介绍) vi 最令 UNIX类操作系统初学者裹足不前的 editor,然而只要你习惯于操作,你会觉得 它比任何的 editor都好用,且功能强大。 pico 一种风格很像 Microsoft
DOS
的 EDIT 的一种文本编辑器。 中文化方面 XCIN+Crxvt 缺省的 Linux 系统是不支持显示中文的,虽然现在国内涌现出许多著名的 Linux 汉化厂商,但是一些著名的 Linux distribution 如 Red Hat、Debian、Caldera 仍然不支 持中文的输入和输出。这套汉化工具组合在
控制台
(console)方式和 X Window方式下都可 以显示和输入汉字信息。 Cxterm 可以很容易的自行设置输入法,或者修改现有的输入法表格。 视窗界面(window manager)方面 KDE 这是 X Window System使用率最高的 Window Manager。 lFvwm 公认的最为好用的 Window Manager之一。 Fvwm95 拥有和 Microsoft Win95 同样界面的 Window Manager。 Afterstep 公认的最好看的 Window Manager,但号内存也很大。 Enlightenment 界面最华丽的 Window Manager, Win95 和它相比简直就是 nothing,但是 号内存太大,有点华而不实。 lIcewin 又一个极富个性的 Window Manager。 视窗应用软件方面 WWW Browser Netscape公司的 navigator3.x 和communicator4.x 版可用,使用方法和 MS Windows上一样。 图像处理 GIMP是类似于 Photoshop的绘图软件,号称是 Linux 上最强的绘图软件。 看图工具 MTV 这是一个可以播放 VCD的软件,但是它是共享软件(Shareware),不是免费软件, 我们也得不到它的源代码。 Star Office 这是一套著名的办公软件,我个人认为它无论在界面上还是在功能上都强于 Microsoft Office 产品。唯一的缺憾是他不支持汉字,无论 GB 还是 BIG5。 Word Perfect 这是一个非常精彩的字处理软件,功能类似于 Microsoft Word。 4文杰字处理系统 这是一套由韩国人开发的字处理系统,功能强大,有专门的中文版推出, 类似于 Microsoft Word。 编译环境 gcc 公认的C 语言世界中功能最为强大的编译器,但是界面不是很友好。 除此之外还有 FORTRAN、 Pascal、 GNU make、 GNU debugger、 GNU LISP、 GNU PERL、 TCL。 这里因为本人对这些编译工具都不熟悉,因此不多介绍。 MS Windows的模拟环境 WINE 可以使绝大多数的 16 位 MS Window程序运行在这个模拟环境中。但是不支持 32 位的程序。 六.在那里可以找到讨论区? 大家最熟悉的是北邮的 BBS: 202.204.7.235 port:23 七.安装过程 这是非常重要的一部分,希望大家仔细了解本部分内容。 就我个人认为,对于初学者来说,Linux 的安装过程是相当难的,新手往往会遇到系统 屡装不成的情况。遇到这种事情,是非常痛苦的,但是几乎每个新手又都会遇到,因此我 觉得安装过程应当仔细的说明一下。但是由于篇幅有限,我不见这个这个问题在讲义的正 文中陈述,而是把它放在附文 2 中仔细说明。希望没有安装过 Linux 的同学们将这篇文章看 一看。我想在上课的时候我会给大家演示一遍安装的过程。 第二讲 Linux基础进阶 经过上一节课的探讨,我想同学们应该对 Linux 有了一个初步的感性认识,但我们的 认识还只是处在一个尚需进步的表层上。通过这一节的学习,同学们会对 Linux 的体系结构, 它的基本操作,基本功能有一个更进一步的认识。 5 一.Linux的文件系统结构 Linux的文件系统和MS-Windows的文件系统有很大的不同,对于微软视窗系统的文件 结构我在这里不再多说,我们主要了结一下 linux的文件系统结构. linux 只有一个文件树,整 个文件系统是以一个树根"/"为起点的,所有的文件和外部设备都以文件的形式挂结在这个文 件树上,包括硬盘,软盘,光驱,调制解调器等,这和以"驱动器盘符为基础的 MS-Windows 系统 是大不相同的.Linux 的文件结构体现了这个操作系统简洁清析的设,常我们能够接触到的 linux 发行版本的根目录大都是以下结构: /bin /etc /lost+found /sbin /var /boot /root /home /mnt /tmp /dev /lib /proc /usr 现在我将这些目录给大家做一个简要的介绍: 1. /bin和/sbin 使用和维护UNIX和Linux系统的大部分基本程序都包含在/bin和/sbin里,这两个目录 的名气之所以包含 bin,是因为可执行的程序都是二进制文件(binary files). /bin 目录通常用来存放用户最常用的基本程序,如: login Shells 文件操作实用程序 系统实用程序 压缩工具 /sbin 目录通常存放基本的系统和系统维护程序,如: fsck fdisk mkfs shutdown lilo init 存放在这两个目录中的程序的主要区别是:/sbin 中的程序只能由 root(管理员)来执行. 2. /etc 这个目录一般用来存放程序所需的整个文件系统的配置文件,其中的一些重要文件如 下: passwd shadow fstab hosts motd profile shells services lilo.conf 3. /lost+found 这个目录专门是用来放那些在系统非正常菪机后重新启动系统时,不知道改网哪里恢复 的"流浪"文件的。 4. /boot 这个目录下面存放着和系统启动有关系的各种文件,包括系统的引导程序和系统核心 部分。 65. /root 这是系统管理员(root)的主目录。 6. /home 系统中所有用户的主目录都存放在/home 中,它包含实际用户(人)的主目录和其他用户 的主目录.Linux同 UNIX 的不同之处是,Linux的 root 用户的主目录通常是在/root或 /home/root,而 UNIX 通常是在/。 7. /mnt 按照约定,像 CD-ROM,软盘,Zip盘,或者 Jaz这样的可以动介质都应该安装在/mnt 目录下,/mnt 目录通常包含一些子目录,每个子目录是某种特定设备类型的一个安装点。 例如: /cdrom /floppy /zip /win .... 如果我们要使用这些特定设备,我们需要用 mount 命令从/dev 目录中将外部设备挂接 过来。在这里大家可能看到了有一个 win 的目录,这是我的机子上面做的一个通向 windows 文件系统的挂接点,这样我通过访问这个目录就可以访问到我在 windows 下面的文件了。 但如果你的 windows 文件系统是 NTFS 格式,那么这个办法就不行了。 8. /tmp和/var 这两个目录用来存放临时文件和经常变动的文件。 9. /dev 这是一个非常重要的目录,它存放着各种外部设备的镜像文件,其中有一些内容我们 是要牢牢记住的。例如第一个软盘驱动器的名字是 fd0;第一个硬盘的名字是 hda,硬盘中的 第一个分区是 hda1,第二个分区是 hda2;第一个光盘驱动器的名字是 hdc;此外,还用 modem 和其他外设的名字,在这么多的名字中,我们只需要记住最最常用的那几个外设就可以了。 10. /usr 按照约定,这个目录用来存放与系统的用户直接相关的程序或文件,这里面有每一个 系统用户的主目录,就是相对于他们的小型"/"。 11. /proc 这个目录下面的内容是当前在系统中运行的进程的虚拟镜像,我们在这里可以看到由 当前运行的进程号组成的一些目录,还有一个记录当前内存内容的 kernel 文件。 就个人经验,我认为这些目录以及在它们下面应该存储什么内容,我们都应当很熟练的 记下来,这对于我们进一步的使用系统是很有帮助的。 二. 文件类型 本来我是想把基本操作命令放在这里介绍一下,但是这些命令中又不少是涉及到文件类 7型的,所以我就只好先介绍一下文件类型了。 Linux 的文件类型大致可分为五类,而且它支持长文件名,不论是文件还是目录名,最 长可以达到 256 个字节。如果你能够用 128 个汉字写一片小作文,那你也可以用它来做某 个文件的文件名(当然这里面不能有不合规定的命名字符存在)。 1. 一般性文件 一般性文件,例如纯文本文件 mtv-0.0b4.README,设置文件 lilo.conf,记录文件 ftp.log 等等都是。一般类型的文件在
控制台
的显示下都没有颜色,系统默认的是白色。 2. 目录 至于目录是什么意思我就不解释了,我的任务是要告诉大家,你可以用 cd+目录名进 入到这个目录中去,而这个目录在
控制台
下显示的颜色是蓝色的,非常容易辨认。如果你 用 ls -l 来观看它们,会发现它们的文件属性(共 10 个字符)的一个字符是 d,这表明它是一 个目录,而不是其它的东西。 三.Linux基本操作命令 首先介绍一个名词"
控制台
(console)",它就是我们通常见到的使用字符操作界面的 人机接口,例如
dos
。我们说
控制台
命令,就是指通过字符界面输入的可以操作系统的命令, 例如
dos
命令就是
控制台
命令。我们现在要了解的是基于Linux操作系统的基本
控制台
命令。 有一点一定要注意,和
dos
命令不同的是,Linux 的命令(也包括文件名等等)对大小 写是敏感的,也就是说,如果你输入的命令大小写不对的话,系统是不会做出你期望的响 应的。 1. ls 这个命令就相当于
dos
下的 dir命令一样,肯定是我第一个就要介绍的,这也是 Linux
控制台
命令中最为重要几个命令之一。ls 最常用的参数有三个: -a -l -F。 ls -a Linux 上的文件以.开头的文件被系统视为隐藏文件,仅用 ls 命令是看不到他们的,而用 ls -a 除了显示 一般文件名外,连隐藏文件也会显示出来。 ls -l(这个参数是字母 L 的小写,不是数字 1) 这个命令可以使用长格式显示文件内容,如果需要察看更详细的文件资料,就要用到 ls -l 这个指令。例如我在某个目录下键入 ls -l 可能会显示如下信息(最上面两行是我自己加 的): 位置 1 2 3 4 5 6 7 文件属性 文件数 拥有者 所属的group 文件大小 建档日期 文件名 drwx------ 2 Guest users 1024 Nov 21 21:05 Mail 8 -rwx--x--x 1 root root 89080 Nov 7 22:41 tar* -rwxr-xr-x 1 root bin 5013 Aug 15 9:32 uname* lrwxrwxrwx 1 root root 4 Nov 24 19:30 zcat->gzip -rwxr-xr-x 1 root bin 308364 Nov 29 7:43 zsh* -rwsr-x--- 1 root bin 9853 Aug 15 5:46 su* 下面,我为大家解释一下这些显示内容的意义。 第一个栏位,表示文件的属性。 Linux 的文件基本上分为三个属性:可读(r),可写(w),可执行(x)。但是这里有 十个格子可以添(具体程序实现时,实际上是十个 bit 位)。第一个小格是特殊表示格,表 示目录或连结文件等等,d 表示目录,例如 drwx------;l 表示连结文件,如 lrwxrwxrwx;如果 是以一横"-"表示,则表示这是文件。其余剩下的格子就以每 3 格为一个单位。因为 Linux 是多用户多任务系统,所以一个文件可能同时被许多人使用,所以我们一定要设好每个文 件的权限,其文件的权限位置排列顺序是(以-rwxr-xr-x 为例): rwx(Owner)r-x(Group)r-x(Other) 这个例子表示的权限是:使用者自己可读,可写,可执行;同一组的用户可读,不可 写,可执行;其它用户可读,不可写,可执行。另外,有一些程序属性的执行部分不是 X, 而是 S,这表示执行这个程序的使用者,临时可以有和拥有者一样权力的身份来执行该程序。 一般出现在系统管理之类的指令或程序,让使用者执行时,拥有 root身份。 第二个栏位,表示文件个数。 如果是文件的话,那这个数目自然是 1 了,如果是目录的话,那它的数目就是该目录 中的文件个数了。 第三个栏位,表示该文件或目录的拥有者。 若使用者目前处于自己的 Home,那这一栏大概都是它的账号名称。 第四个栏位,表示所属的组(group)。 每一个使用者都可以拥有一个以上的组,不过大部分的使用者应该都只属于一个组,只 有当系统管理员希望给予某使用者特殊权限时,才可能会给他另一个组。 第五栏位,表示文件大小。 文件大小用 byte 来表示,而空目录一般都是 1024byte,你当然可以用其它参数使文件 显示的单位不同,如使用 ls -k 就是用 kb 莱显示一个文件的大小单位,不过一般我们还是以 byte 为主。 第六个栏位,表示创建日期。 以"月,日,时间"的格式表示,如 Aug 15 5:46表示 8 月15日早上 5:46分。 第七个栏位,表示文件名。 我们可以用 ls -a 显示隐藏的文件名。 Ls -F(注意,是大写的 F) 9 使用这个参数表示在文件的后面多添加表示文件类型的符号,例如*表示可执行,/表示 目录,@表示连结文件,这都是因为使用了-F这个参数。但是现在基本上所有的 Linux 发 行版本的 ls都已经内建了-F参数,也就是说,不用输入这个参数,我们也能看到各种分辨 符号。 2. cd命令 这个命令是用来进出目录的,它的使用方法和在
dos
下没什么两样,所以我觉得没什么 可说的,但有两点我补充一下。 首先,和
dos
不同的是Linux 的目录对大小写是敏感的,如果大小写没拼对,你的 cd 操作是成功不了的。 其次,cd如果直接输入,cd 后面不加任何东西,会回到使用者自己的 Home Directory。 假设如果是 root,那就是回到/root.这个功能同 cd ~是一样的。 3. mkdir,rmdir 命令 mkdir 命令用来建立新的目录,rmdir用来删除以建立的目录,这两个指令的功能不再 多加介绍,他们同
dos
下的 md,rd 功能和用法都是基本一样的。 4. cp命令 这个命令相当于
dos
下面的 copy命令,具体用法是: cp -r 源文件(source) 目的文件(target) 参数 r是指连同元文件中的子目录一同拷贝。熟悉
dos
的读者用起这个命令来会觉得更 方便,毕竟比在
dos
下面要少敲两下键盘。 5. rm 命令 这个命令是用来删除文件的,和
dos
下面的 rm(删除一个空目录)是有区别的,大家 千万要注意。Rm命令常用的参数有三个: -i,-r,-f。 比如我现在要删除一个名字为 text 的一个文件: rm -i test 系统会询问我们:"rm:remove 'test'?y",敲了回车以后,这个文件才会真的被删除。之 所以要这样做,是因为 linux 不象
dos
那样有 undelete 的命令,或者是可以用 pctool 等工具 将删除过的文件救回来,linux 中删除过的文件是救不回来的,所以使用这个参数在删除前 让你再确定一遍,是很有必要的。 rm -r 目录名 这个操作可以连同这个目录下面的子目录都删除,功能上和 rmdir相似。 rm -f 文件名(目录名) 这个操作可以进行强制删除。 6. mv 命令 这个命令的功能是移动目录或文件,引申的功能是给目录或文件重命名。它的用法同 10
dos
下面的 move 基本相同,这里不再多讲。当使用该命令来移动目录时,他会连同该目录 下面的子目录也一同移走。另外因为 linux 下面没有 rename 的命令,所以如果你想给一个 文件或目录重命名时可以用以下方法: mv 原文件(目录)名 新的文件(目录)名 7. du,df 命令 du 命令可以显示目前的目录所占的磁盘空间,df 命令可以显示目前磁盘剩余的磁盘空 间。 如果 du 命令不加任何参数,那么返回的是整个磁盘的使用情况,如果后面加了目录的 话,就是这个目录在磁盘上的使用情况(这个功能可是
dos
没有的呦)。不过我一般不喜欢 用 du,因为它给出的信息是在是太多了,我看不过来,而 df这个命令我是最常用的,因为 磁盘上还剩多少空间对我来说是很重要的。 8. cat 命令 这个命令是 linux 中非常重要的一个命令,它的功能是显示或连结一般的 ascii 文本文 件。cat是 concatenate 的简写,类似于
dos
下面的 type 命令。它的用法如下: cat text 显示 text 这个文件 cat file1 file2 依顺序显示 file1,file2的内容 cat file1 file2>file3 把 file1,file2 的内容结合起来,再"重定向(>)"到 file3文件中。 "〉"是一个非常有趣的符号,是往右重定向的意思,就是把左边的结果当成是输入,然 后输入到 file3 这个文件中。这里要注意一点是 file3 是在重定向以前还未存在的文件,如果 file3 是已经存在的文件,那么它本身的内容被覆盖,而变成 file1+file2的内容。 如果〉左边没有文件的名称,而右边有文件名,例如: cat >file1 结果是会"空出一行空白行",等待你输入文字,输入完毕后再按[Ctrl]+[c]或[Ctrl]+[d], 就会结束编辑,并产生 file1 这个文件,而 file1 的内容就是你刚刚输入的内容。这个过程和
dos
里面的copy con file1的结果是一样的。 另外,如果你使用如下的指令: cat file1>>file2 这将变成将 file1 的文件内容"附加"到 file2 的文件后面,而 file2 的内容依然存在,这种 重定向符〉〉比〉常用,可以多多利用。 9. more,less命令 这是两个显示一般文本文件的指令。 如果一个文本文件太长了超过一个屏幕的画面,用 cat 来看实在是不理想,就可以试试 more 和 less两个指令。More 指令可以使超过一页的文件临时
停留
在屏幕,等你按任何的一 个键以后,才继续显示。而 less 除了有 more 的功能以外,还可以用方向键往上或网下的滚 11动文件,所以你随意浏览,阅读文章时,less 是个非常好的选择。 10. clear 命令 这个命令是用来清除屏幕的,它不需要任何参数,和
dos
下面的 clr具有相同的功能, 如果你觉得屏幕太紊乱,就可以使用它清除屏幕上的信息。 11. pwd命令 这个命令的作用是显示用户当前的工作路径,这个命令不用多说,大家一试即知。 12. ln命令 这是 linux中又一个非常重要命令,请大家一定要熟悉。它的功能是为某一个文件在另 外一个位置建立一个同不的链接,这个命令最常用的参数是-s,具体用法是: ln -s 源文件 目标文件 当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都 放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在其它的目录下 用 ln 命令链接(link)它就可以,不必重复的占用磁盘空间。例如: ln -s /bin/less /usr/local/bin/less -s 是代号(symbolic)的意思。 这里有两点要注意:第一,ln 命令会保持每一处链接文件的同步性,也就是说,不论 你改动了哪一处,其它的文件都会发生相同的变化;第二,ln 的链接又软链接和硬链接两 种,软链接就是 ln -s ** **,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空 间,硬链接 ln ** **,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件, 无论是软链接还是硬链接,文件都保持同步变化。 如果你用ls 察看一个目录时,发现有的文件后面有一个@的符号,那就是一个用 ln 命 令生成的文件,用 ls -l命令去察看,就可以看到显示的 link 的路径了。 13. man命令 如果你的英文足够好,那完全可以不靠任何人就精通 linux,只要你会用 man。Man 实 际上就是察看指令用法的 help,学习任何一种 UNIX类的操作系统最重要的就是学会使用 man 这个辅助命令。man 是 manual(手册)的缩写字,它的说明非常的详细,但是因为它都是 英文,看起来非常的头痛。建议大家需要的时候再去看 man,平常吗,记得一些基本用法 就可以了。 14. logout 命令 一看就知道了,这是退出系统的命令,我就不多说了。要强调的一点是,linux是多用 户多进程的操作系统,因此如果你不用了,退出系统就可以了,关闭系统你就不用操心了, 那是系统管理员的事情。但有一点切记,即便你是单机使用 linux,logout 以后也不能直接 关机,因为这不是关机的命令。 15. Mount 命令 12这是 Linux 初学者问得最多的问题。由于大家已习惯了微软的访问方法,总想用类似 的思路来找到软盘和光盘。但在 Linux 下,却沿袭了 UNIX 将设备当作文件来处理的方法。 所以要访问软盘和光盘,就必须先将它们装载到 Linux 系统的/mnt 目录中来。 装载的命令是 mount,格式如下:mount -t 文件系统类型 设备名 装载目录 文件 系统类型就是分区格式,Linux 支持的文件系统类型有许多: ms
dos
DOS
分区文件系统类型 vfat 支持长文件名的
DOS
分区文件(可以理解为 Windows 文件)系统类型 iso9660 光盘的文件系统类型 ext2 Linux 的文件系统类型 ...... 设备名,指的是你要装载的设备的名称。软盘一般为/dev/fd0 fd1;光盘则根据你的 光驱的位置来决定,通常光驱装在第二硬盘的主盘位置就是/dev/hdc;如果访问的是
DOS
的 分区,则列出其设备名,如/dev/hda1 是指第一硬盘的第一个分区。 装载目录,就是你指 定设备的载入点。 z 装载软盘 首先用 mkdir /mnt/floppy 在/mnt 目录下建立一个空的 floppy目录,然后输入 mount -t ms
dos
/dev/fd0 /mnt/floppy 将
DOS
文件格式的一张软盘装载进来,以后就可以在 /mnt/floppy目录下找到这张软盘的所有内容。 z 装载 Windows 所在的C 盘 mkdir /mnt/c 在/mnt 目录下建立一个空的 c 目录; mount -t vfat /dev/hda1 /mnt/c 将Windows 的C盘按长文件名格式装载到/mnt/c 目 录下,以后在该目录下就能读写 C盘根目录中的内容 z 装载光盘 mkdir /mnt/cdrom 在/mnt 目录下建立一个空的 cdrom 目录; mount -t iso9660 /dev/hdc /mnt/cdrom 将光盘载入到文件系统中来, 将在/mnt/cdrom 目录下找到光盘内容。有的 Linux 版本允许用 mount /dev/cdrom 或 mount /mnt/cdrom 命 令装载光盘。 要注意的是,用 mount命令装入的是软盘、光盘,而不是软驱、光驱。有些初学者容易 犯一个毛病,以为用上面命令后,软驱就成了/mnt/floppy,光驱就成了/mnt/cdrom,其实 不然,当你要换一张光盘或软盘时,一定要先卸载,再对新盘重新装载。 z 卸载 卸载的命令格式是:umonut 目录名,例如要卸载软盘,可输入命令 umonut /mnt/floppy。 要注意的是,在卸载光盘之前,直接按光驱面板上的弹出键是不会起作用的。 13 四.基本的系统管理命令 系统管理基本上可以分为两种,一种是 root(系统管理员)对 linux的系统管理部分, root 本身的职责就是负责整个 linux系统的运行稳定,增加系统安全性,校验使用者的身份, 新增使用者或删除恶意的使用者,并明确每一个在机器上的使用者权限等等。另一种就是 每一个使用者(包括 root)对自己文件的权限管理。因为 linux 是多用户多任务系统,每一 个使用者都有可能将其工作的内容或是一些机密性的文件放在 Linux工作站上,所以对每个 文件或是目录的归属和使用权,都要有非常明确的规定。下面我就按管理员和一般用户分 类来介绍基本的系统管理命令。 z 管理员使用的系统管理指令 1. adduser 命令 新增使用者账号的命令,如果你想新增一个叫做 jack 的用户,那么需在
控制台
下输入: adduser jack 这样就增加了一个名字为 jazk 的用户,要注意这里对大小写是敏感的。另外,新增的 用户是没有口令的,你还应当为用户设置口令或者是吩咐用户在第一次登录系统的时候为 自己设置口令。 2. passwd命令 这个命令可以修改特定用户的口令,使用格式是: passwd 用户名 这是,系统会提示你输入新密码,你输入第一遍后,还要输入第二遍进行确认。输入 两遍相同的密码之后,系统就接受了新的密码。如果这个命令是一般用户来使用的话,那 就只能改变它自己的密码。 3. find,whereis,locate命令 这三个命令都是用来查找文件的,使用格式是: find 路径名称 -name 文件名 参数(我们这里就不讨论参数了) whereis 文件名 locate 文件名 一般来说,find 命令功能最为强大,但是对硬件的损耗也是最大的,当你使用 find 去 查找你个文件时,你会发现硬盘等在不停的闪动,这就意味着你的硬盘可能会比别人的少 用个三四年。当你使用whereis 或locate 去查找文件时,你会发现硬盘却是安安静静的,这 是因为这两个命令是从系统的数据库中查找文件,而不是去拼命的读硬盘。所以,如果平 常你只是想找一些笑文件的话,使用 whereis或 locate 就可以了,如果你是要进行系统管理 的工作,那么使用 find再加上一些参数就可以满足你的要求了。 144. su命令 这个命令可以让普通用户变成具有管理员权限的超级用户(superuser),只要它知道知 道管理员的密码就可以。多用户多任务系统的强调的重点之一就是系统的安全性,所以应 避免直接使用 root 身份登录系统去做一些日常性的操作,因为时间一久 root 密码就有可能 被知道而危害到系统安全。所以平常应避免用 root 身份登录,即使要管理系统,也请尽量 使用 su 指令来临时管理系统,然后记住定期的更换 root 密码。 加入你现在是以一个普通用户的身份登录系统,现在你输入: su 系统会要求你输入管理员的口令,当你输入正确的密码后,就可以获得全部的管理员 权限,这是你就是超级用户(superuser)。但你执行完各种管理操作以后,只要输入 logout 就 可以退回到原先的那个普通用户的状态。 5. shutdown,halt 命令 这两个命令是用来关闭 linux 操作系统的。 在前面我说过,作为一个普通用户是不能够随便关闭系统的,因为虽然你用完了机器, 可是这时候可能还有其它的用户正在使用系统。因此,关闭系统或者是重新启动系统的操 作只有管理员才有权执行。另外 linux 系统在执行的时候会用部分的内存作缓存区,如果内 存上的数据还没有写入硬盘,就把电源拔掉,内存就会丢失数据,如果这些数据是和系统 本身有关的,那么会对系统造成极大的伤害。一般,我们建议在关机之前执行三次同步指 令 sync,可以用分号";"来把指令合并在一起执行,如: # sync;sync;sync 使用 shutdown 关闭系统的时候有以下几种格式: shutdown (系统内置 2分钟关机,并传送一些消息给正在使用的 user) shutdown -h now (下完这个指令,系统立刻关机) shutdown -r now (下完这个指令,系统立刻重新启动,相当于 reboot) shutdown -h 20:25 (系统会在今天的 20:25 关机) shutdown -h +10 (系统会在十分钟后关机) 如果在关机之前,要传送信息给正在机器上的使用者,可以加"-q"的参数,则会输出系 统内置的 shutdown 信息给使用者,通知他们离线。 halt 命令就不用多说了,只要你输入 halt,系统就会开始进入关闭过程,其效果和 shutdown -h now是完全一样的,我每次关机的时候都是用 halt。 6. reboot 命令 一看这个词,就知道这个命令是用来重新启动系统的。 当你输入 reboot 后,你就会看到系统正在将一个一个的服务都关闭掉,然后再关闭文 件系统和硬件,接着机器开始重新自检,重新引导,再次进入 linux 系统。 15z 普通用户使用的系统管理指令 1. chown命令 这个命令的作用是改变文件的所有者。 如果你有一个文件名为 classment.list 的文件,所有权要给于另一个账号为 golden的同 学,则可用 chown 来实现这个操作,但是当你改变了文件的所有者以后,该文件虽然在你 的 Home 目录下,可是你已经无任何修改或删除该文件的权限了,这一点同学们千万要注 意。通常会用到这个指令的时机,应该是你想让 linux 机器上的某位使用者到你的 Home 下 去用谋个文件是会用到。不过,泼出去的水就收不回来了,你用这个命令的时候可一定要 想清楚呦。 2. chmod命令 这个命令用来改变目录或文件的属性,是 linux 中一个应当熟悉的命令。 对这个命令,使用的方法很多,鉴于篇幅的原因,我只例出其中我最常用的一种。前 面讲过,一个文件用 10个小格来记录文件的权限。前三个小格是拥有者(user)本身的权 限,中间三个小格是和使用者同一组的成员(group)的权限,最后三个小格是表示其它使 用者(other)的权限。现在我们用三位的 2 进制数来表示相应的三小格的权限,例如: 111 rwx 101 r-x 011 -wx 001 -x 100 r- 这样一来,我们就可以用三个十进制的数来表示一个文件属性位上的十个格,其中每 一个十进制数大小等于代表每三格的那个三位的二进制数。例如,如果一个文件的属性是: rwxr-r--,那么我们就可以用 744 来代表它的权限属性;如果一个文件的属性是:rwxrwxr--, 那它对应的三个十进制数就是 774。这样一来我们就可以用这种简便的方法指定文件的属性 了。例如,我想把一个文件 test.list的属性设置为 rwxr-x---,那么我只要执行: chmod 750 test.list 就可以了,对于改变后的权限,你用 ls -l 就可以看到。 五.关於 Process 处理的指令 1. ps ps 是用来显示目前你的 process 或系统 processes 的状况。 以下列出比较常用的参数: 其选项说明如下: -a 列出包括其他 users 的 process 状况。 -u 显示 user - oriented 的 process 状况 。 -x 显示包括没有 terminal 控制的 process 状况 。 -w 使用较宽的显示模式来显示 process 状况 。 16我们可以经由 ps 取得目前 processes 的状况,如 pid , running state 等。 2. kill kill 指令的用途是送一个 signal 给某一个 process 。因为大部份送的都是用来杀掉 process 的 SIGKILL 或 SIGHUP ,因此称为 kill 。kill 的用法 为: kill [ -SIGNAL ] pid ... kill –l SIGNAL 为一个 singal 的数字,从 0 到 31 ,其中 9 是 SIGKILL ,也就是一般用来 杀掉一些无法正常 terminate 的讯号。其馀讯号的用途可参考 sigvec(2)中对 signal 的 说明。你也可以用 kill -l 来察看可代替 signal 号码的数目字。kill 的详细情形请参 阅 man kill。 六. 关於字串处理的指令 1. echo echo 是用来显示一字串在终端机上。□ echo -n 则是当显示完之後不会有跳行的动 作。 2. grep/fgrep grep 为一过滤器,它可自一个或多个档案中过滤出具有某个字串的行,或是自标准 输入过滤出具有某个字串的行。 fgrep 可将欲过滤的一群字串放在某一个档案中,然後使用 fgrep 将包含有属於这 一群字串的行过滤出来。 grep 与 fgrep 的用法如下: grep [-nv] match_pattern file1 file2 .... fgrep [-nv] -f pattern_file file1 file2 ... -n 把所找到的行在行前加上行号列出 -v 把不包含 match_pattern 的行列出 match_pattern 所要搜寻的字串 -f 以 pattern_file 存放所要搜寻的字串 七. 网路上查询状况的指令 1. man 17man 是手册 ( manual ) 的意思。 UNIX 提供线上辅助( on-line help )的功能, man 就 是用来让使用者在使用时查询指令、系统呼叫、标准程式库函式、各种表格等的使用所用 的。man 的用法如下: man [-M path] [[section] title ] ..... man [-M path] -k keyword ... -M path man 所需要的 manual database 的路径。 我们也可以用设定环境变数 MANPATH 的方式来取代 -M 选项。 title 这是所要查询的目的物。 section 为一个数字表示 manual 的分类,通常 1 代表可执行指令,2 代表系统呼叫 ( system call ) ,3 代表标准函数,等等。 我们如要参考 eqnchar(7) 的资料,则我们就输入 man 7 eqnchar ,便能取得我们所要 的辅助讯息。 -k keyword 用来将含有这项 keyword 的 title 列出来。 man 在 UNIX 上是一项非常重要的指令,我们在本讲义中所述之用法均仅只是一个大家 比较常用的用法以及简单的说明,真正详细的用法与说明还是要请你使用 man 来得到。 2. who who 指令是用来查询目前有那些人在线上。 3. w w 指令是用来查询目前有那些人在线上,同时显示出那些人目前的工作。 4. ku ku 可以用来搜寻整个网路上的 user , 不像 w 跟 who 只是针对 local host 的查询. 而且 ku 提供让使用者建立搜寻特定使用者名单的功能。你可以建立一个档案 information-file 以条列的方式存放你的朋友的资料,再建立一个档案 hosts-file 来指 定搜寻的机器名称。 ku 的指令格式可由 ku -h 得到。 八. 网路指令 UNIX 提供网路的连接,使得你可以在各个不同的机器上做一些特殊的事情,如你可以 在系上的 iris 图形工作站上做图形的处理,在系上的 Sun 上读 News ,甚至到学校的计 中去找别系的同学 talk 。这些工作可以利用 UNIX 的网路指令,在你的位子上连到各个 不同的机器上工作。如此一来,即使你在寝室,也能轻易的连至系上或计中来工作,不用 像以前的人必须泡在冷冰冰的机房面。 这些网路的指令如下所述: 181. rlogin 与 rsh rlogin 的意义是 remote login , 也就是经由网路到另外一部机器 login 。 rlogin 的格式是: rlogin host [ -l username ] 选项 -l username 是当你在远方的机器上的 username 和 local host 不同的时後, 必须输入的选项,否则 rlogin 将会假设你在那边的 username 与 localhost 相同,然後 在第一次 login 时必然会发生错误。 rsh 是在远方的机器上执行某些指令,而把结果传回 local host 。rsh 的格式如下: rsh host [ -l username ] [ command ] 如同 rlogin 的参数 -l username , rsh 的 -l username 也是指定 remote host 的 username 。而 command 则是要在 remote host 上执行的指令。如果没有 指定 command , 则 rsh 会去执行 rlogin ,如同直接执行 rlogin 。 不过 rsh 在执行的时候并不会像一般的 login 程序一样还会问你 password , 而是 如果你没有设定 trust table , 则 remote host 将不会接受你的 request 。 rsh 须要在每个可能会做为 remote host 的机器上设定一个档案,称为 .rhosts。这 个档案每一行分为两个部份,第一个是允许 login 的 hostname , 第二个部份则是允许 login 的username 。 例如, 在 ccsun7.csie.nctu.edu.tw 上头你的 username 为 QiangGe , 而你的 home 下面的 .rhost 有以下的一行: ccsun6.cc.nctu.edu.tw u8217529 则在 ccsun6.cc.nctu.edu.tw 机器上的 user u8217529 就可以用以下的方法来执行 rsh 程式: % rsh ccsun7.csie.nctu.edu.tw -l ysjuang cat mbox 将 ysjuang 在 ccsun7.csie.nctu.edu.tw 上的 mbox 档案内容显示在 local host ccsun6.cc.nctu.edu.tw 上。 而如果 .rhost 有这样的一行,则 ccsun6.cc.nctu.edu.tw 上的 user u8217529 将可以不用输入 password 而直接经由 rsh 或 rlogin login 到 ccsun7.csie.nctu.edu.tw 来。 注意: .rhost 是一个设定可以信任的人 login 的表格,因此如果设定不当将会让不法之徒 有可以乘机侵入系统的机会。 如果你阅读 man 5 rhosts ,将会发现你可以在第一栏用 + 来取代任何 hostname ,第二栏用 + 来取代任何 username 。 如一般 user 喜欢偷懒利用 " + username " 来代替列一长串 hostname ,但是这样 将会使得即使有一台 PC 上跑 UNIX 的 user 有与你相同的 username , 也可以得到你的 trust 而侵入你的系统。这样容易造成系统安全上的危险。因此本系禁止使用这样子的方 19式写你的 .rhost 档,如果发现将予以停机直到你找中心的工作人员将其改正为止。 同理, 如果你的第二个栏位为 + , 如"hostname + " ,则你是允许在某一部机器上的"所有"user 可 以不用经由输入 password 来进入你的帐号,是壹种更危险的行为。所以请自行小心。 2. telnet telnet 是一个提供 user 经由网路连到 remote host。 telnet 的格式如下: telnet [ hostname | ip-address ] [ port ] hostname 为一个像 ccsun1 或是 ccsun1.cc.nctu.edu.tw 的 nameaddress, ip-address 则为一个由四个小於 255 的数字组成的 ip address ,如 ccsun1 的 ip-address 为 140.113.17.173 ccsun1.cc.nctu.edu.tw 的 ip-address 为 140.113.4.11 。你可以利用 telnet ccsun1 或telnet 140.113.17.173 来连到 ccsun1。 port 为一些特殊的程式所提供给外界的沟通点, 如资工系的 MUD 其 server 便提 供一些 port 让 user 由这些 port 进入 MUD 程式。详情请参阅 telnet(1)的说明。 3. ftp ftp 的意义是 File Transfer Program ,是一个很常应用在网路档案传输的程式。ftp 的格式如下: ftp [ hostname | ip-address ] 其中 hostname | ip-address 的意义跟 telnet 中的相同。 在进入 ftp 之後,如果与 remote host 连接上了,它将会询问你 username 与密码, 如果输入对了就可以开始进行档案传输。 在 ftp 中有许多的命令,详细的使用方式请参考 ftp(1) ,这里仅列出较常用的 cd , lcd , mkdir , put , mput , get , mget , binary , ascii , prompt , help 与 quit 的 使用方式。 ascii 将传输模式设为 ascii 模式。通常用於传送文字档。 binary 将传输模式设为 binary 模式,通常用於传送执行档,压缩档与影像档等。 cd remote-directory 将 remote host 上的工作目录改变。 lcd [ directory ] 更改 local host 的工作目录。 ls [ remote-directory ] [ local-file ] 列出 remote host 上的档案。 get remote-file [ local-file ] 取得远方的档案。 mget remote-files 可使用通用字元一次取得多个档案。 put local-file [ remote-file] 将 local host 的档案送到 remote host。 mput local-files 可使用通用字元一次将多个档案放到 remote host 上。 help [ command ] 线上辅助指令。 20mkdir directory-name 在 remote host 造一个目录。 prompt 更改交谈模式,若为 on 则在 mput 与 mget 时每作一个档案之传输时均会询 问。 quit/bye 离开ftp . 利用 ftp ,我们便可以在不同的机器上将所需要的资料做转移,某些特别的机器更存 放大量的资料以供各地的使用者抓取,本校较著名的 ftp server 有 NCTUCCCA 与系上的 ftp.csie.nctu.edu.tw 。这些 ftp server 均有提供一个 user 称为 anonymous ,一般 的"外来客"可以利用这个 username取得该 server 的公共资料。不过 anonymous 在询问 password 时是要求使用 anonymous 的使用者输入其 email address,以往有许多台湾的使 用者在使用国外的 ftp server 时并没有按照人家的要求输入其 email address,而仅是随 便打一些字串,引起许多 internet user 和管理者的不满,对台湾的使用者的风评变得很 差,因此遵循各 ftp server 的使用规则也是一件相当重要的事。 九. 关於通讯用的指令 1. write 这个指令是提供使用者传送讯息给另一个使用者,使用方式: write username [tty] 2. talk/ytalk/cytalk/ctalk UNIX 专用的交谈程式。会将萤幕分隔开为你的区域和交谈对象的区域,同时也可和不 同机器的使用者交谈。使用方式: talk username[@host] [tty] 3. mesg 选择是否接受他人的 messege , 若为 messege no 则他人的 messege 将无法传送给 你,同时他也无法干扰你的工作。使用方法: mesg [-n|-y] 4. mail/elm 在网路上的 email 程式,可经由此程式将信件 mail 给他人。 使用方式: mail [username] mail -f mailboxfile 如有信件,则直接键入 mail 可以读取你的 mail . elm 提供较 mail 更为方便的介面,而且可做线上的 alias . 你可以进入 elm 使用上下 左右键来选读取的信件,并可按 h 取得线上的 help 文件。 21使用方式: elm [usernmae] elm -f mailboxfile 十. 编译器( Compiler ) Compiler 的用处在於将你所撰写的程式翻译成一个可执行档案。在资工系常用的程式语 言是 C , pascal , FORTRAN 等。你可以先写好一个 C 或 Pascal 或 FORTRAN 的原始程 式档,再用这些 compiler 将其翻成可执行档。你可以用这个方法来制造你自己的特殊指 令。 1. cc/gcc (C Compiler) /usr/bin/cc /usr/local/bin/gcc 语法: cc [ -o execfile ] source gcc [ -o execfile ] source execfile 是你所希望的执行档的名称,如果没有加上 -o 选项编译出来的可执行档会以 a.out 做为档名。 source 为一个以 .c 做为结尾的 C 程式档。请参阅 cc(1) 的说明。 2. pc (Pascal Compiler) /usr/local/bin/pc 语法: pc [ -o execfile ] source execfile 是你所希望的执行档的名称,如果没有加上 -o 选项编译出来的可执行档会 以 a.out 做为档名。 source 为一个以 .p 做为结尾的 Pascal 程式档。 请参阅 /net/home5/lang/man 中 pc(1) 的说明。 3. f77 (Fortran Compiler) /net/home5/lang/f77 语法: f77 [ -o execfile ] source execfile 是你所希望的执行档的名称,如果没有加上 -o 选项编译出来的可执行档会以 a.out 做为档名。 source 为一个以 .p 做为结尾的 FORTRAN 程式档。 十一. 有关列印的指令 以下为印表所会用到的指令,在本系的印表机有 lp1 , lp2 ( 点矩阵印表机 ), lw , sp , ps , compaq ( 雷射印表机 ),供使用者使用。 221. lpr lpr 为用来将一个档案印至列表机的指令。用法: lpr -P[ printer ] file1 file2 file3 ... 或 lpr -P[ printer ] < file1 例子: lpr -Plp1 hello.c hello.lst hello.map lpr -Plp1 < hello.c 前者以参数输入所要印出的档案内容,後者列印标准输入档案(standard input)的内 容,因已将 hello.c 转向到标准输入,故会印出 hello.c 的档案内容。 2. lpq lpq 是用来观察 printer queue 上的 Jobs 。用法: lpq -P[ printer ] 3. lprm lprm 是用来取消列印要求的指令。 通常我们有时会印错,或是误送非文字档资料至 printer , 此时就必须利用 lprm 取消列印 request ,以免造成资源的浪费。 用法: lprm -P[ printer ] [ Jobs id | username ] lprm 用来清除 printer queue 中的 Jobs , 如果你使用 Job Id 作为参数,则它将此 Job 自 printer queue 清除,如果你用 username 作为参数,则它将此 queue 中所有 Owner 为此 username 的 Jobs 清除。 到这里,我们第二讲的内容就基本结束了,可以说,这一讲是比较无聊的,但它又是 必不可少的。这里列出的仅仅是最最常用的
控制台
命令,要进一步的熟悉 Linux操作系统, 了解类 UNIX 操作系统的管理思想,我们还有很多要学习,有兴趣的同学可以参看其它的 相关参考书籍。 23 第三讲 Linux下的网络服务,配置问题和 常用工具 这一讲我们会接触到 Linux 下能够提供的一些典型的网络服务,大家会对这些服务有 一个感性的认识,除此之外我们还会看到 Linux下面一些非常重要的配置文件以及他们的用 法。最后我们会看到 Linux 下面最常用的几个工具软件。 一.Linux下的网络服务 一般来说,各种操作系统在网络方面的性能比较是这样的顺序 BSD>Linux>Win NT>Win 9X, 由此说来,Linux 的网络功能仅次于 UNIX,而强于 Win NT 和其它的视窗系 列产品,对于 Win2000我还不能评价太多,因为不是很熟。 Linux 的网络功能除了基本的连线功能如 telnet, ftp, rsh, login, finger等等以外,架设各 种服务器的功能更把 Linux 网络功能发挥的淋漓尽致,下面我大概的为大家介绍一下 Linux 下的各种网络服务。 1. Mail Server Email 现在是网络上最重要的服务了,你可能没有用过 FTP, BBS, INN,但是如果你连电 子邮件都没有用过,那作为 BUPT 的一员,你得自己好好反省一下了。 现在又很多功能强大的 mailserver供你选择,例如 freemail.263.net, hotmail.com, freemail.sohu.com,等等,这些都是免费的。但这是从使用者角度来看,如果你是想为一个局 域网内部提供一个交换电子邮件的服务,那它们对你来说可就是一笔巨款了,再说人家卖 不卖给你还不好说呢。Linux 下面最著名的 mail server是 Sendmail,它是一个负责监控和传 送电子邮件的邮件代理程序,你使用它就可以在在一个小的局域网(例如宿舍网)里提供 一个电子邮件服务,这是多么神奇的事情啊!使用 Linux 下面的 MailServer最大的好处是性 价比高,这些软件的功能强大,却又是完全免费的,我们完全不用去花几万元买一个功能 有限还要按照人头收费的 Exchange Server,或者是使用 D版软件被别人扎脊梁骨。 2. Router 和 Gateway 如果你的计算机可以连接到外面的 Internet 上去, 然而一些可以连接到你这台机器上的 24计算机却只能访问里面的局域网,那么你可以安装 Router或 Gateway的服务,这样别人就 可以通过你的机器和外面的世界联系了。当然了,这么做的前提是你有一颗大公无私的信, 要我就不行,我可舍不得把我的 PIII 的机器贡献给宿舍的网虫们。 3. Samba 在 Windows 横行的今天,Samba 的出现对于 Linux 的茁壮成长是非常重要的,它大大 拓宽了 Linux 的应用领域。Samba 可以提供一种转换 SMB(windows 使用的一种信息格式) 和 NFS(Linux 使用的一种信息格式)的服务,通过 Samba, 运行 Windows的工作站就可以 同运行 Linux 的服务器之间进行通信,还可以 让网络上的使用者(包括 Windows 用户)共 享一台打印机,这样 Linux 的服务器就可以运行在 Windows的环境中了。 4. NFS Server Linux 还可以作为文件服务器,为网络上具有存取权限的 Windows/Linux机器分享相同 的文件系统,这样一来,不论是在 Windows 还是在 Linux 的网络中,Linux 的文件服务器都 能够发挥作用了。 5. Terminal Server 这种服务能够提供 PPP/SLIP Dialup(包括 multi-port,就是一台计算机连多个调制解调器 上网),让一般的民用网络 Moden 使用者可通过 Terminal Server与 Internet连接起来。 6. BBS 在北邮如果你没有上过 BBS(Bulletin Board System电子布告版)我会很吃惊的, 202.112.101.44 或者是202.204.7.235 你至少应该去过一个吧?如果没有去过,那么赶快把这 一课补上。关于 BBS到底能做什么我就不多说了,我假定你已经知道了,现在网络上流行 的免费 BBS版本很多,著名的有 Phoenix,Maple,Firebird,Pivot等等,这些都可以在 Linux 上 使用。另外还有许多基于 WWW 的 BBS,例如著名的跨平台的 Motiff Community,可以非 常稳定的在 Linux 下运行,这是"瘟都死"所不能比拟的。 7. WWW 在 Linux下面也有功能强大的 WWW服务器,你完全可以不必去使用又贵又不稳定的 IIS。但是不可否认 IIS 的操作非常的简单,如果你觉得自己有钱,可以买得起 Win2000 Advanced Server,又出得起"人头税",那你就用"瘟都死"吧。在 Linux 上的 WWW服务程序 很多,现在最著名最流行的是 Apache,在北邮,有许多的服务器就是跑 Apache 的。现在在 Linux 上使用 Apache+PHP+MySQL 是实现动态页面的最佳搭配,立志于搞网站建设的朋友 可一定要留心这一块,因为它可以为你的网站建设节省大笔的成本(现在可是操作系统比 机器贵)。我知道一个讨论组:www.coventive.com.cn/club/default.htm,它就是用 Apache+PHP+MySQL 这种组合建立起来的,有兴趣的朋友可以去看看。 25 二.几种重要的配置文件 Linux 下面的配置文件非常的多,对于初学者来说,我们只需要知道最最常用的几个配 置文件就可以了。由于片符合时间的原因,在这里我只介绍四个非常经典的配置文件 (lilo.conf, passwd,inittab,fasttab),这四个文件中我重点介绍 lilo.conf,其余三个文件会简单的 在课堂上演示。至于 Linux 其它众多的配置文件必须各位同学自己下去查找相关资料自己学 习了。 1. lilo.conf 这是 Linuxloader(lilo)的配置文件。对于初学者来说,这个配置文件是非常重要的,因 为它直接关系到你的系统是否能够正确的引导到 Linux 上来。 我在这里主要将一下如何使用 lilo 实现多个在一台机器上安装多个操作系统。 一般来说,第一次安装 Linux 后,缺省引导的系统是 Linux,但是对大多数 Linux 用户 来说,他们使用 windows 的时间会多于 Linux,所以我们最好能够将缺省引导的系统改为 windows,这样的话,就省去了每次启动时敲一串字符的麻烦。要修改引导顺序,就要修改 Linux 系统中的一个配置文件,这个文件就是/etc/lilo.conf。我使用的是 Xlinux OS 1.5,用 vi 打开这个文件后,会出现下面的文字: boot=/dev/hda map=/boot/map install=/boot/boot.b prompt timeout=100 linear default=xlinux image=/boot/vmlinuz-2.2.14-5.0 read-only root=/dev/hda4 other=/dev/hda1 label=win 这就是刚刚安装完毕后的 LILO配制文件.这个文件是按照由前到后顺序引用的,通过修 改这个文件就可以改变 lilo 执行时的一些特性.首先我将这个文件中比较重要的几个地方给 大家介绍一下: 首先请看第 5 行:timeout=100,这是一个设置在 lilo 引导缺省的系统之前等候用户输入系 统别名的等候时间长度.它的时长好象不是按秒一级的数量级进行计算的,总之用户可以按 照自己的实际需要设置相应的时长.我一般是设置成 timeout=500. 然后我们看第 7 行:default=xlinux,这里是关键之一!这一行指明缺省引导的系统的别名 26是 xlinux,要想改变系统的缺省引导顺序,这里是需要修改的,稍后就会说到是怎么修改的. 再看第8行到第 11 行,这四行指明了引导 Linux 系统的一些细节. image=/boot/vmlinuz-2.2.14-5.0指明了操作系统核心是放在哪里的,以便于引导程序装载操作 系统核心;label=xlinux指明了引导这个操作系统时用的别名,这里是xlinux; root=/dev/hda4指 明了引导程序需要到哪一个硬盘的第几个分区去寻找 init 过程,在这里是要到第一个硬盘的 第四个分区中去将引导系统的控制权交给这个分区里的 init过程. 最后我们看看文件中的最后两行.other=/dev/hda1说明除了linux操作系统以外,机器中还 安装了别的操作系统(当然我知道这个另外的操作系统是我的 win2000了),它位于第一块硬 盘中的第一个分区,一般来说,这个路径是在安装的时候就设置好的,不需要我们手工修改,但 是我认为知道这些信息还是很有必要的;label=win指明了这个系统引导时使用的别名为win. 因为 lilo 是顺序引用的,所以如果我们想要让缺省引导的系统变成 windows,就需要将这两行 移动到 image=.....那一行之前的位置,我建议的位置是放在 image=...之前和default=.....之后. 这是关键之二! 当你将前面的两个关键步骤完成之后,还需要将default=....那一行改成 default=win,这是 比较重要的一步,虽然即使你不改动这里,系统也可以按照你的想法去引导,但是我可不敢保 证你这样做不会出一点问题.再说,如果你不改动这里那多别扭啊! 做到这里,我们对lilo.conf这个文件的改动就结束了,然后只要退出vi,然后键入 lilo -v -v -v这个命令来更新一下LILO,我们就大功告成了.当你reboot以后,就会发现在"lilo:"那里敲入 回车键后,系统就会缺省的引导到 windows 系统去了. 2. Passwd 这个配置文件是关于用户口令的。如果你是一名系统管理员,有可能会一次新增很多 的用户,这时用 adduser就相当麻烦了。一般有功力的管理员会直接去修改/etc/passwd 文件。 利用 passwd文件,可以控制用户的口令状态及一些个人配置。 对于这个文件,普通单机用户使用的并不是很多,主要是多用户的管理员使用,对于 它的一些基本配置方法,我会在课堂上为同学们演示,这里不再赘述。 3. Inittab和 fasttab 这两个文件都是存放在/etc 这个目录下面的,Inittab 文件用来配置 Linux 初始化的一些 动作,我们最常用的是设定 Linux 的启动方式。Fasttab 文件用来设定一些在 Linux 启动时的 动作,主要是文件系统或者是外设的挂接动作,如果你想让你的 Linux 一开始就能够使用光 盘驱动器,就可以把 mount 指令加到这个文件中去。 因为这两个文件对我们初学者来说,可以利用的地方不是很多,所以我不用过多的文 字来描述它们的功能,具体的操作我会在课堂上为同学们演示,这里不再赘述。 27 三.Linux下常用的工具软件 这里我会为大家介绍 Linux 世界里最常用的几种工具软件,包括:vi, tar, gzip, rpm。 1. 文字编辑 vi 是Linux(UNIX)世界最强大的文本编辑工具,我在第一讲中提到过它,现在我把它的 一些基本使用方法介绍给大家。 Vi 的三种状态 Command mode : 控制萤幕游标之移动,字元或游标之删除,搬移复制某 区段及进入 Insert mode 下,或者到 Last line mode 。 Insert mode : 唯有在 Insert mode 下, 才可做文字资料输入,按 Esc 键可到 Command mode 。 Last line mode : 将档案写入或离开编辑器,亦可设定编辑环境, 如寻找字 串、列出行号..等。 vi 的基本操作 进入 vi 1. 在系统提示符号下输入 vi 及档案名称後即进入 vi 全萤幕编辑画面,且在 Command mode 下。 切换至 Insert mode 编辑文件: 在 Command mode 下可按 'i' 或 'a' 或 'o' 三键进入 Insert mode。 离开 vi 及存档: 在 Command mode 下可按 ':' 键进入 Last line mode, :w filename (存入指定档案) :wq (写入并离开 vi) :q! (离开并放弃编辑的档案) Command mode 下功能键简介 1. 进入 Insert mode i : 插入, 从目前游标所在之处插入所输入之文字。 a : 增加, 目前游标所在之下一个字开始输入文字。 o : 从新的一行行首开始输入文字。 2. 移动游标
Windows 系统错误代码简单分析
Microsoft Windows 系统错误代码简单分析: 0000 操作已成功完成。 0001 错误的函数。 0002 系统找不到指定的文件。 0003 系统找不到指定的路径。 0004 系统无法打开文件。 0005 拒绝访问。 0006 句柄无效。 0007 存储区控制块已损坏。 0008 可用的存储区不足, 无法执行该命令。 0009 存储区控制块地址无效。 0010 环境错误。 0011 试图使用不正确的格式加载程序。 0012 访问代码无效。 0013 数据无效。 0014 可用的存储区不足,无法完成该操作。 0015 系统找不到指定的驱动器。 0016 无法删除该目录。 0017 系统无法将文件移到其他磁盘驱动器上。 0018 没有其他文件。 0019 媒体写保护。 0020 系统找不到指定的设备。 0021 设备尚未准备好。 0022 设备无法识别该命令。 0023 数据错误(循环冗余检查)。 0024 程序发出命令,但是该命令的长度错误。 0025 驱动器在磁盘上无法定位指定的区域或磁道。 0026 无法访问指定的磁盘或软盘。 0027 驱动器找不到所请求的扇区。 0028 打印机缺纸。 0029 系统无法写入指定的设备。 0030 系统无法读取指定的设备。 0031 与系统连接的设备不能正常运转。 0032 其他进程正使用该文件,因此现在无法访问。 0033 另一进程已锁定该文件的某一部分,因此现在无法访问。 0034 驱动器中的软盘不正确。请将 %2 (卷标序列号: %3)插入驱动器 %1。 0036 打开共享的文件太多。 0038 已到达文件结尾。 0039 磁盘已满。 0050 不支持此网络请求。 0051 远程计算机无法使用。 0052 网络中存在重名。 0053 找不到网络路径。 0054 网络正忙。 0055 指定的网络资源或设备已不可用。 0056 已经达到网络命令的极限。 0057 网络适配器出现错误。 0058 指定的服务器无法执行所请求的操作。 0059 网络出现意外错误。 0060 远程适配器不兼容。 0061 打印机队列已满。 0062 服务器上没有存储等待打印的文件的空间。 0063 已经删除等候打印的文件。 0064 指定的网络名无法使用。 0065 拒绝访问网络。 0066 网络资源类型错误。 0067 找不到网络名。 0068 已超过本地计算机网络适配器卡的名称极限。 0069 已超过网络 BIOS 会话的极限。 0070 远程服务器已经暂停或者正在启动过程中。 0071 由于该计算机的连接数目已达到上限,此时无法再连接到该远程计算机。 0072 指定的打印机或磁盘设备已经暂停。 0080 该文件存在。 0082 无法创建该目录或文件。 0083 INT 24 失败。 0084 处理该请求的存储区不可用。 0085 正在使用该本地设备名。 0086 指定的网络密码不正确。 0087 参数错误。 0088 网络出现写入错误。 0089 此时系统无法启动其他进程。 0100 无法创建其他系统标志。 0101 属于其他进程的专用标志。 0102 标志已经设置, 无法关闭。 0103 无法再次设置该标志。 0104 中断时无法请求专用标志。 0105 此标志先前的所有权已终止。 0106 请将软盘插入驱动器 %1。 0107 后续软盘尚未插入,程序停止。 0108 磁盘正在使用或已由其他进程锁定。 0109 管道已经结束。 0110 系统无法打开指定的设备或文件。 0111 文件名太长。 0112 磁盘空间不足。 0113 没有其他可用的内部文件标识符。 0114 目标内部文件标识符不正确。 0117 该应用程序所运行的 IOCTL 调用不正确。 0118 校验写入的开关参数值不正确。 0119 系统不支持所请求的命令。 0120 该系统上不支持此功能。 0121 标记已超时。 0123 文件名、目录名或卷标语法错误。 0124 系统调用层不正确。 0125 磁盘没有卷标。 0126 找不到指定的模块。 0127 找不到指定的过程。 0128 没有要等候的子进程。 0129 模式下运行。 0130 试图使用操作(而非原始磁盘I/O)的已打开磁盘分区的文件句柄。 0131 试图将文件指针移至文件开头之前。 0132 无法在指定的设备或文件中设置文件指针。 0133 对于包含已连接驱动器的驱动器,不能使用 JOIN 或 SUBST 命令。 0134 试图在已经连接的驱动器上使用 JOIN 或 SUBST 命令。 0135 试图在已经替换的驱动器上使用 JOIN 或 SUBST 命令。 0136 系统试图删除尚未连接的驱动器的 JOIN。 0137 系统试图删除尚未替换的驱动器的替换项。 0138 系统试图将驱动器连接到已连接的驱动器下的目录。 0139 系统试图将驱动器替换成已替换的驱动器下的目录。 0140 系统试图将驱动器连接到已替换的驱动器的一个目录中。 0141 系统试图将驱动器替换成到已连接的驱动器下的目录。 0142 此时系统无法运行 JOIN 或 SUBST。 0143 系统无法将驱动器连接到或替换成同一驱动器下的目录。 0144 此目录不是该根目录的子目录。 0145 该目录未清空。 0146 指定的路径已经在替换中使用。 0147 资源不足,无法执行该命令。 0148 此时无法使用指定的路径。 0149 试图连接或替换某个驱动器目录,该驱动器上的某个目录是上一次替换的目标目录。 0150 CONFIG.SYS 文件未指定系统跟踪信息,或禁止跟踪。 0151
Dos
MuxSemWait 的指定信号事件的数目不正确。 0152
Dos
MuxSemWait 没有运行;已经设置太多的标志。 0153
Dos
MuxSemWait 列表不正确。 0154 输入的卷标超过目标文件系统的标号字符长度极限。 0155 无法创建其他线程。 0156 接收进程拒绝该信号。 0157 已经放弃该区域,因此无法锁定。 0158 该区域已经解除锁定。 0159 线程标识符的地址错误。 0160 传到
Dos
ExecPgm 的参数字符串错误。 0161 指定的路径无效。 0162 信号已挂起。 0164 系统无法创建其他线程。 0167 无法锁定文件的范围。 0170 所要求的资源正在使用中。 0173 锁定请求对于提供的取消区域不重要。 0174 文件系统不支持到锁定类型的自动更改。 0180 系统检测到错误的区域号码。 0182 操作系统无法运行 %1。 0183 不能创建已经存在的文件。 0186 传送的标志不正确。 0187 找不到指定的系统信号名称。 0188 操作系统无法运行 %1。 0189 操作系统无法运行 %1。 0190 操作系统无法运行 %1。 0191 无法在 Win32 模式下运行 %1。 0192 操作系统无法运行 %1。 0193 %1 不是有效的 Win32 应用程序。 0194 操作系统无法运行 %1。 0195 操作系统无法运行 %1。 0196 操作系统无法运行此应用程序。 0197 当前无法配置操作系统运行此应用程序。 0198 操作系统无法运行 %1。 0199 操作系统无法运行此应用程序。 0200 代码段应小于 64K。 0201 操作系统无法运行 %1。 0202 操作系统无法运行 %1。 0203 系统找不到输入的环境选项。 0205 在命令子树中的进程没有信号句柄。 0206 文件名或扩展名太长。 0207 环 2 堆栈正在使用中。 0208 输入的全局文件名字符 * 或 ? 不正确,或指定的全局文件名字符太多。 0209 所发送的信号不正确。 0210 无法设置信号处理程序。 0212 区域已锁定,无法重新分配。 0214 附加到此程序或动态链接模块的动态链接模块太多。 0215 无法嵌套调用 LoadModule。 0216 图像文件 %1 有效,但不适用于本机类型。 0230 管道状态无效。 0231 所有的管道实例都处于忙状态。 0232 管道正在关闭。 0233 在管道的另一端没有进程。 0234 有更多可用的数据。 0240 已取消会话。 0254 指定的扩展属性名无效。 0255 扩展属性不一致。 0258 等待操作过时。 0259 没有其他可用数据。 0266 无法使用复制功能。 0267 目录名无效。 0275 扩展属性不匹配缓冲区。 0276 所装载的文件系统上的扩展属性文件已被损坏。 0277 扩展属性表格文件已满。 0278 指定的扩展属性句柄无效。 0282 安装的文件系统不支持扩展属性。 0288 试图释放不属于调用者的多路同步信号。 0298 信号投递的次数太多。 0299 仅完成部分 ReadProcessMemory 或 WriteProcessMemory 请求。 0300 操作锁定请求被拒绝。 0301 系统接收了一个无效的操作锁定确认。 0317 在 %2 的消息文件中,系统无法找到消息号为 0x%1 的消息文本。 0487 试图访问无效地址。 0534 运算结果超过 32 位。 0535 该管道的另一方有一进程。 0536 等候进程打开管道的另一端。 0994 拒绝对扩展属性的访问。 0995 由于线程退出或应用程序的要求, I/O 操作异常终止。 0996 重叠的 I/O 事件不处于已标记状态。 0997 正在处理重叠的 I/O 操作。 0998 对内存位置的无效访问。 0999 执行页内操作出错。 1001 递归太深;堆栈溢出。 1002 窗口无法用来发送消息。 1003 无法完成此项功能。 1004 标志无效。 1005 卷不包含已识别的文件系统。请确认所有需要的文件系统驱动程序都已经加载,而且卷没有任何损坏。 1006 某文件的卷已在外部改变,因而打开的文件不再有效。 1007 要求的操作无法以全屏幕模式执行。 1008 试图引用并不存在的符号。 1009 配置注册表数据库已损坏。 1010 配置注册表主键无效。 1011 无法打开配置注册表主键。 1012 无法读取配置注册表主键。 1013 无法写入配置注册表主键。 1014 必须使用日志文件或其他副本来恢复注册表数据库中的某个文件。恢复成功。 1015 注册表已损坏。可能是一个包含注册表数据文件的结构已损坏,也可能内存中该文件的系统映像已损坏,或者因为备份副本(或日志)不存在(或损坏)导致无法恢复该文件。 1016 由注册表引起的 I/O 操作发生了不可恢复的错误。注册表将不能读取、写出或刷新包含注册表系统映像的其中一个文件。 1017 系统试图将文件加载或还原到注册表中,但是,指定的文件不是注册表文件格式。 1018 试图在注册表键(已经标记为删除)中完成的操作非法。 1019 系统无法在注册表日志文件中分配所需的空间。 1020 无法在已经有子键或键值的注册表项中创建符号链接。 1021 在易失的父键下不能创建固定的子键。 1022 通知的更改请求已经完成,并且返回信息还没有被送到调用者的缓冲区中。调用者需要列举所有文件以找到改动的内容。 1051 已将停止控制发送给与其他运行服务相关的服务。 1052 所要求的控制对此服务无效。 1053 服务没有及时地响应启动或控制请求。 1054 无法为该服务创建线程。 1055 服务数据库已锁定。 1056 该服务的实例已在运行。 1057 帐户名无效或者不存在,或者指定帐户名的密码无效。 1058 服务无法启动,可能因为被禁用,也可能因为没有关联的可用设备。 1059 已经指定了循环服务的从属关系。 1060 指定的服务不是所安装的服务。 1061 该服务此时无法接收控制消息。 1062 服务尚未启动。 1063 服务进程无法连接到服务控制程序。 1064 处理控制请求时,服务出现意外情况。 1065 指定的数据库不存在。 1066 服务返回服务特定的错误码。 1067 进程意外地终止。 1068 无法启动从属服务或组。 1069 由于登录失败,没有启动服务。 1070 启动后,服务保持在启动挂起状态。 1071 指定的服务数据库锁定无效。 1072 指定的服务已经标记为删除。 1073 指定的服务已经存在。 1074 系统当前正以上一次运行成功的配置运行。 1075 从属服务不存在,或已经标记为删除。 1076 已接受使用当前引导作为最后的有效控制设置。 1077 自从上一次启动以后,没有再次启动过该服务。 1078 该名称已经用作服务名或服务显示名。 1079 此服务的帐户不同于运行于同一进程上的其它服务的帐户。 1080 只能为 Win32 服务设置失败操作,不能为驱动程序设置。 1081 这个服务所运行的进程和服务控制管理器相同。所以,如果服务进程意外中止的话,服务控制管理器无法进行任何操作。 1082 这个服务没有设置恢复程序。 1083 配置成在该可执行程序中运行的这个服务不能执行该服务。 1100 已经到达磁带的物理尽头。 1101 磁带访问到文件标记。 1102 到达磁带或分区首部。 1103 磁带访问到文件组的末尾。 1104 磁带上没有其他数据。 1105 磁带无法分区。 1106 访问多重卷分区的新磁带时, 当前的区块大小不正确。 1107 加载磁带时,找不到磁带分区信息。 1108 无法锁定媒体退出功能。 1109 无法卸载媒体。 1110 驱动器中的媒体已经更改。 1111 已经复位 I/O 总线。 1112 驱动器中没有媒体。 1113 在目标多字节代码页中不存在对单码字符的映射。 1114 动态链接库 (DLL) 初始化例程失败。 1115 正在关闭系统。 1116 无法终止系统关机,因为没有进行中的关机操作。 1117 由于 I/O 设备出现错误,无法运行该请求。 1118 串行设备初始化失败。将卸载串行驱动程序。 1119 无法打开正与其他设备共享中断请求 (IRQ) 的设备。至少有一个使用该 IRQ 的设备已经打开。 1120 由于再次写入串行口,串行 I/O 操作已结束。(IOCTL_SERIAL_XOFF_COUNTER 为零。) 1121 由于超时,串行 I/O 操作已结束。 (IOCTL_SERIAL_XOFF_COUNTER 未达到零。) 1122 在软盘上找不到标识符地址标记。 1123 软盘扇区标识符字段与软盘控制器磁道地址不匹配。 1124 软盘控制器报告软盘驱动程序不能识别的错误。 1125 软盘控制器返回的结果和注册的不一致。 1126 访问硬盘时,再校准操作失败,再试一次后也无法操作。 1127 访问硬盘时,磁盘操作失败,再试一次后仍没有作用。 1128 访问硬盘时,需要重启动磁盘控制器,但仍未成功。 1129 磁带已卷到尽头。 1130 可用的服务器存储区不足,无法执行该命令。 1131 检测到潜在的死锁情况。 1132 指定的基址或文件偏移量没有正确对齐。 1140 试图更改系统电源状态的操作被另一应用程序或驱动程序禁止。 1141 系统 BIOS 无法更改系统电源状态。 1142 试图在一文件上创建超过系统允许数额的链接。 1150 指定的程序需要新的 Windows 版本。 1151 指定的程序不是 Windows 或 MS-
DOS
程序。 1152 无法启动指定程序的多个实例。 1153 指定的程序是为 Windows 的早期版本编写的。 1154 运行此应用程序所需的某个库文件已损。 1155 没有应用程序与该操作中所指定的文件关联。 1156 将命令发送到应用程序时出现错误。 1157 找不到运行此应用程序所需的某个库文件。 1158 当前进程已使用了 Window 管理器对象的系统允许的所有句柄。 1159 消息只能与同步操作一起使用。 1160 指出的源元素没有媒体。 1161 指出的目标元素已包含媒体。 1162 指出的元素不存在。 1163 指出的元素是未显示的存储资源的一部分。 1164 指出的设备需要重新初始化,因为硬件有错误。 1165 设备显示在尝试进一步操作之前需要清除。 1166 设备显示它的门仍是打开状态。 1167 设备没有连接。 1168 找不到元素。 1169 索引中没有同指定项相匹配的项。 1170 在对象上不存在指定的属性集。 1171 传递到 GetMouseMovePoints 的点不在缓冲区中。 1172 跟踪(工作站)服务没运行。 1173 找不到卷 ID。 1175 无法删除要被替换的文件。 1176 无法将替换文件移到要被替换的文件。要被替换的文件保持原来的名称。 1177 无法将替换文件移到要被替换的文件。要被替换的文件已被重新命名为备份名称。 1178 卷更改记录被删除。 1179 卷更改记录服务不处于活动中。 1180 找到一份文件,但是可能不是正确的文件。 1181 日志项已从日志中删除。 1200 指定的设备名无效。 1201 设备当前虽然未连接, 但它是记忆连接。 1202 试图记起已经记住的设备。 1203 网络供应商不接受给定的网络路径。 1204 指定的网络供应商名无效。 1205 无法打开网络连接配置文件。 1206 网络连接配置文件已损坏。 1207 无法列举非包容类。 1208 出现扩展错误。 1209 指定组名的格式无效。 1210 指定计算机名的格式无效。 1211 指定事件名的格式无效。 1212 指定域名的格式无效。 1213 指定服务名的格式无效。 1214 指定网络名的格式无效。 1215 指定共享名的格式无效。 1216 指定密码的格式无效。 1217 指定的邮件名无效。 1218 指定邮件目的地的格式无效。 1219 所提供的凭据与现有凭据设置冲突。 1220 试图与网络服务器建立会话,但目前与该服务器建立的会话太多。 1221 网络上的其他计算机已经使用该工作组或域名。 1222 网络不存在或者没有启动。 1223 用户已经取消该操作。 1224 所要求的操作无法在已经打开用户映射区域的文件中运行。 1225 远程系统拒绝网络连接。 1226 已经关闭网络连接。 1227 网络传输的终点已经有一个地址与其关联。 1228 网络终点尚未与地址关联。 1229 试图在不存在的网络连接中操作。 1230 试图在活动的网络连接上进行无效操作。 1231 不能访问网络位置。有关网络疑难解答的信息,请参阅 Windows 帮助。 1232 不能访问网络位置。有关网络疑难解答的信息,请参阅 Windows 帮助。 1233 不能访问网络位置。有关网络疑难解答的信息,请参阅 Windows 帮助。 1234 远程系统的目标网络端点没有运行任何服务。 1235 该请求已经终止。 1236 本地系统已经终止网络连接。 1237 无法完成操作。请再试一次。 1238 无法创建到该服务器的连接,因为已经到达了该帐户同时连接的最大数目。 1239 试图在该帐户未授权的时间内登录。 1240 尚未授权此帐户从该站登录网络。 1241 网络地址无法用于要求的操作。 1242 服务已经注册。 1243 指定的服务不存在。 1244 由于尚未验证用户身份,无法执行要求的操作。 1245 由于用户尚未登录网络,无法运行要求的操作。指定的服务不存在。 1246 继续工作。 1247 完成初始化操作后,试图再次运行初始化操作。 1248 没有其他本地设备。 1249 指定的站点不存在。 1250 具有指定名称的域控制器已经存在。 1251 只有连接到服务器上时,才支持该操作。 1252 即使没有改动,组策略框架也应该调用扩展。 1253 指定的用户没有一个有效的配置文件。 1254 Microsoft Small Business Server 不支持此操作。 1300 不是对所有的调用方分配引用特权。 1301 帐户名与安全标识符之间的映射未完成。 1302 没有为该帐户明确地设置系统配额限制。 1303 没有可用的密钥。返回已知的密钥。 1304 密码太复杂, 无法转换成 LAN Manager 密码。返回的 LAN Manager 密码是空字符串。 1305 修订级别未知。 1306 表示两个修订级别不兼容。 1307 无法将此安全标识符指定为该对象的拥有者。 1308 无法将此安全标识符指定为主要的对象组。 1309 当前并未模拟客户的线程试图操作模拟令牌。 1310 不可以禁用该组。 1311 目前没有可用的登录服务器处理登录请求。 1312 指定的登录会话不存在。该会话可能已终止。 1313 指定的权限不存在。 1314 客户不保留请求的权限。 1315 提供的名称不是正确的帐户名称格式。 1316 指定的用户已经存在。 1317 指定的用户不存在。 1318 指定的组已经存在。 1319 指定的组不存在。 1320 或者指定的用户帐户已经是某个特定组的成员,或者也可能指定的组非空而不能被删除。 1321 指定的用户帐户不是所指定组帐户的成员。 1322 上次保留的管理帐户无法关闭或删除。 1323 无法更新密码。所输入的密码不正确。 1324 无法更新密码。所提供的新密码包含不可用于密码的值。 1325 无法更新密码。为新密码提供的值不符合字符域的长度、复杂性或历史要求。 1326 登录失败: 用户名未知或密码错误。 1327 登录失败: 用户帐户限制。 1328 登录失败: 违反帐户登录时间限制。 1329 登录失败: 禁止用户登录到该计算机上。 1330 登录失败: 指定的帐户密码已过期。 1331 登录失败: 当前禁用帐户。 1332 未完成帐户名与安全性标识符之间的映射。 1333 一次请求的本地用户标识符(LUID)太多。 1334 没有其他可用的本地用户标识符(LUID)。 1335 对这个特定使用来说,安全标识符的子部分是无效的。 1336 访问控制清单(ACL)结构无效。 1337 安全标识符结构无效。 1338 安全描述符结构无效。 1340 无法创建继承的访问控制列表(ACL)或访问控制项目(ACE)。 1341 当前已禁用服务器。 1342 当前已启用服务器。 1343 所提供的值是无效的标识符授权值。 1344 没有更多的内存用于更新安全信息。 1345 指定的属性无效,或指定的属性与整个组的属性不兼容。 1346 或者没有提供所申请的模仿级别,或者提供的模仿级别无效。 1347 无法打开匿名级安全性符号。 1348 所请求的验证信息类别无效。 1349 该类符号不能以所尝试的方式使用。 1350 无法在没有相关安全性的对象上运行安全操作。 1351 未能从域控制器读取配置信息,或者是因为机器不可使用,或者是访问被拒绝。 1352 安全帐户管理程序(SAM)或本地安全颁发机构(LSA)服务器状态不正确,所以无法运行安全操作。 1353 域处于执行安全操作的错误状态。 1354 该操作只能在域的主域控制器中执行。 1355 指定的域不存在或联系不上。 1356 指定的域已经存在。 1357 试图超过每个服务器域数目的极限。 1358 由于严重的媒体错误或磁盘的数据结构损坏,无法完成所请求的操作。 1359 发生内部错误。 1360 通用的访问类型包含在访问掩码中,该掩码已经映射为非通用类型。 1361 安全性描述符的格式错误(绝对或自相关)。 1362 请求的操作只准登录进程使用。该调用过程并未被记录为登录进程。 1363 无法用已经使用的标识符来启动新的登录会话。 1364 指定的确认数据包未知。 1365 登录会话的状态与请求的操作不一致。 1366 登录会话标识符正在使用中。 1367 登录请求包含无效的登录类型值。 1368 在使用命名管道读取数据之前,无法经由该管道模拟。 1369 注册表子树的事务状态与所请求的操作不兼容。 1370 突发的内部安全性数据库故障。 1371 无法在内部帐户下运行该操作。 1372 无法在该内部特定组中运行该操作。 1373 无法在该内部特定用户中运行该操作。 1374 因为该组当前是用户的主要组,所以不能从此组中删除用户。 1375 该符号已作为主要符号使用。 1376 指定的本地组不存在。 1377 指定的帐户名不是本地组的成员。 1378 指定的帐户名已经是本地组的成员。 1379 指定的本地组已经存在。 1380 登录失败: 用户在本计算机上没有被授与所需注册类型。 1381 超过了可以存储在单个系统中的最大机密限制。 1382 机密的长度超过了最大允许值。 1383 本地安全授权数据库包含内部不一致的错误。 1384 登录时,用户的安全性上下文累积太多的安全标识符。 1385 登录失败: 用户在本计算机上没有被授与所需注册类型。 1386 经交叉加密的密码必须更改用户密码。 1387 成员不存在,因此无法将其添加到本地组或从中删除。 1388 新成员的帐户类型有误,因此无法将其添加到本地组。 1389 指定的安全标识符太多。 1390 经交叉加密的密码必须更改该用户密码。 1391 表示 ACL 没有可继承的组件。 1392 文件或目录已损坏,无法读取数据。 1393 磁盘结构已损坏,无法读取数据。 1394 指定的登录会话没有用户会话密钥。 1395 正在访问的服务允许特定数目的连接。因为连接的数目已达到服务可接受的数目,所以此时无法创建新的服务连接。 1396 登录失败: 该目标帐户名称不正确。 1397 相互身份验证失败。该服务器在域控制器的密码过期。 1398 在客户机和服务器之间有一个时间差。 1400 窗口句柄无效。 1401 菜单句柄无效。 1402 光标句柄无效。 1403 加速键表的句柄无效。 1404 挂接句柄无效。 1405 多重窗口位置结构句柄无效。 1406 无法创建最上层的子窗口。 1407 找不到窗口类。 1408 窗口无效;属于其他线程。 1409 已经注册热键。 1410 类已经存在。 1411 类不存在。 1412 类窗口仍打开着。 1413 索引无效。 1414 图标句柄无效。 1415 使用私人对话框窗口字。 1416 找不到列表框标识符。 1417 找不到任何通配符。 1418 线程没有打开剪贴板。 1419 尚未注册热键。 1420 该窗口不是有效的对话框窗口。 1421 找不到控制标识符。 1422 由于没有编辑控制, 因此该组合框的消息无效。 1423 窗口不是组合框。 1424 高度必须小于 256。 1425 设备上下文(DC)句柄无效。 1426 挂接过程类型无效。 1427 挂接过程无效。 1428 不能在无模块句柄的情况下设置非本地的挂接。 1429 只能全局设置该挂接过程。 1430 已安装日记挂接过程。 1431 未安装挂接过程。 1432 单选列表框的消息无效。 1433 LB_SETCOUNT 发送到活动的列表框。 1434 该列表框不支持制表符。 1435 无法破坏由其他线程所创建的对象。 1436 子窗口不能有菜单。 1437 窗口没有系统菜单。 1438 消息框样式无效。 1439 系统范围内的(SPI_*)的参数无效。 1440 屏幕已经锁定。 1441 多重窗口位置结构中所有窗口句柄必须具有相同的父窗口。 1442 窗口不是子窗口。 1443 GW_* 命令无效。 1444 线程标识符无效。 1445 无法处理非多文档接口(MDI)窗口的消息。 1446 弹出式菜单已激活。 1447 窗口没有滚动条。 1448 滚动条范围不能大于 MAXLONG。 1449 无法以指定的方式显示或关闭窗口。 1450 系统资源不足,无法完成所请求的服务。 1451 系统资源不足,无法完成所请求的服务。 1452 系统资源不足,无法完成所请求的服务。 1453 配额不足,无法完成请求的服务。 1454 配额不足,无法完成请求的服务。 1455 页面交换文件太小,无法完成此项操作。 1456 找不到菜单项。 1457 键盘布局句柄无效。 1458 不允许使用挂钩类型。 1459 该操作需要交互式窗口工作站。 1460 由于超时时间已过,该操作返回。 1461 无效监视器句柄。 1500 事件日志文件已损坏。 1501 无法打开事件日志文件, 因此无法启动事件记录服务。 1502 事件日志文件已满。 1503 事件日志文件在两次读取操作间已发生变化。 1601 无法访问 Windows 安装服务。请与技术支持人员联系,确认 Windows 安装服务是否注册正确。 1602 用户取消了安装。 1603 安装时发生严重错误。 1604 安装已挂起,未完成。 1605 这个操作只对当前安装的产品有效。 1606 功能 ID 未注册。 1607 组件 ID 未注册。 1608 未知属性。 1609 句柄处于不正确的状态。 1610 这个产品的配置数据已损坏。请与技术支持人员联系。 1611 组件限制语不存在。 1612 这个产品的安装来源无法使用。请验证来源是否存在,是否可以访问。 1613 Windows 安装服务无法安装这个安装程序包。您必须安装含有 Windows 安装服务新版本的 Windows Service Park。 1614 产品已卸载。 1615 SQL 查询语法不正确或不被支持。 1616 记录字符域不存在。 1617 设备已被删除。 1618 正在进行另一个安装操作。请在继续这个安装操作之前完成那个操作。 1619 未能打开这个安装程序包。请验证程序包是否存在,是否可以访问;或者与应用程序供应商联系,验证这是否是有效的 Windows 安装程序包。 1620 未能打开这个安装程序包。请与应用程序供应商联系,验证这是否是有效的 Windows 安装程序包。 1621 启动 Windows 安装服务用户界面时有错误。请与技术支持人员联系。 1622 打开安装日志文件时出错。请验证指定的日志文件位置是否存在,是否可以写入。 1623 安装程序包的语言不受系统支持。 1624 应用变换时出错。请验证指定的变换路径是否有效。 1625 系统策略禁止这个安装。请与系统管理员联系。 1626 无法执行函数。 1627 执行期间,函数出了问题。 1628 指定了无效的或未知的表格。 1629 提供的数据类型不对。 1630 这个类型的数据不受支持。 1631 Windows 安装服务未能启动。请与技术支持人员联系。 1632 临时文件夹已满或无法使用。请验证临时文件夹是否存在,是否可以写入。 1633 这个处理器类型不支持该安装程序包。请与产品供应商联系。 1634 组件没有在这台计算机上使用。 1635 无法打开修补程序包。请验证修补程序包是否存在,是否可以访问;或者与应用程序供应商联系,验证这是否是有效的 Windows 安装修补程序包。 1636 无法打开修补程序包。请与应用程序供应商联系,验证这是否是有效的 Windows 安装修补程序包。 1637 Windows 安装服务无法处理这个修补程序包。您必须安装含有 Windows 安装服务新版本的 Windows Service Pack。 1638 已安装这个产品的另一个版本。这个版本的安装无法继续。要配置或删除这个产品的现有版本,请用“控制面板”上的“添加/删除程序”。 1639 无效的命令行参数。有关详细的命令行帮助,请查阅 Windows 安装服务的 SDK。 1640 在终端服务远程会话期间,只有管理员有添加、删除或配置服务器软件的权限。如果您要在服务器上安装或配置软件,请与网络管理员联系。 1641 要求的操作已成功结束。要使改动生效,必须重新启动系统。 1642 Windows 安装服务无法安装升级修补程序,因为被升级的程序丢失,或者升级修补程序将更新此程序的其他版本。请确认要被升级的程序在您的计算机上且您的升级修补程序是正确的。 1700 串绑定无效。 1701 绑定句柄的类型错误。 1702 绑定句柄无效。 1703 不支持 RPC 协议顺序。 1704 RPC 协议序列无效。 1705 字符串的全球唯一标识符(UUID)无效。 1706 终点的格式无效。 1707 网络地址无效。 1708 未找到终点。 1709 超时设置值无效。 1710 找不到该对象的全球唯一标识符(UUID)。 1711 该对象的全球唯一标识符(UUID)已经注册。 1712 这一类型的全球唯一标识符(UUID)已经注册。 1713 RPC 服务器正在监听。 1714 尚未注册协议顺序。 1715 RPC 服务器不处于监听状态。 1716 管理程序的类型未知。 1717 接口未知。 1718 没有绑定。 1719 没有协议序列。 1720 无法创建终点。 1721 资源不足, 无法完成该操作。 1722 RPC 服务器无法使用。 1723 RPC 服务器太忙,无法完成此项操作。 1724 网络选项无效。 1725 该线程中不存在活动的远程过程调用。 1726 远程过程调用失败。 1727 远程过程调用失败并且无法执行。 1728 远程过程调用(RPC)协议出现错误。 1730 RPC 服务器不支持传输语法。 1732 不支持这种类型的全球唯一标识符。 1733 标识无效。 1734 数组边界无效。 1735 绑定类型中不包含项目名。 1736 名称语法无效。 1737 不支持这种命名语法。 1739 没有可用的网络地址,无法创建全球唯一标识符(UUID)。 1740 终结点重复。 1741 身份验证类型未知。 1742 调用次数的上限太小。 1743 字符串太长。 1744 找不到 RPC 协议序列。 1745 过程号超出范围。 1746 此次绑定不包含任何身份验证信息。 1747 身份验证服务未知。 1748 身份验证级别未知。 1749 安全描述符无效。 1750 身份验证服务未知。 1751 项目无效。 1752 服务器的终结点无法执行此项操作。 1753 终点的映射器没有更多的终点可用。 1754 没有导出任何接口。 1755 项目名不完整。 1756 版本选项无效。 1757 没有其他成员。 1758 可以导出全部内容。 1759 未找到接口。 1760 项目已经存在。 1761 项目找不到。 1762 名称服务不可用。 1763 网络地址集无效。 1764 不支持请求的操作。 1765 没有可供冒仿的安全性描述符。 1766 远程过程调用(RPC)出现内部错误。 1767 RPC 服务器企图进行整除零运算。 1768 RPC 服务器出现寻址错误。 1769 RPC 服务器中的浮点运算造成被零除。 1770 RPC 服务器产生了浮点下溢错误。 1771 RPC 服务器产生了浮点上溢错误。 1772 可用于自动句柄绑定的 RPC 服务器列表已经用完。 1773 无法打开字符转换表文件。 1774 包含字符转换表的文件小于 512 个字节。 1775 在远程过程调用中,客户机向主机传送了一个空的描述体句柄。 1777 远程过程调用中的描述体句柄发生变化。 1778 发送到远程过程调用的绑定句柄不匹配。 1779 占位程序无法获得远程过程调用的句柄。 1780 将空的参考指针发送给占位程序。 1781 列举值超出范围。 1782 字节数目太小。 1783 占位程序接收到错误数据。 1784 所提供的用户缓冲区对所申请的操作无效。 1785 无法识别磁盘媒体。它可能还未格式化。 1786 工作站没有信任密码。 1787 服务器上的安全数据库中没有该工作站信任关系的计算机帐户。 1788 建立主域和受托域间的信任关系失败。 1789 建立工作站和主域间的信任关系失败。 1790 网络登录失败。 1791 该线程执行过程中已经进行了远程过程调用。 1792 试图登录网络,但网络登录服务尚未启动。 1793 用户帐户已到期。 1794 重定向程序正在使用,无法卸载。 1795 已经安装所指定的打印机驱动程序。 1796 指定的端口未知。 1797 打印机驱动程序未知。 1798 打印处理程序未知。 1799 指定的分隔符文件无效。 1800 指定的优先级无效。 1801 打印机名无效。 1802 打印机已经存在。 1803 打印机命令无效。 1804 指定的数据类型无效。 1805 指定的环境无效。 1806 没有其他绑定。 1807 使用的帐户是跨网络的信任帐户。请使用全局用户帐户或本地用户帐户来访问此服务器。 1808 所使用的帐户是计算机帐户。请使用全局用户帐户或本地用户帐户来访问该服务器。 1809 使用的帐户是服务器信任帐户。请使用全局用户帐户或本地用户帐户来访问该服务器。 1810 指定的域名或安全标识符与域的信任信息不一致。 1811 服务器正在使用中, 无法卸载。 1812 指定的映像文件不包含资源部分。 1813 在映像文件中找不到指定的资源类型。 1814 在映像文件中找不到指定的资源名称。 1815 在映像文件中找不到指定的资源语言 ID 。 1816 可用的配额不足,无法执行该命令。 1817 没有已注册的接口。 1818 远程过程调用被取消。 1819 绑定句柄不包含所有需要的信息。 1820 远程调用过程中发生通讯失败。 1821 所需的身份验证级别不被支持。 1822 主要的名称没有注册。 1823 指定的错误不是有效的 Windows RPC 错误代码。 1824 已分配仅在本机上有效的 UUID。 1825 产生了特定的安全包错误。 1826 没有取消线程。 1827 在编码/解码处理时的操作无效。 1828 序列化软件包的版本不兼容。 1829 RPC 占位程序的版本不兼容。 1830 RPC 管道对象无效或已损坏。 1831 试图在 RPC 管道对象上进行无效操作。 1832 不被支持的 RPC 管道版本。 1898 找不到组成员。 1899 无法创建终结点映射数据库条目。 1900 对象的全球标识符(UUID)为空。 1901 指定的时间无效。 1902 指定的表单名无效。 1903 指定的表单大小无效。 1904 指定的打印机句柄正在等候处理 1905 指定的打印机已经删除。 1906 打印机的状态无效。 1907 用户首次登录前,必须先更改其密码。 1908 找不到该域的域控制器。 1909 引用的帐户目前被锁定,可能无法登录。 1910 没有发现指定的此对象导出者。 1911 没有发现指定的对象。 1912 没有发现指定的对象解析器。 1913 一些待发数据仍
停留
在请求缓冲区内。 1914 无效的异步远程过程调用句柄。 1915 这个操作的异步 RPC 调用句柄不正确。 1916 RPC 管道对象已经关闭。 1917 RPC 调用在全部的管道都被处理之前完成。 1918 没有其他可用的数据来自 RPC 管道。 1919 这个机器没有可用的站点名。 1920 系统无法访问此文件。 1921 系统无法解析文件名。 1922 项目不是所要的类型。 1923 无法将所有对象的 UUID 导出到指定的项。 1924 无法将接口导出到指定的项。 1925 无法添加指定的配置文件项。 1926 无法添加指定的配置文件元素。 1927 无法删除指定的配置文件元素。 1928 无法添加组元素。 1929 无法删除组元素。 2000 像素格式无效。 2001 指定的驱动程序无效。 2002 该操作的窗口样式或类属性无效。 2003 不支持请求的图元文件操作。 2004 不支持请求的转换操作。 2005 不支持请求的剪辑操作。 2010 指定的颜色管理模块无效。 2011 指定的颜色文件配置无效。 2012 找不到指定的标识。 2013 所需的标识不存在。 2014 指定的标识已经存在。 2015 指定的颜色文件配置与任何设备都不相关。 2016 找不到该指定的颜色文件配置。 2017 指定的颜色空间无效。 2018 图像颜色管理没有启用。 2019 在删除该颜色转换时有一个错误。 2020 指定的颜色转换无效。 2021 指定的转换与位图的颜色空间不匹配。 2022 指定的命名颜色索引在配置文件中不存在。 2108 网络连接已成功, 但需要提示用户输入一个不同于原始指定的密码。 2202 指定的用户名无效。 2250 网络连接不存在。 2401 在这个网络连接上已存在打开的文件或未处理的请求。 2402 活动的连接仍然存在。 2404 设备正由活动进程使用,无法断开连接。 3000 指定的打印监视程序未知。 3001 指定的打印机驱动程序正在使用中。 3002 找不到假脱机文件。 3003 没有发出 StartDocPrinter 调用。 3004 尚未发出 AddJob 调用。 3005 指定的打印处理程序已经安装。 3006 指定的打印监视程序已经安装。 3007 该指定的打印监视器不具备所要求的功能。 3008 指定的打印机监视器正在使用中。 3009 当打印机有作业排成队列时此操作请求是不允许的。 3010 请求的操作成功。只有重新启动系统,更改才会生效。 3011 请求的操作成功。只有重新启动服务,更改才会生效。 3012 找不到打印机。 4000 WINS 在处理命令时遇到执行错误。 4001 无法删除本地的 WINS。 4002 从文件引入失败。 4003 备份失败。以前执行过完整的备份吗? 4004 备份失败。请检查备份数据库的目标目录。 4005 名称在 WINS 数据库中不存在。 4006 不允许进行未配置部分的复制。 4100 DHCP 客户获得一个在网上已被使用的 IP 地址。直到 DHCP 客户可以获得新的地址前,本地接口将被禁用。 4200 WMI 数据提供程序不能识别传来的 GUID 是否有效。 4201 WMI 数据提供程序无法识别传来的实例名是否有效。 4202 WMI 数据提供程序无法识别传来的数据项目标识符是否有效。 4203 无法完成 WMI 请求,请重试一次。 4204 找不到 WMI 数据提供程序。 4205 WMI 数据提供程序引用到一个未注册的实例组。 4206 WMI 数据块或事件通知已启用。 4207 WMI 数据块不再可用。 4208 WMI 数据服务无法使用。 4209 WMI 数据提供程序无法完成请求。 4210 WMI MOF 信息无效。 4211 WMI 注册信息无效。 4212 WMI 数据块或事件通知已禁用。 4213 WMI 数据项目或数据块为只读。 4214 WMI 数据项目或数据块不能更改。 6118 该工作组的服务器列表当前不可用。 6200 要正常运行,任务计划程序服务的配置必须在系统帐户中运行。单独的任务可以被配置成在其他帐户中运行。 7001 指定的会话名无效。 7002 指定的协议驱动程序无效。 7003 在系统路径上找不到指定的协议驱动程序。 7004 在系统路径上找不到指定的终端连接驱动程序。 7005 不能为这个会话创建一个事件日志的注册键。 7006 同名的一个服务已经在系统中存在。 7007 在会话上一个关闭操作挂起。 7008 没有可用的输出缓冲器。 7009 找不到 MODEM.INF 文件。 7010 在 MODEM.INF 中没有找到调制解调器名称。 7011 调制解调器没有接受发送给它的指令。验证配置的调制解调器与连接的调制解调器是否匹配。 7012 调制解调器没有响应发送给它的指令。验证该调制解调器是否接线正确并且打开了电源开关。 7013 由于断开连接,载波检测失败或载波停止。 7014 在要求的时间内没有发现拨号音。确定电话线连接正确并可使用。 7015 在远程站点回叫时检测到了占线信号。 7016 在回叫时远程站点上检测到了声音。 7017 传输驱动程序错误 7022 找不到指定的会话。 7023 指定的会话名称已处于使用中。 7024 由于终端连接目前正在忙于处理一个连接、断开连接、复位或删除操作,无法完成该请求的操作。 7025 试图连接到其视频模式不受当前客户支持的会话。 7035 应用程序尝试启动
DOS
图形模式。不支持
DOS
图形模式。 7037 您的交互式登录权限已被禁用。请与您的管理员联系。 7038 该请求的操作只能在系统
控制台
上执行。这通常是一个驱动程序或系统 DLL 要求直接
控制台
访问的结果。 7040 客户未能对服务器连接消息作出响应。 7041 不支持断开
控制台
会话。 7042 不支持重新将一个断开的会话连接到
控制台
。 7044 远程控制另一个会话的请求被拒绝。 7045 拒绝请求的会话访问。 7049 指定的终端连接驱动程序无效。 7050 不能远程控制请求的会话。这也许是由于该会话被中断或目前没有一个用户登录。另外,您不能从该系统
控制台
远程控制一个会话或远程控制系统
控制台
。并且,您不能远程控制您自己的当前会话。 7051 该请求的会话没有配置成允许远程控制。 7052 连接到这个终端服务器的申请被拒绝。终端服务器客户许可证目前正在被另一个用户使用。请与系统管理员联系,获取一份新的终端服务器客户,其许可证号码必须是有效的、唯一的。 7053 连接到这个终端服务器的申请被拒绝。还没有为这份终端服务器客户输入您的终端服务器客户许可证号码。请与系统管理员联系,为该终端服务器客户输入一个有效的、唯一的许可证号码。 7054 系统已达到其授权的登录限制。请以后再试一次。 7055 您正在使用的客户没有使用该系统的授权。您的登录请求被拒绝。 7056 系统许可证已过期。您的登录请求被拒绝。
Java调用
DOS
指令,并将
控制台
中显示的内容输出。
用Java调用
DOS
指令可以方便很多,但是普通的使用,
DOS
执行完后就会自己关掉,我们无法获得执行后的信息。 因此有两种方法。 1.让运行后的
DOS
停留
在窗口(但我们并获取不到输出的值)。 2.将
控制台
的内容打印下来。 这里只对方法二进行解释。 第一步:开启子线程运行
DOS
指令 Process proc = null; String[] cmd = { "...
c语言让
控制台
窗口
停留
_VS2015使用教程(使用VS2015编写C语言程序)
前面我们给出了一段完整的C语言代码,就是在显示器上输出“C语言中文网”,如下所示:#include int main(){ puts("C语言中文网"); return 0;}本节我们就来看看如何通过 VS2015 来运行这段代码。1) 创建项目(Project)在 VS2015 下开发程序首先要创建项目,不同类型的程序对应不同类型的项目,初学者应该从
控制台
程序学起。打开 V...
界面
15,978
社区成员
115,866
社区内容
发帖
与我相关
我的任务
界面
VC/MFC 界面
复制链接
扫一扫
分享
社区描述
VC/MFC 界面
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章