文件管理
Cat (英文全拼:concatenate)命令用于连接文件并打印到标准输出设备上
cat
[-AbeEnstTuv] [–help] [–version] fileName
-n 或 --number:由 1 开始对所有输出的行数编号。
-b 或 --number-nonblank:和 -n 相似,只不过对于空白行不编号。
-s 或 --squeeze-blank:当遇到有连续两行以上的空白行,就代换为一行的空白行。
-v 或 --show-nonprinting:使用 ^ 和 M- 符号,除了 LFD 和 TAB 之外。
-E 或 --show-ends : 在每行结束处显示 $。
-T 或 --show-tabs: 将 TAB 字符显示为 ^I。
-A, --show-all:等价于 -vET。
-e:等价于"-vE"选项;
-t:等价于"-vT"选项;
实例:
把 textfile1 的文档内容加上行号后输入 textfile2 这个文档里:
cat -n textfile1 > textfile2
把 textfile1 和 textfile2 的文档内容加上行号(空白行不加)之后将内容附加到 textfile3 文档里:
cat -b textfile1 textfile2 >> textfile3
清空 /etc/test.txt 文档内容:
cat /dev/null > /etc/test.txt
Chattr
Linux chattr命令用于改变文件属性
这项指令可改变存放在ext2文件系统上的文件或目录属性,这些属性共有以下8种模式:
chgrp
Linux chgrp(英文全拼:change group)命令用于变更文件或目录的所属群组
与 chown 命令不同,chgrp 允许普通用户改变文件所属的组,只要该用户是该组的一员。
在 UNIX 系统家族里,文件或目录权限的掌控以拥有者及所属群组来管理。您可以使用 chgrp 指令去变更文件与目录的所属群组,设置方式采用群组名称或群组识别码皆可。
语法
chgrp [-cfhRv][–help][–version][所属群组][文件或目录…] 或 chgrp [-cfhRv][–help][–reference=<参考文件或目录>][–version][文件或目录…]
参数说明
-c或–changes 效果类似"-v"参数,但仅回报更改的部分。
-f或–quiet或–silent 不显示错误信息。
-h或–no-dereference 只对符号连接的文件作修改,而不更动其他任何相关文件。
-R或–recursive 递归处理,将指定目录下的所有文件及子目录一并处理。
-v或–verbose 显示指令执行过程。
--help 在线帮助。
--reference=<参考文件或目录> 把指定文件或目录的所属群组全部设成和参考文件或目录的所属群组相同。
--version 显示版本信息。
实例
实例1:改变文件的群组属性:
chgrp -v bin log2012.log
输出:
[root@localhost test]# ll
—xrw-r-- 1 root root 302108 11-13 06:03 log2012.log
[root@localhost test]# chgrp -v bin log2012.log
“log2012.log” 的所属组已更改为 bin
[root@localhost test]# ll
—xrw-r-- 1 root bin 302108 11-13 06:03 log2012.log
说明: 将log2012.log文件由root群组改为bin群组
实例2:根据指定文件改变文件的群组属性
chgrp --reference=log2012.log log2013.log
输出:
[root@localhost test]# ll
—xrw-r-- 1 root bin 302108 11-13 06:03 log2012.log
-rw-r–r-- 1 root root 61 11-13 06:03 log2013.log
[root@localhost test]# chgrp --reference=log2012.log log2013.log
[root@localhost test]# ll
—xrw-r-- 1 root bin 302108 11-13 06:03 log2012.log
-rw-r–r-- 1 root bin 61 11-13 06:03 log2013.log
说明: 改变文件log2013.log 的群组属性,使得文件log2013.log的群组属性和参考文件log2012.log的群组属性相同
Chmod Linux chmod(英文全拼:change mode)命令是控制用户对文件的权限的命令
Linux/Unix 的文件调用权限分为三级 : 文件所有者(Owner)、用户组(Group)、其它用户(Other Users)
chmod [-cfvR] [–help] [–version] mode file…
参数说明
mode : 权限设定字串,格式如下 :
[ugoa…][[±=][rwxX]…][,…]
其中:
u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个群体(group)者,o 表示其他以外的人,a 表示这三者皆是。
Chown Linux chown(英文全拼:change owner)命令用于设置文件所有者和文件关联组的命令。
Linux/Unix 是多人多工操作系统,所有的文件皆有拥有者。利用 chown 将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户 ID,组可以是组名或者组 ID,文件是以空格分开的要改变权限的文件列表,支持通配符。 。
chown 需要超级用户 root 的权限才能执行此命令。
只有超级用户和属于组的文件所有者才能变更文件关联组。非超级用户如需要设置关联组可能需要使用 chgrp 命令。
使用权限 : root
语法
chown [-cfhvR] [–help] [–version] user[:group] file…
参数 :
• user : 新的文件拥有者的使用者 ID
• group : 新的文件拥有者的使用者组(group)
• -c : 显示更改的部分的信息
• -f : 忽略错误信息
• -h :修复符号链接
• -v : 显示详细的处理信息
• -R : 处理指定目录以及其子目录下的所有文件
• --help : 显示辅助说明
• --version : 显示版本
实例
把 /var/run/httpd.pid 的所有者设置 root:
chown root /var/run/httpd.pid
将文件 file1.txt 的拥有者设为 runoob,群体的使用者 runoobgroup :
chown runoob:runoobgroup file1.txt
将当前前目录下的所有文件与子目录的拥有者皆设为 runoob,群体的使用者 runoobgroup:
chown -R runoob:runoobgroup *
把 /home/runoob 的关联组设置为 512 (关联组ID),不改变所有者:
chown :512 /home/runoob
cksum Linux cksum命令用于检查文件的CRC是否正确。确保文件从一个系统传输到另一个系统的过程中不被损坏。
CRC是一种排错检查方式,该校验法的标准由CCITT所指定,至少可检测到99.998%的已知错误。
指定文件交由指令"cksum"进行校验后,该指令会返回校验结果供用户核对文件是否正确无误。若不指定任何文件名称或是所给予的文件名为"-",则指令"cksum"会从标准输入设备中读取数据
语法
cksum [–help][–version][文件…]
参数:
• --help:在线帮助。
• --version:显示版本信息。
• 文件…:需要进行检查的文件路径
实例
使用指令"cksum"计算文件"testfile1"的完整性,输入如下命令:
$ cksum testfile1
以上命令执行后,将输出校验码等相关的信息,具体输出信息如下所示:
1263453430 78 testfile1 //输出信息
上面的输出信息中,"1263453430"表示校验码,"78"表示字节数。
注意:如果文件中有任何字符被修改,都将改变计算后CRC校验码的值。
Cmp Linux cmp命令用于比较两个文件是否有差异。
当相互比较的两个文件完全一样时,则该指令不会显示任何信息。若发现有所差异,预设会标示出第一个不同之处的字符和列数编号。若不指定任何文件名称或是所给予的文件名为"-",则cmp指令会从标准输入设备读取数据。
语法
cmp [-clsv][-i <字符数目>][–help][第一个文件][第二个文件]
参数:
• -c或–print-chars 除了标明差异处的十进制字码之外,一并显示该字符所对应字符。
• -i<字符数目>或–ignore-initial=<字符数目> 指定一个数目。
• -l或–verbose 标示出所有不一样的地方。
• -s或–quiet或–silent 不显示错误信息。
• -v或–version 显示版本信息。
• --help 在线帮助。
实例
要确定两个文件是否相同,请输入:
cmp prog.o.bak prog.o
这比较 prog.o.bak 和 prog.o。如果文件相同,则不显示消息。如果文件不同,则显示第一个不同的位置;例如:
prog.o.bak prog.o differ: char 4, line 1
如果显示消息 cmp: EOF on prog.o.bak,则 prog.o 的第一部分与 prog.o.bak 相同,但在 prog.o 中还有其他数据。
2013-03
8c8
< 2013-07
2013-08
11,12d10
< 2013-11
< 2013-12
上面的"3c3"和"8c8"表示log2014.log和log20143log文件在3行和第8行内容有所不同;"11,12d10"表示第一个文件比第二个文件多了第11和12行。
实例2:并排格式输出
[root@localhost test3]# diff log2014.log log2013.log -y -W 50
2013-01 2013-01
2013-02 2013-02
2014-03 | 2013-03
2013-04 2013-04
2013-05 2013-05
2013-06 2013-06
2013-07 2013-07
2013-07 | 2013-08
2013-09 2013-09
2013-10 2013-10
2013-11 <
2013-12 <
[root@localhost test3]# diff log2013.log log2014.log -y -W 50
2013-01 2013-01
2013-02 2013-02
2013-03 | 2014-03
2013-04 2013-04
2013-05 2013-05
2013-06 2013-06
2013-07 2013-07
2013-08 | 2013-07
2013-09 2013-09
2013-10 2013-10
2013-11
2013-12
说明:
• "|"表示前后2个文件内容有不同
• "<"表示后面文件比前面文件少了1行内容
• ">“表示后面文件比前面文件多了1行内容
Diffstat Linux diffstat命令根据diff的比较结果,显示统计数字。
diffstat读取diff的输出结果,然后统计各文件的插入,删除,修改等差异计量。
语法
diff [-wV][-n <文件名长度>][-p <文件名长度>]
参数:
• -n<文件名长度> 指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名。
• -p<文件名长度> 与-n参数相同,但此处的<文件名长度>包括了文件的路径。
• -w 指定输出时栏位的宽度。
• -V 显示版本信息。
实例
用户也可以直接使用”|"将diff指令所输出的结果直接送给diffstat指令进行统计结果的显示。
使用该指令时,若所比较的文件或者子目录不在当前目录下,则应该使用其完整路径。
将目录"test1"和"test2"下的同名文件"testf.txt"使用diff指令进行比较。然后使用diffstat指令对结果进行统计显示,输入如下命令:
$ diff test1 test2 | diffstat #进行比较结果的统计显示
注意:使用这条命令可以非常方便地实现统计显示的功能。
对于查看文件中的内容,用户可以通过指令"cat"进行查看即可,具体操作如下:
$ cat test1/testf.txt #查看test1/testf的内容
abc
def
ghi
jkl
mno
pqr
stu
vws
$ cat test2/testf.txt #查看test2/testf的内容
abc
def
ghi
jkl
mno
从上面的文件内容显示,可以看到两个文件内容的差别。现在来运行刚才的命令,对文件比较的结果进行统计显示,结果如下:
testfile | 2 ± #统计信息输出显示
1 file changed, 1 insertion(+), 1 deletion(-)
File Linux file命令用于辨识文件类型
通过file指令,我们得以辨识该文件的类型。
语法
file [-bcLvz][-f <名称文件>][-m <魔法数字文件>…][文件或目录…]
参数:
• -b 列出辨识结果时,不显示文件名称。
• -c 详细显示指令执行过程,便于排错或分析程序执行的情形。
• -f<名称文件> 指定名称文件,其内容有一个或多个文件名称时,让file依序辨识这些文件,格式为每列一个文件名称。
• -L 直接显示符号连接所指向的文件的类别。
• -m<魔法数字文件> 指定魔法数字文件。
• -v 显示版本信息。
• -z 尝试去解读压缩文件的内容。
• [文件或目录…] 要确定类型的文件列表,多个文件之间使用空格分开,可以使用shell通配符匹配多个文件。
实例
显示文件类型:
[root@localhost ~]# file install.log
install.log: UTF-8 Unicode text
[root@localhost ~]# file -b install.log <== 不显示文件名称
UTF-8 Unicode text
[root@localhost ~]# file -i install.log <== 显示MIME类别。
install.log: text/plain; charset=utf-8
[root@localhost ~]# file -b -i install.log
text/plain; charset=utf-8
显示符号链接的文件类型
[root@localhost ~]# ls -l /var/mail
lrwxrwxrwx 1 root root 10 08-13 00:11 /var/mail -> spool/mail
[root@localhost ~]# file /var/mail
/var/mail: symbolic link to `spool/mail’
[root@localhost ~]# file -L /var/mail
/var/mail: directory
[root@localhost ~]# file /var/spool/mail
/var/spool/mail: directory
[root@localhost ~]# file -L /var/spool/mail
/var/spool/mail: directory
Find Linux find 命令用来在指定目录下查找文件。
任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则 find 命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示
语法
find path -option [ -print ] [ -exec -ok command ] {} ;
参数说明 :
find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。
expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份。
-mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件
-amin n : 在过去 n 分钟内被读取过
-anewer file : 比文件 file 更晚被读取过的文件
-atime n : 在过去n天内被读取过的文件
-cmin n : 在过去 n 分钟内被修改过
-cnewer file :比文件 file 更新的文件
-ctime n : 在过去n天内被修改过的文件
-empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名称是 name
-ipath p, -path p : 路径名称符合 p 的文件,ipath 会忽略大小写
-name name, -iname name : 文件名称符合 name 的文件。iname 会忽略大小写
-size n : 文件大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组。
-type c : 文件类型是 c 的文件。
d: 目录
c: 字型装置文件
b: 区块装置文件
p: 具名贮列
f: 一般文件
l: 符号连结
s: socket
-pid n : process id 是 n 的文件
你可以使用 ( ) 将运算式分隔,并使用下列运算。
exp1 -and exp2
! expr
-not expr
exp1 -or exp2
exp1, exp2
实例
将当前目录及其子目录下所有文件后缀为 .c 的文件列出来:
将目前目录其其下子目录中所有一般文件列出
将当前目录及其子目录下所有最近 20 天内更新过的文件列出:
查找 /var/log 目录中更改时间在 7 日以前的普通文件,并在删除之前询问它们:
查找当前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件:
查找系统中所有文件长度为 0 的普通文件,并列出它们的完整路径:
Git Linux git命令是文字模式下的文件管理员
git是用来管理文件的程序,它十分类似DOS下的Norton Commander,具有互动式操作界面。它的操作方法和Norton Commander几乎一样。
语法
git
操作说明:
• F1 :执行info指令,查询指令相关信息,会要求您输入欲查询的名称。
• F2 :执行cat指令,列出文件内容。
• F3 :执行gitview指令,观看文件内容。
• F4 :执行vi指令,编辑文件内容。
• F5 :执行cp指令,复制文件或目录,会要求您输入目标文件或目录。
• F6 :执行mv指令,移动文件或目录,或是更改其名称,会要求您输入目标文件或目录。
• F7 :执行mkdir指令,建立目录。
• F8 :执行rm指令,删除文件或目录。
• F9 :执行make指令,批处理执行指令或编译程序时,会要求您输入相关命令。
• F10 :离开git文件管理员。
Gitview Linux gitview命令用于观看文件的内容,它会同时显示十六进制和ASCII格式的字码
语法
gitview [-bchilv][文件]
参数:
• -b 单色模式,不使用ANSI控制码显示彩色。
• -c 彩色模式,使用ANSI控制码显示色彩。
• -h 在线帮助。
• -i 显示存放gitview程序的所在位置。
• -l 不使用先前的显示字符。
• -v 显示版本信息。
实例
使用指令gitview以彩色模式观看文件"/home/ rootlocal/demo.txt"中的内容,输入如下命令:
$ gitview -c /home/rootlocal/demo.txt #使用gitview指令观看指定文件内容
Indent Linux indent命令用于调整C原始代码文件的格式。
indent可辨识C的原始代码文件,并加以格式化,以方便程序设计师阅读
语法
indent [参数][源文件] 或 indent [参数][源文件][-o 目标文件]
参数:
• -bad或–blank-lines-after-declarations 在声明区段或加上空白行。
• -bap或–blank-lines-after-procedures 在程序或加上空白行。
• -bbb或–blank-lines-after-block-comments 在注释区段后加上空白行。
• -bc或–blank-lines-after-commas 在声明区段中,若出现逗号即换行。
• -bl或–braces-after-if-line if(或是else,for等等)与后面执行区段的"{“不同行,且”}“自成一行。
• -bli<缩排格数>或–brace-indent<缩排格数> 设置{ }缩排的格数。
• -br或–braces-on-if-line if(或是else,for等等)与后面执行跛段的”{“不同行,且”}“自成一行。
• -bs或–blank-before-sizeof 在sizeof之后空一格。
• -c<栏数>或–comment-indentation<栏数> 将注释置于程序码右侧指定的栏位。
• -cd<栏数>或–declaration-comment-column<栏数> 将注释置于声明右侧指定的栏位。
• -cdb或–comment-delimiters-on-blank-lines 注释符号自成一行。
• -ce或–cuddle-else 将else置于”}"(if执行区段的结尾)之后。
• -ci<缩排格数>或–continuation-indentation<缩排格数> 叙述过长而换行时,指定换行后缩排的格数。
• -cli<缩排格数>或–case-indentation-<缩排格数> 使用case时,switch缩排的格数。
• -cp<栏数>或-else-endif-column<栏数> 将注释置于else与elseif叙述右侧定的栏位。
• -cs或–space-after-cast 在cast之后空一格。
• -d<缩排格数>或-line-comments-indentation<缩排格数> 针对不是放在程序码右侧的注释,设置其缩排格数。
• -di<栏数>或–declaration-indentation<栏数> 将声明区段的变量置于指定的栏位。
• -fc1或–format-first-column-comments 针对放在每行最前端的注释,设置其格式。
• -fca或–format-all-comments 设置所有注释的格式。
• -gnu或–gnu-style 指定使用GNU的格式,此为预设值。
• -i<格数>或–indent-level<格数> 设置缩排的格数。
• -ip<格数>或–parameter-indentation<格数> 设置参数的缩排格数。
• -kr或–k-and-r-style 指定使用Kernighan&Ritchie的格式。
• -lp或–continue-at-parentheses 叙述过长而换行,且叙述中包含了括弧时,将括弧中的每行起始栏位内容垂直对其排列。
• -nbad或–no-blank-lines-after-declarations 在声明区段后不要加上空白行。
• -nbap或–no-blank-lines-after-procedures 在程序后不要加上空白行。
• -nbbb或–no-blank-lines-after-block-comments 在注释区段后不要加上空白行。
• -nbc或–no-blank-lines-after-commas 在声明区段中,即使出现逗号,仍旧不要换行。
• -ncdb或–no-comment-delimiters-on-blank-lines 注释符号不要自成一行。
• -nce或–dont-cuddle-else 不要将else置于"}"之后。
• -ncs或–no-space-after-casts 不要在cast之后空一格。
• -nfc1或–dont-format-first-column-comments 不要格式化放在每行最前端的注释。
• -nfca或–dont-format-comments 不要格式化任何的注释。
• -nip或–no-parameter-indentation 参数不要缩排。
• -nlp或–dont-line-up-parentheses 叙述过长而换行,且叙述中包含了括弧时,不用将括弧中的每行起始栏位垂直对其排列。
• -npcs或–no-space-after-function-call-names 在调用的函数名称之后,不要加上空格。
• -npro或–ignore-profile 不要读取indent的配置文件.indent.pro。
• -npsl或–dont-break-procedure-type 程序类型与程序名称放在同一行。
• -nsc或–dont-star-comments 注解左侧不要加上星号()。
• -nsob或–leave-optional-semicolon 不用处理多余的空白行。
• -nss或–dont-space-special-semicolon 若for或while区段仅有一行时,在分号前不加上空格。
• -nv或–no-verbosity 不显示详细的信息。
• -orig或–original 使用Berkeley的格式。
• -pcs或–space-after-procedure-calls 在调用的函数名称与"{"之间加上空格。
• -psl或–procnames-start-lines 程序类型置于程序名称的前一行。
• -sc或–start-left-side-of-comments 在每行注释左侧加上星号()。
• -sob或–swallow-optional-blank-lines 删除多余的空白行。
• -ss或–space-special-semicolon 若for或swile区段今有一行时,在分号前加上空格。
• -st或–standard-output 将结果显示在标准输出设备。
• -T 数据类型名称缩排。
• -ts<格数>或–tab-size<格数> 设置tab的长度。
• -v或–verbose 执行时显示详细的信息。
• -version 显示版本信息。
Indent代码格式化说明
使用的indent参数 值 含义
–blank-lines-after-declarations bad 变量声明后加空行
–blank-lines-after-procedures bap 函数结束后加空行
–blank-lines-before-block-comments bbb 块注释前加空行
–break-before-boolean-operator bbo 较长的行,在逻辑运算符前分行
–blank-lines-after-commas nbc 变量声明中,逗号分隔的变量不分行
–braces-after-if-line bl “if"和”{"分做两行
–brace-indent 0 bli0 "{"不继续缩进
–braces-after-struct-decl-line bls 定义结构,“struct"和”{"分行
–comment-indentationn c33 语句后注释开始于行33
–declaration-comment-columnn cd33 变量声明后注释开始于行33
–comment-delimiters-on-blank-lines ncdb 不将单行注释变为块注释
–cuddle-do-while ncdw “do — while"的"while"和其前面的”}“另起一行
–cuddle-else nce “else"和其前面的”}“另起一行
–case-indentation 0 cli0 switch中的case语句所进0个空格
–else-endif-columnn cp33 #else, #endif后面的注释开始于行33
–space-after-cast cs 在类型转换后面加空格
–line-comments-indentation n d0 单行注释(不从1列开始的),不向左缩进
–break-function-decl-args nbfda 关闭:函数的参数一个一行
–declaration-indentationn di2 变量声明,变量开始于2行,即不必对齐
–format-first-column-comments nfc1 不格式化起于第一行的注释
–format-all-comments nfca 不开启全部格式化注释的开关
–honour-newlines hnl Prefer to break long lines at the position of newlines in the input.
–indent-leveln i4 设置缩进多少字符,如果为tab的整数倍,用tab来缩进,否则用空格填充。
–parameter-indentationn ip5 旧风格的函数定义中参数说明缩进5个空格
–line-length 75 l75 非注释行最长75
–continue-at-parentheses lp 续行从上一行出现的括号开始
–space-after-procedure-calls pcs 函数和”(“之间插入一个空格
–space-after-parentheses nprs 在”(“后”)“前不插入空格
–procnames-start-lines psl 将函数名和返回类型放在两行定义
–space-after-for saf for后面有空格
–space-after-if sai if后面有空格
–space-after-while saw while后面有空格
–start-left-side-of-comments nsc 不在生成的块注释中加*
–swallow-optional-blank-lines nsob 不去掉可添加的空行
–space-special-semicolon nss 一行的for或while语句,在”;“前不加空。
–tab-size ts4 一个tab为4个空格(要能整除”-in”)
–use-tabs ut 使用tab来缩进
Cut Linux cut命令用于显示每行从开头算起 num1 到 num2 的文字。
语法
cut [-bn] [file]
cut [-c] [file]
cut [-df] [file]
使用说明:
cut 命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段写至标准输出。
如果不指定 File 参数,cut 命令将读取标准输入。必须指定 -b、-c 或 -f 标志之一。
参数:
• -b :以字节为单位进行分割。这些字节位置将忽略多字节字符边界,除非也指定了 -n 标志。
• -c :以字符为单位进行分割。
• -d :自定义分隔符,默认为制表符。
• -f :与-d一起使用,指定显示哪个区域。
• -n :取消分割多字节字符。仅和 -b 标志一起使用。如果字符的最后一个字节落在由 -b 标志的 List 参数指示的
范围之内,该字符将被写出;否则,该字符将被排除
实例
当你执行who命令时,会输出类似如下的内容:
$ who
rocrocket :0 2009-01-08 11:07
rocrocket pts/0 2009-01-08 11:23 (:0.0)
rocrocket pts/1 2009-01-08 14:15 (:0.0)
如果我们想提取每一行的第3个字节,就这样:
$ who|cut -b 3
c
c
ln Linux ln(英文全拼:link files)命令是一个非常重要命令,它的功能是为某一个文件在另外一个位置建立一个同步的链接。
当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在 其它的目录下用ln命令链接(link)它就可以,不必重复的占用磁盘空间。
语法
ln [参数][源文件或目录][目标文件或目录]
其中参数的格式为
[-bdfinsvF] [-S backup-suffix] [-V {numbered,existing,simple}]
[–help] [–version] [–]
命令功能 :
Linux文件系统中,有所谓的链接(link),我们可以将其视为档案的别名,而链接又可分为两种 : 硬链接(hard link)与软链接(symbolic link),硬链接的意思是一个档案可以有多个名称,而软链接的方式则是产生一个特殊的档案,该档案的内容是指向另一个档案的位置。硬链接是存在同一个文件系统中,而软链接却可以跨越不同的文件系统。
不论是硬链接或软链接都不会将原本的档案复制一份,只会占用非常少量的磁碟空间。
软链接:
• 1.软链接,以路径的形式存在。类似于Windows操作系统中的快捷方式
• 2.软链接可以 跨文件系统 ,硬链接不可以
• 3.软链接可以对一个不存在的文件名进行链接
• 4.软链接可以对目录进行链接
硬链接:
• 1.硬链接,以文件副本的形式存在。但不占用实际空间。
• 2.不允许给目录创建硬链接
• 3.硬链接只有在同一个文件系统中才能创建
命令参数
必要参数:
• -b 删除,覆盖以前建立的链接
• -d 允许超级用户制作目录的硬链接
• -f 强制执行
• -i 交互模式,文件存在则提示用户是否覆盖
• -n 把符号链接视为一般目录
• -s 软链接(符号链接)
• -v 显示详细的处理过程
选择参数:
• -S "-S<字尾备份字符串> "或 “–suffix=<字尾备份字符串>”
• -V “-V<备份方式>“或”–version-control=<备份方式>”
• --help 显示帮助信息
• --version 显示版本信息
实例
给文件创建软链接,为log2013.log文件创建软链接link2013,如果log2013.log丢失,link2013将失效:
ln -s log2013.log link2013
输出:
[root@localhost test]# ll
-rw-r–r-- 1 root bin 61 11-13 06:03 log2013.log
[root@localhost test]# ln -s log2013.log link2013
[root@localhost test]# ll
lrwxrwxrwx 1 root root 11 12-07 16:01 link2013 -> log2013.log
-rw-r–r-- 1 root bin 61 11-13 06:03 log2013.log
给文件创建硬链接,为log2013.log创建硬链接ln2013,log2013.log与ln2013的各项属性相同
ln log2013.log ln2013
输出:
[root@localhost test]# ll
lrwxrwxrwx 1 root root 11 12-07 16:01 link2013 -> log2013.log
-rw-r–r-- 1 root bin 61 11-13 06:03 log2013.log
[root@localhost test]# ln log2013.log ln2013
[root@localhost test]# ll
lrwxrwxrwx 1 root root 11 12-07 16:01 link2013 -> log2013.log
-rw-r–r-- 2 root bin 61 11-13 06:03 ln2013
-rw-r–r-- 2 root bin 61 11-13 06:03 log2013.log
Less less 与 more 类似,但使用 less 可以随意浏览文件,而 more 仅能向前移动,却不能向后移动,而且 less 在查看之前不会加载整个文件
语法
less [参数] 文件
参数说明:
• -b <缓冲区大小> 设置缓冲区的大小
• -e 当文件显示结束后,自动离开
• -f 强迫打开特殊文件,例如外围设备代号、目录和二进制文件
• -g 只标志最后搜索的关键词
• -i 忽略搜索时的大小写
• -m 显示类似more命令的百分比
• -N 显示每行的行号
• -o <文件名> 将less 输出的内容在指定文件中保存起来
• -Q 不使用警告音
• -s 显示连续空行为一行
• -S 行过长时间将超出部分舍弃
• -x <数字> 将"tab"键显示为规定的数字空格
• /字符串:向下搜索"字符串"的功能
• ?字符串:向上搜索"字符串"的功能
• n:重复前一个搜索(与 / 或 ? 有关)
• N:反向重复前一个搜索(与 / 或 ? 有关)
• b 向上翻一页
• d 向后翻半页
• h 显示帮助界面
• Q 退出less 命令
• u 向前滚动半页
• y 向前滚动一行
• 空格键 滚动一页
• 回车键 滚动一行
• [pagedown]: 向下翻动一页
• [pageup]: 向上翻动一页
实例
1、查看文件
less log2013.log
2、ps查看进程信息并通过less分页显示
ps -ef |less
3、查看命令历史使用记录并通过less分页显示
[root@localhost test]# history | less
22 scp -r tomcat6.0.32 [email protected]:/opt/soft
23 cd …
24 scp -r web [email protected]:/opt/
25 cd soft
26 ls
……省略……
4、浏览多个文件
less log2013.log log2014.log
说明:
输入 :n后,切换到 log2014.log
输入 :p 后,切换到log2013.log
附加备注
1.全屏导航
• ctrl + F - 向前移动一屏
• ctrl + B - 向后移动一屏
• ctrl + D - 向前移动半屏
• ctrl + U - 向后移动半屏
2.单行导航
• j - 向前移动一行
• k - 向后移动一行
3.其它导航
• G - 移动到最后一行
• g - 移动到第一行
• q / ZZ - 退出 less 命令
4.其它有用的命令
• v - 使用配置的编辑器编辑当前文件
• h - 显示 less 的帮助文档
• &pattern - 仅显示匹配模式的行,而不是整个文件
5.标记导航
当使用 less 查看大文件时,可以在任何一个位置作标记,可以通过命令导航到标有特定标记的文本位置:
• ma - 使用 a 标记文本的当前位置
• 'a - 导航到标记 a 处
Locate 一般情况我们需要出入 locate your_file_name查找指定文件
Linux locate命令用于查找符合条件的文档,他会去保存文档和目录名称的数据库内,查找合乎范本样式条件的文档或目录。
语法
locate [-d ][–help][–version][范本样式…]
参数:
• -b, --basename – 仅匹配路径名的基本名称
• -c, --count – 只输出找到的数量
• -d, --database DBPATH – 使用 DBPATH 指定的数据库,而不是默认数据库 /var/lib/mlocate/mlocate.db
• -e, --existing – 仅打印当前现有文件的条目
• -1 – 如果 是 1.则启动安全模式。在安全模式下,使用者不会看到权限无法看到 的档案。这会始速度减慢,因为 locate 必须至实际的档案系统中取得档案的 权限资料。
• -0, --null – 在输出上带有NUL的单独条目
• -S, --statistics – 不搜索条目,打印有关每个数据库的统计信息
• -q – 安静模式,不会显示任何错误讯息。
• -P, --nofollow, -H – 检查文件存在时不要遵循尾随的符号链接
• -l, --limit, -n LIMIT – 将输出(或计数)限制为LIMIT个条目
• -n – 至多显示 n个输出。
• -m, --mmap – 被忽略,为了向后兼容
• -r, --regexp REGEXP – 使用基本正则表达式
• --regex – 使用扩展正则表达式
• -q, --quiet – 安静模式,不会显示任何错误讯息
• -s, --stdio – 被忽略,为了向后兼容
• -o – 指定资料库存的名称。
• -h, --help – 显示帮助
• -i, --ignore-case – 忽略大小写
• -V, --version – 显示版本信息
实例
查找 passwd 文件,输入以下命令:
locate passwd
搜索 etc 目录下所有以 sh 开头的文件 :
locate /etc/sh
忽略大小写搜索当前用户目录下所有以 r 开头的文件 :
locate -i ~/r
附加说明
locate 与 find 不同: find 是去硬盘找,locate 只在 /var/lib/slocate 资料库中找。
locate 的速度比 find 快,它并不是真的查找,而是查数据库,一般文件数据库在 /var/lib/slocate/slocate.db 中,所以 locate 的查找并不是实时的,而是以数据库的更新为准,一般是系统自己维护,也可以手工升级数据库 ,命令为:
updatedb
默认情况下 updatedb 每天执行一次。
Lsattr Linux lsattr命令用于显示文件属性。
用chattr执行改变文件或目录的属性,可执行lsattr指令查询其属性。
语法
lsattr [-adlRvV][文件或目录…]
参数:
• -a 显示所有文件和目录,包括以".“为名称开头字符的额外内建,现行目录”.“与上层目录”…"。
• -d 显示,目录名称,而非其内容。
• -l 此参数目前没有任何作用。
• -R 递归处理,将指定目录下的所有文件及子目录一并处理。
• -v 显示文件或目录版本。
• -V 显示版本信息。
实例
1、用chattr命令防止系统中某个关键文件被修改:
然后用mv /etc/resolv.conf等命令操作于该文件,都是得到Operation not permitted 的结果。
vim编辑该文件时会提示W10: Warning: Changing a readonly file错误。要想修改此文件就要把i属性去掉:
chattr -i /etc/resolv.conf
使用 lsattr 命令来显示文件属性:
输出结果为:
----i-------- /etc/resolv.conf
2、让某个文件只能往里面追加数据,但不能删除,适用于各种日志文件:
Mattrib Linux mattrib命令用来变更或显示MS-DOS文件的属性。
mattrib为mtools工具指令,模拟MS-DOS的attrib指令,可变更MS-DOS文件的属性。
语法
mattrib [-a|+a] [-h|+h] [-r|+r] [-s|+s] [-/] [-X] msdosfile [ msdosfiles … ]
参数:
• -a/+a 除去/设定备份属性。
• -h/+h 除去/设定隐藏属性。
• -r/+r 除去/设定唯读属性。
• -s/+s 除去/设定系统属性。
• -/ 递回的处理包含所有子目录下的档案。
• -X 以较短的格式输出结果。
实例
列出 A 槽 MSDOS 格式磁片上所有文件的属性。
mattrib a:
除去 A 槽磁片上 msdos.sys 档案的隐藏、系统与唯读属性。
mattrib -h -s -r a:msdos.sys
除去 A 槽磁片上包含子目录下所有档案的唯读属性。
mattrib -r -/ a:.
mc Linux mc命令用于提供一个菜单式的文件管理程序。
执行mc之后,将会看到菜单式的文件管理程序,共分成4个部分。
mc [-abcdfhkPstuUVx][-C <参数>][-l <文件>][-v <文件>][目录]
参 数:
• -a 当mc程序画线时不用绘图字符画线。
• -b 使用单色模式显示。
• -c 使用彩色模式显示。
• -C<参数> 指定显示的颜色。
• -d 不使用鼠标。
• -f 显示mc函数库所在的目录。
• -h 显示帮助。
• -k 重设softkeys成预设置。
• -l<文件> 在指定文件中保存ftpfs对话窗的内容。
• -P 程序结束时,列出最后的工作目录。
• -s 用慢速的终端机模式显示,在这模式下将减少大量的绘图及文字显示。
• -t 使用TEMPCAP变量设置终端机,而不使用预设置。
• -u 不用目前的shell程序。
• -U 使用目前的shell程序。
• -v<文件> 使用mc的内部编辑器来显示指定的文件。
• -V 显示版本信息。
• -x 指定以xterm模式显示。
Linux MC 相关操作
命令按键 描 述
F9 or Esc+9 激活菜单栏
Tab 在两个窗口间移动
F10 or Esc+0 退出MC
Control-Enter or Alt-Enter 可以将文件名拷贝到命令行
F1 or Esc+1 打开帮助页面
虽然MC很好用,不过我还是建议大家使用命令行工具!
Mdel Linux mdel命令用来删除 MSDOS 格式的档案
在删除只读之前会有提示信息产生。
语法
mdel [-v] msdosfile [ msdosfiles … ]
参数:
• -v 显示更多的讯息。
实例
将 A 槽磁片根目录中的 autoexec.bat 删除。
mdel a:autoexec.bat .
mdir Linux mdir命令用于显示MS-DOS目录。
mdir为mtools工具指令,模拟MS-DOS的dir指令,可显示MS-DOS文件系统中的目录内容
语法
mdir [-afwx/][目录]
参数:
• -/ 显示目录下所有子目录与文件。
• -a 显示隐藏文件。
• -f 不显示磁盘所剩余的可用空间。
• -w 仅显示目录或文件名称,并以横排方式呈现,以便一次能显示较多的目录或文件。
• -X 仅显示目录下所有子目录与文件的完整路径,不显示其他信息。
实例
显示a盘中的内容
$ mdir -/ a:*
以上命令执行后,mdir将显示指定盘"a:"中的所有子目录及其中的文件信息,如下所示:
Volume in drive A has no label #加载信息
Volume Serial Number is 13D2~055C
Directory for A:\ #以下为目录信息
./TEST
More 类似于cat
Linux more 命令类似 cat ,不过会以一页一页的形式显示,更方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能(与 vi 相似),使用中的说明文件,请按 h
语法
more [-dlfpcsu] [-num] [+/pattern] [+linenum] [fileNames…]
参数:
• -num 一次显示的行数
• -d 提示使用者,在画面下方显示 [Press space to continue, ‘q’ to quit.] ,如果使用者按错键,则会显示 [Press ‘h’ for instructions.] 而不是 ‘哔’ 声
• -l 取消遇见特殊字元 ^L(送纸字元)时会暂停的功能
• -f 计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上)
• -p 不以卷动的方式显示每一页,而是先清除萤幕后再显示内容
• -c 跟 -p 相似,不同的是先显示内容再清除其他旧资料
• -s 当遇到有连续两行以上的空白行,就代换为一行的空白行
• -u 不显示下引号 (根据环境变数 TERM 指定的 terminal 而有所不同)
• +/pattern 在每个文档显示前搜寻该字串(pattern),然后从该字串之后开始显示
• +num 从第 num 行开始显示
• fileNames 欲显示内容的文档,可为复数个数
实例
逐页显示 testfile 文档内容,如有连续两行以上空白行则以一行空白行显示。
more -s testfile
从第 20 行开始显示 testfile 之文档内容。
more +20 testfile
常用操作命令
• Enter 向下n行,需要定义。默认为1行
• Ctrl+F 向下滚动一屏
• 空格键 向下滚动一屏
• Ctrl+B 返回上一屏
• = 输出当前行的行号
• :f 输出文件名和当前行的行号
• V 调用vi编辑器
• !命令 调用Shell,并执行命令
• q 退出more
mmove Linux mmove命令用于在MS-DOS文件系统中,移动文件或目录,或更改名称。
mmove为mtools工具命令,模拟MS-DOS的move命令,可在MS-DOS文件系统中移动现有的文件或目录,或是更改现有文件或目录的名称。
语法
mmove [源文件或目录…][目标文件或目录]
参数说明:
• [源文件或目录…]: 执行操作的源文件或目录路径
• [目标文件或目录]: 执行操作后的目标文件或目录路径
实例
使用指令mmove将文件"autorun.bat"移动到目录"test"中,输入如下命令:
$ mmove autorun.bat test #移动文件到目录test中
以上命令执行以后,指令mmove会将文件"autorun.bat"移动到指定目录"test"中。
注意:用户可以使用mdir指令查看移动后的文件或目录信息。mtools
Mv Linux mv(英文全拼:move file)命令用来为文件或目录改名、或将文件或目录移入其它位置。
语法
mv [options] source dest
mv [options] source… directory
参数说明:
• -b: 当目标文件或目录存在时,在执行覆盖前,会为其创建一个备份。
• -i: 如果指定移动的源目录或文件与目标的目录或文件同名,则会先询问是否覆盖旧文件,输入 y 表示直接覆盖,输入 n 表示取消该操作。
• -f: 如果指定移动的源目录或文件与目标的目录或文件同名,不会询问,直接覆盖旧文件。
• -n: 不要覆盖任何已存在的文件或目录。
• -u:当源文件比目标文件新或者目标文件不存在时,才执行移动操作。
mv 参数设置与运行结果
命令格式 运行结果
mv source_file(文件) dest_file(文件) 将源文件名 source_file 改为目标文件名 dest_file
mv source_file(文件) dest_directory(目录) 将文件 source_file 移动到目标目录 dest_directory 中
mv source_directory(目录) dest_directory(目录) 目录名 dest_directory 已存在,将 source_directory 移动到目录名 dest_directory 中;目录名 dest_directory 不存在则 source_directory 改名为目录名 dest_directory
mv source_directory(目录) dest_file(文件) 出错
实例
将文件 aaa 改名为 bbb :
mv aaa bbb
将 info 目录放入 logs 目录中。注意,如果 logs 目录不存在,则该命令将 info 改名为 logs。
mv info/ logs
再如将 /usr/runoob 下的所有文件和目录移到当前目录下,命令行为:
$ mv /usr/runoob/* .
Od Linux od命令用于输出文件内容。
od指令会读取所给予的文件的内容,并将其内容以八进制字码呈现出来。
语法
od [-abcdfhilovx][-A <字码基数>][-j <字符数目>][-N <字符数目>][-s <字符串字符数>][-t <输出格式>][-w <每列字符数>][–help][–version][文件…]
参数:
• -a 此参数的效果和同时指定"-ta"参数相同。
• -A<字码基数> 选择要以何种基数计算字码。
• -b 此参数的效果和同时指定"-toC"参数相同。
• -c 此参数的效果和同时指定"-tC"参数相同。
• -d 此参数的效果和同时指定"-tu2"参数相同。
• -f 此参数的效果和同时指定"-tfF"参数相同。
• -h 此参数的效果和同时指定"-tx2"参数相同。
• -i 此参数的效果和同时指定"-td2"参数相同。
• -j<字符数目>或–skip-bytes=<字符数目> 略过设置的字符数目。
• -l 此参数的效果和同时指定"-td4"参数相同。
• -N<字符数目>或–read-bytes=<字符数目> 到设置的字符数目为止。
• -o 此参数的效果和同时指定"-to2"参数相同。
• -s<字符串字符数>或–strings=<字符串字符数> 只显示符合指定的字符数目的字符串。
• -t<输出格式>或–format=<输出格式> 设置输出格式。
• -v或–output-duplicates 输出时不省略重复的数据。
• -w<每列字符数>或–width=<每列字符数> 设置每列的最大字符数。
• -x 此参数的效果和同时指定"-h"参数相同。
• --help 在线帮助。
• --version 显示版本信息。
实例
创建 tmp 文件:
$ echo abcdef g > tmp
$ cat tmp
abcdef g
使用 od 命令:
$ od -b tmp
0000000 141 142 143 144 145 146 040 147 012
0000011
使用单字节八进制解释进行输出,注意左侧的默认地址格式为八字节:
$ od -c tmp
0000000 a b c d e f g \n
0000011
使用ASCII码进行输出,注意其中包括转义字符
$ od -t d1 tmp
0000000 97 98 99 100 101 102 32 103 10
0000011
使用单字节十进制进行解释
$ od -A d -c tmp
0000000 a b c d e f g \n
0000009
Paste Linux paste 命令用于合并文件的列
paste 指令会把每个文件以列对列的方式,一列列地加以合并。
语法
paste [-s][-d <间隔字符>][–help][–version][文件…]
参数:
• -d<间隔字符>或–delimiters=<间隔字符> 用指定的间隔字符取代跳格字符。
• -s或–serial 串列进行而非平行处理。
• --help 在线帮助。
• --version 显示帮助信息。
• [文件…] 指定操作的文件路径
实例
使用paste指令将文件"file"、“testfile”、“testfile1"进行合并,输入如下命令:
paste file testfile testfile1 #合并指定文件的内容
但是,在执行以上命令之前,首先使用"cat"指令对3个文件内容进行查看,显示如下所示:
$ cat file #file文件的内容
xiongdan 200
lihaihui 233
lymlrl 231
$ cat testfile #testfile文件的内容
liangyuanm ss
$ cat testfile1 #testfile1文件的内容
huanggai 56
zhixi 73
当合并指令”$ paste file testfile testfile1"执行后,程序界面中将显示合并后的文件内容,如下所示:
xiongdan 200
lihaihui 233
lymlrl 231
liangyuanm ss
huanggai 56
zhixi 73
若使用paste指令的参数"-s",则可以将一个文件中的多行数据合并为一行进行显示。例如,将文件"file"中的3行数据合并为一行数据进行显示,输入如下命令
$ paste -s file #合并指定文件的多行数据
上面的命令执行后,显示的数据内容如下所示:
xiongdan 200 lihaihui 233 lymlrl 231
注意:参数"-s"只是将testfile文件的内容调整显示方式,并不会改变原文件的内容格式。
Hello,Thisisthesecondfile!
#将比较结果保存到tetsfile.patch文件
$ diff testfile1 testfile2>testfile.patch
$ cat testfile.patch #查看补丁包的内容
1c1
Hello,Thisisthesecondfile!
#使用补丁包升级testfile1文件
$ patch -p0 testfile1 testfile.patch
patching file testfile1
KaTeX parse error: Expected 'EOF', got '#' at position 32: … #̲再次查看testfile1的内… diff testfile1 testfile2>testfile. patch"所使用的操作符">"表示将该操作符左边的文件数据写入到右边所指向的文件中。在这里,即是指将两个文件比较后的结果写入到文件"testfile.patch"中。
Rcp Linux rcp命令用于复制远程文件或目录
rcp指令用在远端复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到该目录中。
语法
rcp [-pr][源文件或目录][目标文件或目录]
或
rcp [-pr][源文件或目录…][目标文件]
参数:
-p 保留源文件或目录的属性,包括拥有者,所属群组,权限与时间。
-r 递归处理,将指定目录下的文件与子目录一并处理。
实例
使用rcp指令复制远程文件到本地进行保存。
设本地主机当前账户为rootlocal,远程主机账户为root,要将远程主机(218.6.132.5)主目录下的文件"testfile"复制到本地目录"test"中,则输入如下命令:
rcp [email protected]:./testfile testfile #复制远程文件到本地
rcp [email protected]:home/rootlocal/testfile testfile
#要求当前登录账户cmd 登录到远程主机
rcp 218.6.132.5:./testfile testfile
注意:指令"rcp"执行以后不会有返回信息,仅需要在目录"test"下查看是否存在文件"testfile"。若存在,则表示远程复制操作成功,否则远程复制操作失败。
Rm liunx rm(英文全拼: remove) 命令用于删除一个文件或者目录
语法
rm [options] name…
参数:
• -i 删除前逐一询问确认。
• -f 即使原档案属性设为唯读,亦直接删除,无需逐一确认。
• -r 将目录及以下之档案亦逐一删除。
实例
删除文件可以直接使用rm命令,若删除目录则必须配合选项"-r",例如:
rm:是否删除 一般文件 “test.txt”? y
rm: 无法删除目录"homework": 是一个目录
rm:是否删除 目录 “homework”? y
删除当前目录下的所有文件及目录,命令行为:
rm -r *
文件一旦通过rm命令删除,则无法恢复,所以必须格外小心地使用该命令。
Split Linux split命令用于将一个文件分割成数个。
该指令将大文件分割成较小的文件,在默认情况下将按照每1000行切割成一个小文件。
语法
split [–help][–version][-<行数>][-b <字节>][-C <字节>][-l <行数>][要切割的文件][输出文件名]
参数说明:
• -<行数> : 指定每多少行切成一个小文件
• -b<字节> : 指定每多少字节切成一个小文件
• --help : 在线帮助
• --version : 显示版本信息
• -C<字节> : 与参数"-b"相似,但是在切 割时将尽量维持每行的完整性
• [输出文件名] : 设置切割后文件的前置文件名, split会自动在前置文件名后再加上编号
实例
使用指令"split"将文件"README"每6行切割成一个文件,输入如下命令:
$ split -6 README #将README文件每六行分割成一个文件
以上命令执行后,指令"split"会将原来的大文件"README"切割成多个以"x"开头的小文件。而在这些小文件中,每个文件都只有6行内容。
使用指令"ls"查看当前目录结构,如下所示:
$ ls #执行ls指令
#获得当前目录结构
README xaa xad xag xab xae xah xac xaf xai
Tee Linux tee命令用于读取标准输入的数据,并将其内容输出成文件。
tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。
语法
tee [-ai][–help][–version][文件…]
参数:
• -a或–append 附加到既有文件的后面,而非覆盖它.
• -i或–ignore-interrupts 忽略中断信号。
• --help 在线帮助。
• --version 显示版本信息。
实例
使用指令"tee"将用户输入的数据同时保存到文件"file1"和"file2"中,输入如下命令:
$ tee file1 file2 #在两个文件中复制内容
以上命令执行后,将提示用户输入需要保存到文件的数据,如下所示:
My Linux #提示用户输入数据
My Linux #输出数据,进行输出反馈
此时,可以分别打开文件"file1"和"file2",查看其内容是否均是"My Linux"即可判断指令"tee"是否执行成功。
Touch 创建文件
Linux touch命令用于修改文件或者目录的时间属性,包括存取时间和更改时间。若文件不存在,系统会建立一个新的文件。
ls -l 可以显示档案的时间记录
语法
touch [-acfm][-d<日期时间>][-r<参考文件或目录>] [-t<日期时间>][–help][–version][文件或目录…]
参数说明:
• a 改变档案的读取时间记录。
• m 改变档案的修改时间记录。
• c 假如目的档案不存在,不会建立新的档案。与 --no-create 的效果一样。
• f 不使用,是为了与其他 unix 系统的相容性而保留。
• r 使用参考档的时间记录,与 --file 的效果一样。
• d 设定时间与日期,可以使用各种不同的格式。
• t 设定档案的时间记录,格式与 date 指令相同。
• --no-create 不会建立新档案。
• --help 列出指令格式。
• --version 列出版本讯息。
实例
使用指令"touch"修改文件"testfile"的时间属性为当前系统时间,输入如下命令:
$ touch testfile #修改文件的时间属性
首先,使用ls命令查看testfile文件的属性,如下所示:
$ ls -l testfile #查看文件的时间属性
#原来文件的修改时间为16:09
-rw-r–r-- 1 hdd hdd 55 2011-08-22 16:09 testfile
执行指令"touch"修改文件属性以后,并再次查看该文件的时间属性,如下所示:
$ touch testfile #修改文件时间属性为当前系统时间
$ ls -l testfile #查看文件的时间属性
#修改后文件的时间属性为当前系统时间
-rw-r–r-- 1 hdd hdd 55 2011-08-22 19:53 testfile
使用指令"touch"时,如果指定的文件不存在,则将创建一个新的空白文件。例如,在当前目录下,使用该指令创建一个空白文件"file",输入如下命令:
$ touch file #创建一个名为“file”的新的空白文件
Which Linux which命令用于查找文件
which指令会在环境变量$PATH设置的目录里查找符合条件的文件。
语法
which [文件…]
参数:
• -n<文件名长度> 指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名。
• -p<文件名长度> 与-n参数相同,但此处的<文件名长度>包括了文件的路径。
• -w 指定输出时栏位的宽度。
• -V 显示版本信息。
实例
使用指令"which"查看指令"bash"的绝对路径,输入如下命令:
$ which bash
上面的指令执行后,输出信息如下所示:
/bin/bash #bash可执行程序的绝对路径
Cp Linux cp(英文全拼:copy file)命令主要用于复制文件或目录。
语法
cp [options] source dest
或
cp [options] source… directory
参数说明:
• -a:此选项通常在复制目录时使用,它保留链接、文件属性,并复制目录下的所有内容。其作用等于dpR参数组合。
• -d:复制时保留链接。这里所说的链接相当于Windows系统中的快捷方式。
• -f:覆盖已经存在的目标文件而不给出提示。
• -i:与-f选项相反,在覆盖目标文件之前给出提示,要求用户确认是否覆盖,回答"y"时目标文件将被覆盖。
• -p:除复制文件的内容外,还把修改时间和访问权限也复制到新文件中。
• -r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件。
• -l:不复制文件,只是生成链接文件。
实例
使用指令 cp 将当前目录 test/ 下的所有文件复制到新目录 newtest 下,输入如下命令:
$ cp –r test/ newtest
注意:用户使用该指令复制目录时,必须使用参数 -r 或者 -R
Whhereis Linux whereis命令用于查找文件
该指令会在特定目录中查找符合条件的文件。这些文件应属于原始代码、二进制文件,或是帮助文件。
该指令只能用于查找二进制文件、源代码文件和man手册页,一般文件的定位需使用locate命令。
语法
whereis [-bfmsu][-B <目录>…][-M <目录>…][-S <目录>…][文件…]
参数:
• • -b 只查找二进制文件。
• -B<目录> 只在设置的目录下查找二进制文件。
• -f 不显示文件名前的路径名称。
• -m 只查找说明文件。
• -M<目录> 只在设置的目录下查找说明文件。
• -s 只查找原始代码文件。
• -S<目录> 只在设置的目录下查找原始代码文件。
• -u 查找不包含指定类型的文件。
实例
使用指令"whereis"查看指令"bash"的位置,输入如下命令:
$ whereis bash
上面的指令执行后,输出信息如下所示:
bash:/bin/bash/etc/bash.bashrc/usr/share/man/man1/bash.1.gz
注意:以上输出信息从左至右分别为查询的程序名、bash路径、bash的man 手册页路径。
如果用户需要单独查询二进制文件或帮助文件,可使用如下命令:
$ whereis -b bash
$ whereis -m bash
输出信息如下:
$ whereis -b bash #显示bash 命令的二进制程序
bash: /bin/bash /etc/bash.bashrc /usr/share/bash # bash命令的二进制程序的地址
$ whereis -m bash #显示bash 命令的帮助文件
bash: /usr/share/man/man1/bash.1.gz #bash命令的帮助文件地址
rhmask Linux rhmask命令用于对文件进行加密和解密操作。
执行rhmask指令可制作加密过的文件,方便用户在公开的网络上传输该文件,而不至于被任意盗用。
语法
rhmask [加密文件][输出文件] 或 rhmask [-d][加密文件][源文件][输出文件]
参数:
• -d 产生加密过的文件。
实例
使用指令"rhmask"将加密文件"code.txt"进行加密后,另存为输出文件"demo.txt",输入如下命令:
$ rhmask code.txt demo.txt
以上命令执行后,文件"code.txt"将被加密后,另存为已经加密的文件"demo.txt"。
注意:该指令有两种语法,用户可以有选择性地进行使用即可。
Scp Linux scp 命令用于 Linux 之间复制文件和目录。
scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。
scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。
语法
scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program]
[[user@]host1:]file1 […] [[user@]host2:]file2
简易写法:
scp [可选参数] file_source file_target
参数说明:
• -1: 强制scp命令使用协议ssh1
• -2: 强制scp命令使用协议ssh2
• -4: 强制scp命令只使用IPv4寻址
• -6: 强制scp命令只使用IPv6寻址
• -B: 使用批处理模式(传输过程中不询问传输口令或短语)
• -C: 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)
• -p:保留原文件的修改时间,访问时间和访问权限。
• -q: 不显示传输进度条。
• -r: 递归复制整个目录。
• -v:详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。
• -c cipher: 以cipher将数据传输进行加密,这个选项将直接传递给ssh。
• -F ssh_config: 指定一个替代的ssh配置文件,此参数直接传递给ssh。
• -i identity_file: 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
• -l limit: 限定用户所能使用的带宽,以Kbit/s为单位。
• -o ssh_option: 如果习惯于使用ssh_config(5)中的参数传递方式,
• -P port:注意是大写的P, port是指定数据传输用到的端口号
• -S program: 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
实例
1、从本地复制到远程
命令格式:
scp local_file remote_username@remote_ip:remote_folder
或者
scp local_file remote_username@remote_ip:remote_file
或者
scp local_file remote_ip:remote_folder
或者
scp local_file remote_ip:remote_file
• 第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名;
• 第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名;
应用实例:
scp /home/space/music/1.mp3 [email protected]:/home/root/others/music
scp /home/space/music/1.mp3 [email protected]:/home/root/others/music/001.mp3
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music/001.mp3
复制目录命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
• 第1个指定了用户名,命令执行后需要再输入密码;
• 第2个没有指定用户名,命令执行后需要输入用户名和密码;
应用实例:
scp -r /home/space/music/ [email protected]:/home/root/others/
scp -r /home/space/music/ www.runoob.com:/home/root/others/
上面命令将本地 music 目录复制到远程 others 目录下。
2、从远程复制到本地
从远程复制到本地,只要将从本地复制到远程的命令的后2个参数调换顺序即可,如下实例
应用实例:
scp [email protected]:/home/root/others/music /home/space/music/1.mp3
scp -r www.runoob.com:/home/root/others/ /home/space/music/
说明
1.如果远程服务器防火墙有为scp命令设置了指定的端口,我们需要使用 -P 参数来设置命令的端口号,命令格式如下:
#scp 命令使用端口号 4588
scp -P 4588 [email protected]:/usr/local/sin.sh /home/administrator
2.使用scp命令要确保使用的用户具有可读取远程服务器相应文件的权限,否则scp命令是无法起作用的。
Awk AWK 是一种处理文本文件的语言,是一个强大的文本分析工具。
之所以叫 AWK 是因为其取了三位创始人 Alfred Aho,Peter Weinberger, 和 Brian Kernighan 的 Family Name 的首字符。
语法
awk [选项参数] ‘script’ var=value file(s)
或
awk [选项参数] -f scriptfile var=value file(s)
选项参数说明:
• -F fs or --field-separator fs
指定输入文件折分隔符,fs是一个字符串或者是一个正则表达式,如-F:。
• -v var=value or --asign var=value
赋值一个用户定义变量。
• -f scripfile or --file scriptfile
从脚本文件中读取awk命令。
• -mf nnn and -mr nnn
对nnn值设置内在限制,-mf选项限制分配给nnn的最大块数目;-mr选项限制记录的最大数目。这两个功能是Bell实验室版awk的扩展功能,在标准awk中不适用。
• -W compact or --compat, -W traditional or --traditional
在兼容模式下运行awk。所以gawk的行为和标准的awk完全一样,所有的awk扩展都被忽略。
• -W copyleft or --copyleft, -W copyright or --copyright
打印简短的版权信息。
• -W help or --help, -W usage or --usage
打印全部awk选项和每个选项的简短说明。
• -W lint or --lint
打印不能向传统unix平台移植的结构的警告。
• -W lint-old or --lint-old
打印关于不能向传统unix平台移植的结构的警告。
• -W posix
打开兼容模式。但有以下限制,不识别:/x、函数关键字、func、换码序列以及当fs是一个空格时,将新行作为一个域分隔符;操作符和=不能代替和=;fflush无效。
• -W re-interval or --re-inerval
允许间隔正则表达式的使用,参考(grep中的Posix字符类),如括号表达式[[:alpha:]]。
• -W source program-text or --source program-text
使用program-text作为源代码,可与-f命令混用。
• -W version or --version
打印bug报告信息的版本。
基本用法
log.txt文本内容如下:
2 this is a test
3 Are you like awk
This’s a test
10 There are orange,apple,mongo
用法一:
awk ‘{[pattern] action}’ {filenames} # 行匹配语句 awk ‘’ 只能用单引号
实例:
2 a
3 like
This’s
10 orange,apple,mongo
2 a
3 like
This’s
10 orange,apple,mongo
用法二:
awk -F #-F相当于内置变量FS, 指定分割字符
实例:
2 this is a test
3 Are you like awk
This’s a test
10 There are orange apple
2 this is a test
3 Are you like awk
This’s a test
10 There are orange apple
2 3 2s
3 4 3s
This’s 1 This’ss
10 11 10s
用法四:
awk -f {awk脚本} {文件名}
实例:
$ awk -f cal.awk log.txt
运算符
运算符 描述
= += -= *= /= %= ^= **= 赋值
?: C条件表达式
|| 逻辑或
&& 逻辑与
~ 和 !~ 匹配正则表达式和不匹配正则表达式
< <= > >= != == 关系运算符
空格 连接
log.txt 2 1 ’ 1 1
log.txt 2 2 ’ 1 2
log.txt 2 3 ’ 2 3
log.txt 2 4 ’ 1 4
1 1 2 this is
2 2 3 Are you
3 3 This’s a test
4 4 10 There are
2 $ this $ test
3 $ Are $ awk
This’s $ a $
10 $ There $
使用正则,字符串匹配
3 Are you like awk
10 There are orange,apple,mongo
2 this is a test
This’s a test
Are like
a
There orange,apple,mongo
awk脚本
关于 awk 脚本,我们需要注意两个关键词 BEGIN 和 END。
• BEGIN{ 这里面放的是执行前的语句 }
• END {这里面放的是处理完所有的行后要执行的语句 }
• {这里面放的是处理每一行时要执行的语句}
假设有这么一个文件(学生成绩表):
$ cat score.txt
Marry 2143 78 84 77
Jack 2321 66 78 45
Tom 2122 48 77 71
Mike 2537 87 97 95
Bob 2415 40 57 62
我们的 awk 脚本如下:
$ cat cal.awk
#!/bin/awk -f
#运行前
BEGIN {
math = 0
english = 0
computer = 0
printf "NAME NO. MATH ENGLISH COMPUTER TOTAL\n"
printf "---------------------------------------------\n"
TOTAL: 319 393 350
AVERAGE: 63.80 78.60 70.00
666581
从文件中找出长度大于 80 的行:
awk ‘length>80’ log.txt
打印九九乘法表
seq 9 | sed ‘H;g’ | awk -v RS=’’ ‘{for(i=1;i<=NF;i++)printf("%dx%d=%d%s", i, NR, i*NR, i==NR?"\n":"\t")}’
read Linux read命令用于从标准输入读取数值
read 内部命令被用来从标准输入读取单行数据。这个命令可以用来读取键盘输入,当使用重定向的时候,可以读取文件中的一行数据。
语法
read [-ers] [-a aname] [-d delim] [-i text] [-n nchars] [-N nchars] [-p prompt] [-t timeout] [-u fd] [name …]
参数说明:
• -a 后跟一个变量,该变量会被认为是个数组,然后给其赋值,默认是以空格为分割符。
• -d 后面跟一个标志符,其实只有其后的第一个字符有用,作为结束的标志。
• -p 后面跟提示信息,即在输入前打印提示信息。
• -e 在输入的时候可以使用命令补全功能。
• -n 后跟一个数字,定义输入文本的长度,很实用。
• -r 屏蔽\,如果没有该选项,则\作为一个转义字符,有的话 \就是个正常的字符了。
• -s 安静模式,在输入字符时不再屏幕上显示,例如login时输入密码。
• -t 后面跟秒数,定义输入字符的等待时间。
• -u 后面跟fd,从文件描述符中读入,该文件描述符可以是exec新开启的。
实例
1、简单读取
#!/bin/bash
#这里默认会换行
echo "输入网站名: "
#读取从键盘的输入
read website
echo “你输入的网站名是 $website”
exit 0 #退出
测试结果为:
输入网站名:
www.runoob.com
你输入的网站名是 www.runoob.com
2、-p 参数,允许在 read 命令行中直接指定一个提示。
#!/bin/bash
read -p “输入网站名:” website
echo “你输入的网站名是 $website”
exit 0
测试结果为:
输入网站名:www.runoob.com
你输入的网站名是 www.runoob.com
3、-t 参数指定 read 命令等待输入的秒数,当计时满时,read命令返回一个非零退出状态。
#!/bin/bash
if read -t 5 -p “输入网站名:” website
then
echo “你输入的网站名是 $website”
else
echo “\n抱歉,你输入超时了。”
fi
exit 0
执行程序不输入,等待 5 秒后:
输入网站名:
抱歉,你输入超时了
4、除了输入时间计时,还可以使用 -n 参数设置 read 命令计数输入的字符。当输入的字符数目达到预定数目时,自动退出,并将输入的数据赋值给变量。
#!/bin/bash
read -n1 -p “Do you want to continue [Y/N]?” answer
case $answer in
Y | y)
echo “fine ,continue”;;
N | n)
echo “ok,good bye”;;
*)
echo “error choice”;;
esac
exit 0
该例子使用了-n 选项,后接数值 1,指示 read 命令只要接受到一个字符就退出。只要按下一个字符进行回答,read 命令立即接受输入并将其传给变量,无需按回车键。
只接收 2 个输入就退出:
#!/bin/bash
read -n2 -p "请随便输入两个字符: " any
echo “\n您输入的两个字符是:$any”
exit 0
执行程序输入两个字符:
请随便输入两个字符: 12
您输入的两个字符是:12
5、-s 选项能够使 read 命令中输入的数据不显示在命令终端上(实际上,数据是显示的,只是 read 命令将文本颜色设置成与背景相同的颜色)。输入密码常用这个选项。
#!/bin/bash
read -s -p “请输入您的密码:” pass
echo “\n您输入的密码是 $pass”
exit 0
执行程序输入密码后是不显示的:
请输入您的密码:
您输入的密码是 runoob
6.读取文件
每次调用 read 命令都会读取文件中的 “一行” 文本。当文件没有可读的行时,read 命令将以非零状态退出。
通过什么样的方法将文件中的数据传给 read 呢?使用 cat 命令并通过管道将结果直接传送给包含 read 命令的 while 命令。
测试文件 test.txt 内容如下:
123
456
runoob
测试代码:
#!/bin/bash
count=1 # 赋值语句,不加空格
cat test.txt | while read line # cat 命令的输出作为read命令的输入,read读到>的值放在line中
do
echo “Line c o u n t : count: count:line”
count=$[ $count + 1 ] # 注意中括号中的空格。
done
echo “finish”
exit 0
执行结果为:
Line 1:123
Line 2:456
Line 3:runoob
finish
使用 -e 参数,以下实例输入字符 a 后按下 Tab 键就会输出相关的文件名(该目录存在的):
$ read -e -p “输入文件名:” str
输入文件名:a
a.out a.py a.pyc abc.txt
输入文件名:a
文档编辑
Col liunx col 命令用于过滤控制字符
在许多UNIX说明文件里,都有RLF控制字符。当我们运用shell特殊字符">“和”>>",把说明文件的内容输出成纯文本文件时,控制字符会变成乱码,col指令则能有效滤除这些控制字符。
语法
col [-bfx][-l<缓冲区列数>]
参数:
• -b 过滤掉所有的控制字符,包括RLF和HRLF。
• -f 滤除RLF字符,但允许将HRLF字符呈现出来。
• -x 以多个空格字符来表示跳格字符。
• -l<缓冲区列数> 预设的内存缓冲区有128列,您可以自行指定缓冲区的大小。
实例
下面以 man 命令帮助文档为例,讲解col 命令的使用。
将man 命令的帮助文档保存为man_help,使用-b 参数过滤所有控制字符。在终端中使用如下命令:
man man | col-b > man_help
注:其中"|"用于建立管道,把man命令的输出结果转为col命令的输入数据。
Egrep Linux egrep命令用于在文件内查找指定的字符串
egrep执行效果与"grep-E"相似,使用的语法及参数可参照grep指令,与grep的不同点在于解读字符串的方法。
egrep是用extended regular expression语法来解读的,而grep则用basic regular expression 语法解读,extended regular expression比basic regular expression的表达更规范。
语法
egrep [范本模式] [文件或目录]
参数说明:
• [范本模式] :查找的字符串规则。
• [文件或目录] :查找的目标文件或目录。
实例
显示文件中符合条件的字符。例如,查找当前目录下所有文件中包含字符串"Linux"的文件,可以使用如下命令:
egrep Linux *
结果如下所示:
$ egrep Linux * #查找当前目录下包含字符串“Linux”的文件
testfile:hello Linux! #以下五行为testfile 中包含Linux字符的行
testfile:Linux is a free Unix-type operating system.
testfile:This is a Linux testfile!
testfile:Linux
testfile:Linux
testfile1:helLinux! #以下两行为testfile1中含Linux字符的行
testfile1:This a Linux testfile!
#以下两行为testfile_2 中包含Linux字符的行
testfile_2:Linux is a free unix-type opterating system.
testfile_2:Linux test
xx00:hello Linux! #xx00包含Linux字符的行
xx01:Linux is a free Unix-type operating system. #以下三行为xx01包含Linux字符的行
xx01:This is a Linux testfile!
xx01:Linux
grep Linux grep 命令用于查找文件里符合条件的字符串
grep 指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设 grep 指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为 -,则 grep 指令会从标准输入设备读取数据。
语法
grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][–help][范本样式][文件或目录…]
参数:
• -a 或 --text : 不要忽略二进制的数据。
• -A<显示行数> 或 --after-context=<显示行数> : 除了显示符合范本样式的那一列之外,并显示该行之后的内容。
• -b 或 --byte-offset : 在显示符合样式的那一行之前,标示出该行第一个字符的编号。
• -B<显示行数> 或 --before-context=<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前的内容。
• -c 或 --count : 计算符合样式的列数。
• -C<显示行数> 或 --context=<显示行数>或-<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前后的内容。
• -d <动作> 或 --directories=<动作> : 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
• -e<范本样式> 或 --regexp=<范本样式> : 指定字符串做为查找文件内容的样式。
• -E 或 --extended-regexp : 将样式为延伸的正则表达式来使用。
• -f<规则文件> 或 --file=<规则文件> : 指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
• -F 或 --fixed-regexp : 将样式视为固定字符串的列表。
• -G 或 --basic-regexp : 将样式视为普通的表示法来使用。
• -h 或 --no-filename : 在显示符合样式的那一行之前,不标示该行所属的文件名称。
• -H 或 --with-filename : 在显示符合样式的那一行之前,表示该行所属的文件名称。
• -i 或 --ignore-case : 忽略字符大小写的差别。
• -l 或 --file-with-matches : 列出文件内容符合指定的样式的文件名称。
• -L 或 --files-without-match : 列出文件内容不符合指定的样式的文件名称。
• -n 或 --line-number : 在显示符合样式的那一行之前,标示出该行的列数编号。
• -o 或 --only-matching : 只显示匹配PATTERN 部分。
• -q 或 --quiet或–silent : 不显示任何信息。
• -r 或 --recursive : 此参数的效果和指定"-d recurse"参数相同。
• -s 或 --no-messages : 不显示错误信息。
• -v 或 --invert-match : 显示不包含匹配文本的所有行。
• -V 或 --version : 显示版本信息。
• -w 或 --word-regexp : 只显示全字符合的列。
• -x --line-regexp : 只显示全列符合的列。
• -y : 此参数的效果和指定"-i"参数相同。
实例
1、在当前目录中,查找后缀有 file 字样的文件中包含 test 字符串的文件,并打印出该字符串的行。此时,可以使用如下命令:
grep test file
结果如下所示:
$ grep test test #查找前缀有“test”的文件包含“test”字符串的文件
testfile1:This a Linux testfile! #列出testfile1 文件中包含test字符的行
testfile_2:This is a linux testfile! #列出testfile_2 文件中包含test字符的行
testfile_2:Linux test #列出testfile_2 文件中包含test字符的行
2、以递归的方式查找符合条件的文件。例如,查找指定目录/etc/acpi 及其子目录(如果存在子目录的话)下所有文件中包含字符串"update"的文件,并打印出该字符串所在行的内容,使用的命令为:
grep -r update /etc/acpi
输出结果如下:
$ grep -r update /etc/acpi #以递归的方式查找“etc/acpi”
#下包含“update”的文件
/etc/acpi/ac.d/85-anacron.sh:# (Things like the slocate updatedb cause a lot of IO.)
Rather than
/etc/acpi/resume.d/85-anacron.sh:# (Things like the slocate updatedb cause a lot of
IO.) Rather than
/etc/acpi/events/thinkpad-cmos:action=/usr/sbin/thinkpad-keys–update
3、反向查找。前面各个例子是查找并打印出符合条件的行,通过"-v"参数可以打印出不符合条件行的内容。
查找文件名中包含 test 的文件中不包含test 的行,此时,使用的命令为:
grep -v test test
结果如下所示:
$ grep-v test* #查找文件名中包含test 的文件中不包含test 的行
testfile1:helLinux!
testfile1:Linis a free Unix-type operating system.
testfile1:Lin
testfile_1:HELLO LINUX!
testfile_1:LINUX IS A FREE UNIX-TYPE OPTERATING SYSTEM.
testfile_1:THIS IS A LINUX TESTFILE!
testfile_2:HELLO LINUX!
testfile_2:Linux is a free unix-type opterating system.
join Linux join命令用于将两个文件中,指定栏位内容相同的行连接起来
找出两个文件中,指定栏位内容相同的行,并加以合并,再输出到标准输出设备。
语法
join [-i][-a<1或2>][-e<字符串>][-o<格式>][-t<字符>][-v<1或2>][-1<栏位>][-2<栏位>][–help][–version][文件1][文件2]
参数:
• -a<1或2> 除了显示原来的输出内容之外,还显示指令文件中没有相同栏位的行。
• -e<字符串> 若[文件1]与[文件2]中找不到指定的栏位,则在输出中填入选项中的字符串。
• -i或–igore-case 比较栏位内容时,忽略大小写的差异。
• -o<格式> 按照指定的格式来显示结果。
• -t<字符> 使用栏位的分隔字符。
• -v<1或2> 跟-a相同,但是只显示文件中没有相同栏位的行。
• -1<栏位> 连接[文件1]指定的栏位。
• -2<栏位> 连接[文件2]指定的栏位。
• --help 显示帮助。
• --version 显示版本信息。
实例
连接两个文件。
为了清楚地了解join命令,首先通过cat命令显示文件testfile_1和 testfile_2 的内容。
然后以默认的方式比较两个文件,将两个文件中指定字段的内容相同的行连接起来,在终端中输入命令:
join testfile_1 testfile_2
首先查看testfile_1、testfile_2 中的文件内容:
$ cat testfile_1 #testfile_1文件中的内容
Hello 95 #例如,本例中第一列为姓名,第二列为数额
Linux 85
test 30
cmd@hdd-desktop:~$ cat testfile_2 #testfile_2文件中的内容
Hello 2005 #例如,本例中第一列为姓名,第二列为年份
Linux 2009
test 2006
然后使用join命令,将两个文件连接,结果如下:
$ join testfile_1 testfile_2 #连接testfile_1、testfile_2中的内容
Hello 95 2005 #连接后显示的内容
Linux 85 2009
test 30 2006
文件1与文件2的位置对输出到标准输出的结果是有影响的。例如将命令中的两个文件互换,即输入如下命令:
join testfile_2 testfile_1
最终在标准输出的输出结果将发生变化,如下所示:
$ join testfile_2 testfile_1 #改变文件顺序连接两个文件
Hello 2005 95 #连接后显示的内容
Linux 2009 85
test 2006 30
look Linux look命令用于查询单词。
look指令用于英文单字的查询。您仅需给予它欲查询的字首字符串,它会显示所有开头字符串符合该条件的单字。
语法
look [-adf][-t<字尾字符串>][字首字符串][字典文件]
参数说明:
• -a 使用另一个字典文件web2,该文件也位于/usr/dict目录下。
• -d 只对比英文字母和数字,其余一慨忽略不予比对。
• -f 忽略字符大小写差别。
• -t<字尾字符串> 设置字尾字符串。
实例
为了查找在testfile文件中以字母L开头的所有的行,可以输入如下命令:
look L testfile
原文件testfile中的内容如下:
$ cat testfile #查看testfile 文件内容
HELLO LINUX!
Linux is a free unix-type opterating system.
This is a linux testfile!
Linux test
在testfile文件中使用look命令查找以"L"开头的单词,结果如下:
$ look L testfile #查找以“L”开头的单词
Linux is a free unix-type opterating system. #第二行以“L”开头,列出全句
Linux test #第四行以“L”开头,列出全句
rgrep Linux rgrep命令用于递归查找文件里符合条件的字符串。
Linux rgrep命令用于递归查找文件里符合条件的字符串。
rgrep指令的功能和grep指令类似,可查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设rgrep指令会把含有范本样式的那一列显示出来。
语法
rgrep [-?BcDFhHilnNrv][-R<范本样式>][-W<列长度>][-x<扩展名>][–help][–version][范本样式][文件或目录…]
参说明数:
• -? 显示范本样式与范例的说明。
• -B 忽略二进制的数据。
• -c 计算符合范本样式的列数。
• -D 排错模式,只列出指令搜寻的目录清单,而不会读取文件内容。
• -F 当遇到符号连接时,rgrep预设是忽略不予处理,加上本参数后,rgrep指令就会读取该连接所指向的原始文件的内容。
• -h 特别将符合范本样式的字符串标示出来。
• -H 只列出符合范本样式的字符串,而非显示整列的内容。
• -i 忽略字符大小写的差别。
• -l 列出文件内容符合指定的范本样式的文件名称。
• -n 在显示符合坊本样式的那一列之前,标示出该列的列数编号。
• -N 不要递归处理。
• -r 递归处理,将指定目录下的所有文件及子目录一并处理。
• -R<范本样式> 此参数的效果和指定"-r"参数类似,但只主力符合范本样式文件名称的文件。
• -v 反转查找。
• -W<列长度> 限制符合范本样式的字符串所在列,必须拥有的字符数。
• -x<扩展名> 只处理符合指定扩展名的文件名称的文件。
• --help 在线帮助。
• --version 显示版本信息。
实例
在当前目录下查找句子中包含"Hello"字符串的文件,可使用如下命令:
rgrep Hello *
其搜索结果如下:
$ rgrep Hello * #在当前目录下查找句子中包含“Hello”字符串的文件
testfile_1:Hello 95 #testfile_1中包含“Hello”字符串的句子
testfile_2:Hello 2005 #testfile_2中包含“Hello”字符串的句子
sed Linux sed 命令是利用脚本来处理文本文件。
sed 可依照脚本的指令来处理、编辑文本文件。
Sed 主要用来自动编辑一个或多个文件、简化对文件的反复操作、编写转换程序等。
语法
sed [-hnV][-e
drink beer ?’
1 root❌0:0:root:/root:/bin/bash
2 bin❌1:1:bin:/bin:/sbin/nologin
Drink tea or …
drink beer ?
3 daemon❌2:2:daemon:/sbin:/sbin/nologin
…(后面省略)…
每一行之间都必须要以反斜杠『 \ 』来进行新行的添加喔!所以,上面的例子中,我们可以发现在第一行的最后面就有 \ 存在。
以行为单位的替换与显示
将第2-5行的内容取代成为『No 2-5 number』呢?
[root@www ~]# nl /etc/passwd | sed ‘2,5c No 2-5 number’
1 root❌0:0:root:/root:/bin/bash
No 2-5 number
6 sync❌5:0:sync:/sbin:/bin/sync
…(后面省略)…
透过这个方法我们就能够将数据整行取代了!
仅列出 /etc/passwd 文件内的第 5-7 行
[root@www ~]# nl /etc/passwd | sed -n ‘5,7p’
5 lp❌4:7:lp:/var/spool/lpd:/sbin/nologin
6 sync❌5:0:sync:/sbin:/bin/sync
7 shutdown❌6:0:shutdown:/sbin:/sbin/shutdown
可以透过这个 sed 的以行为单位的显示功能, 就能够将某一个文件内的某些行号选择出来显示。
数据的搜寻并显示
搜索 /etc/passwd有root关键字的行
nl /etc/passwd | sed ‘/root/p’
1 root❌0:0:root:/root:/bin/bash
1 root❌0:0:root:/root:/bin/bash
2 daemon❌1:1:daemon:/usr/sbin:/bin/sh
3 bin❌2:2:bin:/bin:/bin/sh
4 sys❌3:3:sys:/dev:/bin/sh
5 sync❌4:65534:sync:/bin:/bin/sync
…下面忽略
如果root找到,除了输出所有行,还会输出匹配行。
使用-n的时候将只打印包含模板的行。
nl /etc/passwd | sed -n ‘/root/p’
1 root❌0:0:root:/root:/bin/bash
数据的搜寻并删除
删除/etc/passwd所有包含root的行,其他行输出
nl /etc/passwd | sed ‘/root/d’
2 daemon❌1:1:daemon:/usr/sbin:/bin/sh
3 bin❌2:2:bin:/bin:/bin/sh
…下面忽略
#第一行的匹配root已经删除了
数据的搜寻并执行命令
搜索/etc/passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把bash替换为blueshell,再输出这行:
nl /etc/passwd | sed -n ‘/root/{s/bash/blueshell/;p;q}’
1 root❌0:0:root:/root:/bin/blueshell
最后的q是退出。
数据的搜寻并替换
除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。基本上 sed 的搜寻与替代的与 vi 相当的类似!他有点像这样:
sed ‘s/要被取代的字串/新的字串/g’
先观察原始信息,利用 /sbin/ifconfig 查询 IP
[root@www ~]# /sbin/ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
inet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
…(以下省略)…
本机的ip是192.168.1.100。
将 IP 前面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep ‘inet addr’ | sed ‘s/^.*addr://g’
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
接下来则是删除后续的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
将 IP 后面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep ‘inet addr’ | sed ‘s/^.addr://g’ | sed 's/Bcast. / / g ′ 192.168.1.100 多 点 编 辑 一 条 s e d 命 令 , 删 除 / e t c / p a s s w d 第 三 行 到 末 尾 的 数 据 , 并 把 b a s h 替 换 为 b l u e s h e l l n l / e t c / p a s s w d ∣ s e d − e ′ 3 , //g' 192.168.1.100 多点编辑 一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell nl /etc/passwd | sed -e '3, //g′192.168.1.100多点编辑一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshellnl/etc/passwd∣sed−e′3,d’ -e ‘s/bash/blueshell/’
1 root❌0:0:root:/root:/bin/blueshell
2 daemon❌1:1:daemon:/usr/sbin:/bin/sh
-e表示多点编辑,第一个编辑命令删除/etc/passwd第三行到末尾的数据,第二条命令搜索bash替换为blueshell。
直接修改文件内容(危险动作)
sed 可以直接修改文件的内容,不必使用管道命令或数据流重导向! 不过,由於这个动作会直接修改到原始的文件,所以请你千万不要随便拿系统配置来测试! 我们还是使用文件 regular_express.txt 文件来测试看看吧!
regular_express.txt 文件内容如下:
[root@www ~]# cat regular_express.txt
runoob.
google.
taobao.
facebook.
zhihu-
weibo-
利用 sed 将 regular_express.txt 内每一行结尾若为 . 则换成 !
[root@www ~]# sed -i ‘s/.KaTeX parse error: Expected 'EOF', got '#' at position 40: …xt [root@www ~]#̲ cat regular_ex…a # This is a test’ regular_express.txt
[root@www ~]# cat regular_express.txt
runoob!
google!
taobao!
facebook!
zhihu-
weibo-
由於 $ 代表的是最后一行,而 a 的动作是新增,因此该文件最后新增 # This is a test!
sed 的 -i 选项可以直接修改文件内容,这功能非常有帮助!举例来说,如果你有一个 100 万行的文件,你要在第 100 行加某些文字,此时使用 vim 可能会疯掉!因为文件太大了!那怎办?就利用 sed 啊!透过 sed 直接修改/取代的功能,你甚至不需要使用 vim 去修订!
Sort Linux sort命令用于将文本文件内容加以排序
sort可针对文本文件的内容,以行为单位来排序。
语法
sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符>][+<起始栏位>-<结束栏位>][–help][–verison][文件]
参数说明:
• -b 忽略每行前面开始出的空格字符。
• -c 检查文件是否已经按照顺序排序。
• -d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
• -f 排序时,将小写字母视为大写字母。
• -i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
• -m 将几个排序好的文件进行合并。
• -M 将前面3个字母依照月份的缩写进行排序。
• -n 依照数值的大小排序。
• -u 意味着是唯一的(unique),输出的结果是去完重了的。
• -o<输出文件> 将排序后的结果存入指定的文件。
• -r 以相反的顺序来排序。
• -t<分隔字符> 指定排序时所用的栏位分隔字符。
• +<起始栏位>-<结束栏位> 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
• --help 显示帮助。
• --version 显示版本信息。
实例
在使用sort命令以默认的式对文件的行进行排序,使用的命令如下:
sort testfile
sort 命令将以默认的方式将文本文件的第一列以ASCII 码的次序排列,并将结果输出到标准输出。
使用 cat命令显示testfile文件可知其原有的排序如下:
$ cat testfile #testfile文件原有排序
test 30
Hello 95
Linux 85
使用sort命令重排后的结果如下:
$ sort testfile #重排结果
Hello 95
Linux 85
test 30
spell Linux spell命令可建立拼写检查程序
spell可从标准输入设备读取字符串,结束后显示拼错的词汇。
语法
spell
实例
检查文件testfile是否有拼写错误,在命令行提示符下输入如下命令:
spell testfile
如果文件中有单词拼写错误,则输出如下信息:
$ spell testfile #检查testfile 拼写错误
scurity #以下为有错误的单词
tp
LANs
Securty
practicl
applcations
necesary
如果所检查的文件没有单词拼写错误,那么,命令运行后不会给出任何信息。
检查从标准输入读取的字符串。例如在命令行中输入如下命令:
spell
按回车键后,输入一串字符串,然后按Ctrl+D 组合键退出spell,屏幕上将显示拼写有错误的单词。如下所示:
$ spell #检查标准输入的字符串的拼写错误
hell,this is a linx sustem! #拼写错误的字符串
linx #以下为有拼写错误的单词
sustem
tr Linux tr 命令用于转换或删除文件中的字符。
tr 指令从标准输入设备读取数据,经过字符串转译后,将结果输出到标准输出设备。
语法
tr [-cdst][–help][–version][第一字符集][第二字符集]
tr [OPTION]…SET1[SET2]
参数说明:
• -c, --complement:反选设定字符。也就是符合 SET1 的部份不做处理,不符合的剩余部份才进行转换
• -d, --delete:删除指令字符
• -s, --squeeze-repeats:缩减连续重复的字符成指定的单个字符
• -t, --truncate-set1:削减 SET1 指定范围,使之与 SET2 设定长度相等
• --help:显示程序用法信息
• --version:显示程序本身的版本信息
字符集合的范围:
• \NNN 八进制值的字符 NNN (1 to 3 为八进制值的字符)
• \ 反斜杠
• \a Ctrl-G 铃声
• \b Ctrl-H 退格符
• \f Ctrl-L 走行换页
• \n Ctrl-J 新行
• \r Ctrl-M 回车
• \t Ctrl-I tab键
• \v Ctrl-X 水平制表符
• CHAR1-CHAR2 :字符范围从 CHAR1 到 CHAR2 的指定,范围的指定以 ASCII 码的次序为基础,只能由小到大,不能由大到小。
• [CHAR*] :这是 SET2 专用的设定,功能是重复指定的字符到与 SET1 相同长度为止
• [CHAR*REPEAT] :这也是 SET2 专用的设定,功能是重复指定的字符到设定的 REPEAT 次数为止(REPEAT 的数字采 8 进位制计算,以 0 为开始)
• [:alnum:] :所有字母字符与数字
• [:alpha:] :所有字母字符
• [:blank:] :所有水平空格
• [:cntrl:] :所有控制字符
• [:digit:] :所有数字
• [:graph:] :所有可打印的字符(不包含空格符)
• [:lower:] :所有小写字母
• [:print:] :所有可打印的字符(包含空格符)
• [:punct:] :所有标点字符
• [:space:] :所有水平与垂直空格符
• [:upper:] :所有大写字母
• [:xdigit:] :所有 16 进位制的数字
• [=CHAR=] :所有符合指定的字符(等号里的 CHAR,代表你可自订的字符)
实例
将文件testfile中的小写字母全部转换成大写字母,此时,可使用如下命令:
cat testfile |tr a-z A-Z
testfile文件中的内容如下:
$ cat testfile #testfile原来的内容
Linux networks are becoming more and more common,
but scurity is often an overlooked
issue. Unfortunately, in today’s environment all networks
are potential hacker targets,
fro0m tp-secret military research networks to small home LANs.
Linux Network Securty focuses on securing Linux in a
networked environment, where the
security of the entire network needs to be considered
rather than just isolated machines.
It uses a mix of theory and practicl techniques to
teach administrators how to install and
use security applications, as well as how the
applcations work and why they are necesary.
使用 tr 命令大小写转换后,得到如下输出结果:
$ cat testfile | tr a-z A-Z #转换后的输出
LINUX NETWORKS ARE BECOMING MORE AND MORE COMMON, BUT SCURITY IS OFTEN AN OVERLOOKED
ISSUE. UNFORTUNATELY, IN TODAY’S ENVIRONMENT ALL NETWORKS ARE POTENTIAL HACKER TARGETS,
FROM TP-SECRET MILITARY RESEARCH NETWORKS TO SMALL HOME LANS.
LINUX NETWORK SECURTY FOCUSES ON SECURING LINUX IN A NETWORKED ENVIRONMENT, WHERE THE
SECURITY OF THE ENTIRE NETWORK NEEDS TO BE CONSIDERED RATHER THAN JUST ISOLATED MACHINES.
IT USES A MIX OF THEORY AND PRACTICL TECHNIQUES TO TEACH ADMINISTRATORS HOW TO INSTALL AND
USE SECURITY APPLICATIONS, AS WELL AS HOW THE APPLCATIONS WORK AND WHY THEY ARE NECESARY.
大小写转换,也可以通过[:lower][:upper]参数来实现。例如使用如下命令:
cat testfile |tr [:lower:] [:upper:]
输出结果如下:
$ cat testfile | tr [:lower:] [:upper:] #转换后的输出
LINUX NETWORKS ARE BECOMING MORE AND MORE COMMON, BUT SCURITY IS OFTEN AN OVERLOOKED
ISSUE. UNFORTUNATELY, IN TODAY’S ENVIRONMENT ALL NETWORKS ARE POTENTIAL HACKER TARGETS,
FROM TP-SECRET MILITARY RESEARCH NETWORKS TO SMALL HOME LANS.
LINUX NETWORK SECURTY FOCUSES ON SECURING LINUX IN A NETWORKED ENVIRONMENT, WHERE THE
SECURITY OF THE ENTIRE NETWORK NEEDS TO BE CONSIDERED RATHER THAN JUST ISOLATED MACHINES.
IT USES A MIX OF THEORY AND PRACTICL TECHNIQUES TO TEACH ADMINISTRATORS HOW TO INSTALL AND
USE SECURITY APPLICATIONS, AS WELL AS HOW THE APPLCATIONS WORK AND WHY THEY ARE NECESARY.
Expr expr命令是一个手工命令行计数器,用于在UNIX/LINUX下求表达式变量的值,一般用于整数值,也可用于字符串
语法
expr 表达式
表达式说明:
• 用空格隔开每个项;
• 用反斜杠 \ 放在 shell 特定的字符前面;
• 对包含空格和其他特殊字符的字符串要用引号括起来
实例
1、计算字串长度
expr length “this is a test”
14
2、抓取字串
expr substr “this is a test” 3 5
is is
3、抓取第一个字符数字串出现的位置
expr index “sarasara” a
2
4、整数运算
expr 14 % 9
5
expr 10 + 10
20
expr 1000 + 900
1900
expr 30 / 3 / 2
5
expr 30 * 3 (使用乘号时,必须用反斜线屏蔽其特定含义。因为shell可能会误解显示星号的意义)
90
expr 30 * 3
expr: Syntax error
uniq Linux uniq 命令用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用
uniq 可检查文本文件中重复出现的行列。
语法
uniq [-cdu][-f<栏位>][-s<字符位置>][-w<字符位置>][–help][–version][输入文件][输出文件]
参数:
• -c或–count 在每列旁边显示该行重复出现的次数。
• -d或–repeated 仅显示重复出现的行列。
• -f<栏位>或–skip-fields=<栏位> 忽略比较指定的栏位。
• -s<字符位置>或–skip-chars=<字符位置> 忽略比较指定的字符。
• -u或–unique 仅显示出一次的行列。
• -w<字符位置>或–check-chars=<字符位置> 指定要比较的字符。
• --help 显示帮助。
• --version 显示版本信息。
• [输入文件] 指定已排序好的文本文件。如果不指定此项,则从标准读取数据;
• [输出文件] 指定输出的文件。如果不指定此选项,则将内容显示到标准输出设备(显示终端)。
实例
文件testfile中第 2、3、5、6、7、9行为相同的行,使用 uniq 命令删除重复的行,可使用以下命令:
uniq testfile
testfile中的原有内容为:
$ cat testfile #原有内容
test 30
test 30
test 30
Hello 95
Hello 95
Hello 95
Hello 95
Linux 85
Linux 85
使用uniq 命令删除重复的行后,有如下输出结果:
$ uniq testfile #删除重复行后的内容
test 30
Hello 95
Linux 85
检查文件并删除文件中重复出现的行,并在行首显示该行重复出现的次数。使用如下命令:
uniq -c testfile
结果输出如下:
$ uniq -c testfile #删除重复行后的内容
3 test 30 #前面的数字的意义为该行共出现了3次
4 Hello 95 #前面的数字的意义为该行共出现了4次
2 Linux 85 #前面的数字的意义为该行共出现了2次
当重复的行并不相邻时,uniq 命令是不起作用的,即若文件内容为以下时,uniq 命令不起作用:
$ cat testfile1 # 原有内容
test 30
Hello 95
Linux 85
test 30
Hello 95
Linux 85
test 30
Hello 95
Linux 85
这时我们就可以使用 sort:
$ sort testfile1 | uniq
Hello 95
Linux 85
test 30
统计各行在文件中出现的次数:
$ sort testfile1 | uniq -c
3 Hello 95
3 Linux 85
3 test 30
在文件中找出重复的行:
$ sort testfile1 | uniq -d
Hello 95
Linux 85
test 30
wc Linux wc命令用于计算字数
利用wc指令我们可以计算文件的Byte数、字数、或是列数,若不指定文件名称、或是所给予的文件名为"-",则wc指令会从标准输入设备读取数据。
语法
wc [-clw][–help][–version][文件…]
参数:
• -c或–bytes或–chars 只显示Bytes数。
• -l或–lines 显示行数。
• -w或–words 只显示字数。
• --help 在线帮助。
• --version 显示版本信息。
实例
在默认的情况下,wc将计算指定文件的行数、字数,以及字节数。使用的命令为:
wc testfile
先查看testfile文件的内容,可以看到:
$ cat testfile
Linux networks are becoming more and more common, but scurity is often an overlooked
issue. Unfortunately, in today’s environment all networks are potential hacker targets,
fro0m tp-secret military research networks to small home LANs.
Linux Network Securty focuses on securing Linux in a networked environment, where the
security of the entire network needs to be considered rather than just isolated machines.
It uses a mix of theory and practicl techniques to teach administrators how to install and
use security applications, as well as how the applcations work and why they are necesary.
使用 wc统计,结果如下:
$ wc testfile # testfile文件的统计信息
3 92 598 testfile # testfile文件的行数为3、单词数92、字节数598
其中,3 个数字分别表示testfile文件的行数、单词数,以及该文件的字节数。
如果想同时统计多个文件的信息,例如同时统计testfile、testfile_1、testfile_2,可使用如下命令:
wc testfile testfile_1 testfile_2 #统计三个文件的信息
输出结果如下:
$ wc testfile testfile_1 testfile_2 #统计三个文件的信息
3 92 598 testfile #第一个文件行数为3、单词数92、字节数598
9 18 78 testfile_1 #第二个文件的行数为9、单词数18、字节数78
3 6 32 testfile_2 #第三个文件的行数为3、单词数6、字节数32
15 116 708 总用量 #三个文件总共的行数为15、单词数116、字节数708
Let let 命令是 BASH 中用于计算的工具,用于执行一个或多个表达式,变量计算中不需要加上 $ 来表示变量。如果表达式中包含了空格或其他特殊字符,则必须引起来。
语法格式
let arg [arg …]
参数说明:
arg:要执行的表达式
实例:
自加操作:let no++
自减操作:let no–
简写形式 let no+=10,let no-=20,分别等同于 let no=no+10,let no=no-20。
以下实例计算 a 和 b 两个表达式,并输出结果:
#!/bin/bash
let a=5+4
let b=9-3
echo $a $b
以上实例执行结果为:
9 6
磁盘管理
Cd Linux cd(英文全拼:change directory)命令用于切换当前工作目录。
其中 dirName 表示法可为绝对路径或相对路径。若目录名称省略,则变换至使用者的 home 目录 (也就是刚 login 时所在的目录)。
另外,~ 也表示为 home 目录 的意思, . 则是表示目前所在的目录, … 则表示目前目录位置的上一层目录。
语法
cd [dirName]
• dirName:要切换的目标目录。
实例
跳到 /usr/bin/ :
cd /usr/bin
跳到自己的 home 目录 :
cd ~
跳到目前目录的上上两层 :
cd …/…
df Linux df(英文全拼:disk free) 命令用于显示目前在 Linux 系统上的文件系统磁盘使用情况统计
语法
df [选项]… [FILE]…
• 文件-a, --all 包含所有的具有 0 Blocks 的文件系统
• 文件–block-size={SIZE} 使用 {SIZE} 大小的 Blocks
• 文件-h, --human-readable 使用人类可读的格式(预设值是不加这个选项的…)
• 文件-H, --si 很像 -h, 但是用 1000 为单位而不是用 1024
• 文件-i, --inodes 列出 inode 资讯,不列出已使用 block
• 文件-k, --kilobytes 就像是 --block-size=1024
• 文件-l, --local 限制列出的文件结构
• 文件-m, --megabytes 就像 --block-size=1048576
• 文件–no-sync 取得资讯前不 sync (预设值)
• 文件-P, --portability 使用 POSIX 输出格式
• 文件–sync 在取得资讯前 sync
• 文件-t, --type=TYPE 限制列出文件系统的 TYPE
• 文件-T, --print-type 显示文件系统的形式
• 文件-x, --exclude-type=TYPE 限制列出文件系统不要显示 TYPE
• 文件-v (忽略)
• 文件–help 显示这个帮手并且离开
• 文件–version 输出版本资讯并且离开
实例
显示文件系统的磁盘使用情况统计:
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda6 29640780 4320704 23814388 16% /
udev 1536756 4 1536752 1% /dev
tmpfs 617620 888 616732 1% /run
none 5120 0 5120 0% /run/lock
none 1544044 156 1543888 1% /run/shm
第一列指定文件系统的名称,第二列指定一个特定的文件系统1K-块1K是1024字节为单位的总内存。用和可用列正在使用中,分别指定的内存量。
使用列指定使用的内存的百分比,而最后一栏"安装在"指定的文件系统的挂载点。
df也可以显示磁盘使用的文件系统信息:
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda6 29640780 4320600 23814492 16% /
用一个-i选项的df命令的输出显示inode信息而非块使用量。
df -i
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/sda6 1884160 261964 1622196 14% /
udev 212748 560 212188 1% /dev
tmpfs 216392 477 215915 1% /run
none 216392 3 216389 1% /run/lock
none 216392 8 216384 1% /run/shm
显示所有的信息:
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda6 29640780 4320720 23814372 16% /
udev 1536756 4 1536752 1% /dev
tmpfs 617620 892 616728 1% /run
none 5120 0 5120 0% /run/lock
none 1544044 156 1543888 1% /run/shm
total 33344320 4321772 27516860 14%
我们看到输出的末尾,包含一个额外的行,显示总的每一列。
-h选项,通过它可以产生可读的格式df命令的输出:
Filesystem Size Used Avail Use% Mounted on
/dev/sda6 29G 4.2G 23G 16% /
udev 1.5G 4.0K 1.5G 1% /dev
tmpfs 604M 892K 603M 1% /run
none 5.0M 0 5.0M 0% /run/lock
none 1.5G 156K 1.5G 1% /run/shm
我们可以看到输出显示的数字形式的’G’(千兆字节),“M”(兆字节)和"K"(千字节)。
这使输出容易阅读和理解,从而使显示可读的。请注意,第二列的名称也发生了变化,为了使显示可读的"大小"。
Du 用于显示目录或文件大小
du 会显示指定的目录或文件所占用的磁盘空间。
语法
du [-abcDhHklmsSx][-L <符号连接>][-X <文件>][–block-size][–exclude=<目录或文件>][–max-depth=<目录层数>][–help][–version][目录或文件]
参数说明:
• -a或-all 显示目录中个别文件的大小。
• -b或-bytes 显示目录或文件大小时,以byte为单位。
• -c或–total 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和。
• -D或–dereference-args 显示指定符号连接的源文件大小。
• -h或–human-readable 以K,M,G为单位,提高信息的可读性。
• -H或–si 与-h参数相同,但是K,M,G是以1000为换算单位。
• -k或–kilobytes 以1024 bytes为单位。
• -l或–count-links 重复计算硬件连接的文件。
• -L<符号连接>或–dereference<符号连接> 显示选项中所指定符号连接的源文件大小。
• -m或–megabytes 以1MB为单位。
• -s或–summarize 仅显示总计。
• -S或–separate-dirs 显示个别目录的大小时,并不含其子目录的大小。
• -x或–one-file-xystem 以一开始处理时的文件系统为准,若遇上其它不同的文件系统目录则略过。
• -X<文件>或–exclude-from=<文件> 在<文件>指定目录或文件。
• --exclude=<目录或文件> 略过指定的目录或文件。
• --max-depth=<目录层数> 超过指定层数的目录后,予以忽略。
• --help 显示帮助。
• --version 显示版本信息。
实例
显示目录或者文件所占空间:
608 ./test6
308 ./test4
4 ./scf/lib
4 ./scf/service/deploy/product
4 ./scf/service/deploy/info
12 ./scf/service/deploy
16 ./scf/service
4 ./scf/doc
4 ./scf/bin
32 ./scf
8 ./test3
1288 .
只显示当前目录下面的子目录的目录大小和当前目录的总的大小,最下面的1288为当前目录的总大小
显示指定文件所占空间
300 log2012.log
方便阅读的格式显示test目录所占空间情况:
608K test/test6
308K test/test4
4.0K test/scf/lib
4.0K test/scf/service/deploy/product
4.0K test/scf/service/deploy/info
12K test/scf/service/deploy
16K test/scf/service
4.0K test/scf/doc
4.0K test/scf/bin
32K test/scf
8.0K test/test3
1.3M test
mkdir Linux mkdir(英文全拼:make directory)命令用于创建目录
语法
mkdir [-p] dirName
参数说明:
• -p 确保目录名称存在,不存在的就建一个。
实例
在工作目录下,建立一个名为 runoob 的子目录 :
mkdir runoob
在工作目录下的 runoob2 目录中,建立一个名为 test 的子目录。
若 runoob2 目录原本不存在,则建立一个。(注:本例若不加 -p 参数,且原本 runoob2 目录不存在,则产生错误。)
mkdir -p runoob2/test
pwd Linux pwd(英文全拼:print work directory) 命令用于显示工作目录。
执行 pwd 指令可立刻得知您目前所在的工作目录的绝对路径名称。
语法
pwd [–help][–version]
参数说明:
• --help 在线帮助。
• --version 显示版本信息。
实例
查看当前所在目录:
/root/test #输出结果
Quota Linux quota命令用于显示磁盘已使用的空间与限制。
执行quota指令,可查询磁盘空间的限制,并得知已使用多少空间。
语法
quota [-quvV][用户名称…] 或 quota [-gqvV][群组名称…]
参数说明:
• -g 列出群组的磁盘空间限制。
• -q 简明列表,只列出超过限制的部分。
• -u 列出用户的磁盘空间限制。
• -v 显示该用户或群组,在所有挂入系统的存储设备的空间限制。
• -V 显示版本信息。
实例
Mount Linux mount命令是经常会使用到的命令,它用于挂载Linux系统外的文件。
语法
mount [-hV]
mount -a [-fFnrsvw] [-t vfstype]
mount [-fnrsvw] [-o options [,…]] device | dir
mount [-fnrsvw] [-t vfstype] [-o options] device dir
参数说明:
• -V:显示程序版本
• -h:显示辅助讯息
• -v:显示较讯息,通常和 -f 用来除错。
• -a:将 /etc/fstab 中定义的所有档案系统挂上。
• -F:这个命令通常和 -a 一起使用,它会为每一个 mount 的动作产生一个行程负责执行。在系统需要挂上大量 NFS 档案系统时可以加快挂上的动作。
• -f:通常用在除错的用途。它会使 mount 并不执行实际挂上的动作,而是模拟整个挂上的过程。通常会和 -v 一起使用。
• -n:一般而言,mount 在挂上后会在 /etc/mtab 中写入一笔资料。但在系统中没有可写入档案系统存在的情况下可以用这个选项取消这个动作。
• -s-r:等于 -o ro
• -w:等于 -o rw
• -L:将含有特定标签的硬盘分割挂上。
• -U:将档案分割序号为 的档案系统挂下。-L 和 -U 必须在/proc/partition 这种档案存在时才有意义。
• -t:指定档案系统的型态,通常不必指定。mount 会自动选择正确的型态。
• -o async:打开非同步模式,所有的档案读写动作都会用非同步模式执行。
• -o sync:在同步模式下执行。
• -o atime、-o noatime:当 atime 打开时,系统会在每次读取档案时更新档案的『上一次调用时间』。当我们使用 flash 档案系统时可能会选项把这个选项关闭以减少写入的次数。
• -o auto、-o noauto:打开/关闭自动挂上模式。
• -o defaults:使用预设的选项 rw, suid, dev, exec, auto, nouser, and async.
• -o dev、-o nodev-o exec、-o noexec允许执行档被执行。
• -o suid、-o nosuid:
• 允许执行档在 root 权限下执行。
• -o user、-o nouser:使用者可以执行 mount/umount 的动作。
• -o remount:将一个已经挂下的档案系统重新用不同的方式挂上。例如原先是唯读的系统,现在用可读写的模式重新挂上。
• -o ro:用唯读模式挂上。
• -o rw:用可读写模式挂上。
• -o loop=:使用 loop 模式用来将一个档案当成硬盘分割挂上系统。
实例
将 /dev/hda1 挂在 /mnt 之下。
#mount /dev/hda1 /mnt
将 /dev/hda1 用唯读模式挂在 /mnt 之下。
#mount -o ro /dev/hda1 /mnt
将 /tmp/image.iso 这个光碟的 image 档使用 loop 模式挂在 /mnt/cdrom之下。用这种方法可以将一般网络上可以找到的 Linux 光 碟 ISO 档在不烧录成光碟的情况下检视其内容。
#mount -o loop /tmp/image.iso /mnt/cdrom
Rmdir Linux rmdir(英文全拼:remove directory)命令删除空的目录。
语法
rmdir [-p] dirName
参数:
• -p 是当子目录被删除后使它也成为空目录的话,则顺便一并删除。
实例
将工作目录下,名为 AAA 的子目录删除 :
rmdir AAA
在工作目录下的 BBB 目录中,删除名为 Test 的子目录。若 Test 删除后,BBB 目录成为空目录,则 BBB 亦予删除。
rmdir -p BBB/Test
stat Linux stat命令用于显示inode内容。
stat以文字的格式来显示inode的内容。
语法
stat [文件或目录]
实例
查看 testfile 文件的inode内容内容,可以用以下命令:
执行以上命令输出结果:
File: `testfile’
Size: 102 Blocks: 8 IO Block: 4096 regular file
Device: 807h/2055d Inode: 1265161 Links: 1
Access: (0644/-rw-r–r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2014-08-13 14:07:20.000000000 +0800
Modify: 2014-08-13 14:07:07.000000000 +0800
Change: 2014-08-13 14:07:07.000000000 +0800
Tree Linux tree命令用于以树状图列出目录的内容。
执行tree指令,它会列出指定目录下的所有文件,包括子目录里的文件。
语法
tree [-aACdDfFgilnNpqstux][-I <范本样式>][-P <范本样式>][目录…]
参数说明:
• -a 显示所有文件和目录。
• -A 使用ASNI绘图字符显示树状图而非以ASCII字符组合。
• -C 在文件和目录清单加上色彩,便于区分各种类型。
• -d 显示目录名称而非内容。
• -D 列出文件或目录的更改时间。
• -f 在每个文件或目录之前,显示完整的相对路径名称。
• -F 在执行文件,目录,Socket,符号连接,管道名称名称,各自加上"*","/","=","@","|“号。
• -g 列出文件或目录的所属群组名称,没有对应的名称时,则显示群组识别码。
• -i 不以阶梯状列出文件或目录名称。
• -L level 限制目录显示层级。
• -l 如遇到性质为符号连接的目录,直接列出该连接所指向的原始目录。
• -n 不在文件和目录清单加上色彩。
• -N 直接列出文件和目录名称,包括控制字符。
• -p 列出权限标示。
• -P<范本样式> 只显示符合范本样式的文件或目录名称。
• -q 用”?"号取代控制字符,列出文件和目录名称。
• -s 列出文件或目录大小。
• -t 用文件和目录的更改时间排序。
• -u 列出文件或目录的拥有者名称,没有对应的名称时,则显示用户识别码。
• -x 将范围局限在现行的文件系统中,若指定目录下的某些子目录,其存放于另一个文件系统上,则将该子目录予以排除在寻找范围外。
实例
以树状图列出当前目录结构。可直接使用如下命令:
tree
该命令有如下输出结果:
. #当前目录结构
|-- README
|-- examples.desktop
|-- file
|-- file.new
|-- index.htm
|-- test
| |-- README
| |-- file
| |-- testfile
| |-- testfile1
| |-- xaa
| |-- xab
| |-- xac
| |-- xad
| |-- xae
| |-- xaf
| |-- xag
| |-- xah
| -- xai |-- test.tar.gz |-- test.zip |-- testfile |-- testfile.new |-- testfile.patch |-- testfile1 |-- testfile2 |-- testfile3 |-- xaa |-- xab |-- xac |-- xad |-- xae |-- xaf |-- xag |-- xah |-- xai |-- \345\205\254\345\205\261\347\232\204 |-- \345\233\276\347\211\207 | |-- 075b5c2bb1628c1a5343c10a.jpg | |-- 0c978fe989ac787e799757095719d3c4.jpg | |-- 20050726194826866443.jpg | |-- 20061113171548785122.jpg | |-- 2007102221576687.jpg | |-- 39.jpg | |-- 434887ec4340916a78f0559a.jpg | |-- 498da016ac02fb2bc93d6d08.jpg | |-- 7b284f5a0f854da2f3bf90b204149a34.jpg | |-- 9196c030d342a68d5edf0e98.jpg | |-- a56c5a90de15c8a9a977a4cc.jpg | |-- c74f62167c9d2b244a90a79e.jpg |
– img13.jpg
|-- \346\226\207\346\241\243
|-- \346\241\214\351\235\242
|-- \346\250\241\346\235\277
|-- \350\247\206\351\242\221
`-- \351\237\263\344\271\220
8 directories, 48 files #统计信息,该目录共8个子目录,48个文件
Umount Linux umount(英文全拼:unmount)命令用于卸除文件系统。
umount可卸除目前挂在Linux目录中的文件系统。
语法
umount [-ahnrvV][-t <文件系统类型>][文件系统]
参数:
• -a 卸除/etc/mtab中记录的所有文件系统。
• -h 显示帮助。
• -n 卸除时不要将信息存入/etc/mtab文件中。
• -r 若无法成功卸除,则尝试以只读的方式重新挂入文件系统。
• -t<文件系统类型> 仅卸除选项中所指定的文件系统。
• -v 执行时显示详细的信息。
• -V 显示版本信息。
• [文件系统] 除了直接指定文件系统外,也可以用设备名称或挂入点来表示文件系统。
实例
下面两条命令分别通过设备名和挂载点卸载文件系统,同时输出详细信息:
/dev/sda1 umounted
/tmp/diskboot.img umounted
如果设备正忙,卸载即告失败。卸载失败的常见原因是,某个打开的shell当前目录为挂载点里的某个目录:
umount: /mnt/mymount: device is busy
umount: /mnt/mymount: device is busy
ls Linux ls(英文全拼:list files)命令用于显示指定工作目录下之内容(列出目前工作目录所含之文件及子目录)。
语法
ls [-alrtAFR] [name…]
参数 :
• -a 显示所有文件及目录 (. 开头的隐藏文件也会列出)
• -l 除文件名称外,亦将文件型态、权限、拥有者、文件大小等资讯详细列出
• -r 将文件以相反次序显示(原定依英文字母次序)
• -t 将文件依建立时间之先后次序列出
• -A 同 -a ,但不列出 “.” (目前目录) 及 “…” (父目录)
• -F 在列出的文件名称后加一符号;例如可执行档则加 “*”, 目录则加 “/”
• -R 若目录下有文件,则以下之文件亦皆依序列出
实例
列出根目录()下的所有目录:
bin dev lib media net root srv upload www
boot etc lib64 misc opt sbin sys usr
home lost+found mnt proc selinux tmp var
列出目前工作目录下所有名称是 s 开头的文件,越新的排越后面 :
ls -ltr s*
将 /bin 目录以下所有目录及文件详细资料列出 :
ls -lR /bin
列出目前工作目录下所有文件及目录;目录于名称后加 “/”, 可执行档于名称后加 “*” :
ls -AF
quotacheck Linux quotacheck命令用于检查磁盘的使用空间与限制。
执行quotacheck指令,扫描挂入系统的分区,并在各分区的文件系统根目录下产生quota.user和quota.group文件,设置用户和群组的磁盘空间限制。
语法
quotacheck [-adgRuv][文件系统…]
参数:
• -a 扫描在/etc/fstab文件里,有加入quota设置的分区。
• -d 详细显示指令执行过程,便于排错或了解程序执行的情形。
• -g 扫描磁盘空间时,计算每个群组识别码所占用的目录和文件数目。
• -R 排除根目录所在的分区。
• -u 扫描磁盘空间时,计算每个用户识别码所占用的目录和文件数目。
• -v 显示指令执行过程。
Qutaoff Linux quotaoff命令关闭磁盘空间限制。
执行quotaoff指令可关闭用户和群组的磁盘空间限制。
语法
quotaoff [-aguv][文件系统…]
参数说明:
• -a 关闭在/etc/fstab文件里,有加入quota设置的分区的空间限制。
• -g 关闭群组的磁盘空间限制。
• -u 关闭用户的磁盘空间限制。
• -v 显示指令执行过程。
实例
关闭配额限制:
磁盘维护
Badblocks 用于检查磁盘装置中损坏的区域
执行指令时须指定所要检查的磁盘装置,及此装置的磁盘区块数。
语法
badblocks [-svw][-b <区块大小>][-o <输出文件>][磁盘装置][磁盘区块数][启始区块]
参数说明:
• -b<区块大小> 指定磁盘的区块大小,单位为字节。
• -o<输出文件> 将检查的结果写入指定的输出文件。
• -s 在检查时显示进度。
• -v 执行时显示详细的信息。
• -w 在检查时,执行写入测试。
• [磁盘装置] 指定要检查的磁盘装置。
• [磁盘区块数] 指定磁盘装置的区块总数。
• [启始区块] 指定要从哪个区块开始检查。
实例
查看系统当前硬盘信息。
例如,显示信息如下:
Disk /dev/sda: 298.9 GB, 298999349248 bytes
255 heads, 63 sectors/track, 36351 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sda1 1 262 2104483+ 82 Linux swap / Solaris
/dev/sda2 * 263 32898 262148670 83 Linux
/dev/sda3 32899 36351 27736222+ 83 Linux
Disk /dev/sdb: 42.9 GB, 42949672960 bytes
64 heads, 32 sectors/track, 40960 cylinders
Units = cylinders of 2048 * 512 = 1048576 bytes
通过命令扫描硬盘。
其中n表示硬盘设备名,x表示硬盘对应的分区号。例如需要检查"/dev/sda2",执行命令如下:
Checking blocks 0 to 30681000
Checking for bad blocks (read-only test): 306809600674112/ 306810000000
30680964
30680965
30680966
30680967
30680968
30680969
30680970
30680971
30680972
30680973
…
done
Pass completed, 37 bad blocks found.其中,“37 bad blocks found”表示硬盘存在37个坏块。
Cfdisk Linux cfdisk命令用于磁盘分区。
cfdisk是用来磁盘分区的程序,它十分类似DOS的fdisk,具有互动式操作界面而非传统fdisk的问答式界面,您可以轻易地利用方向键来操控分区操作。
语法
cfdisk [-avz][-c <柱面数目>-h <磁头数目>-s <盘区数目>][-P
参数说明:
• -a 在程序里不用反白代表选取,而以箭头表示。
• -c<柱面数目> 忽略BIOS的数值,直接指定磁盘的柱面数目。
• -h<磁头数目> 忽略BIOS的数值,直接指定磁盘的磁头数目。
• -P
• -s<磁区数目> 忽略BIOS的数值,直接指定磁盘的磁区数目。
• -v 显示版本信息。
• -z 不读取现有的分区,直接当作没有分区的新磁盘使用。
实例
进行磁盘分区:
进行磁盘分区,使用箭头进行操作,而不使用反白表示:
进行磁盘分区,使用箭头进行操作,而不使用反白表示:
e2fsck Linux e2fsck命令用于检查使用 Linux ext2 档案系统的 partition 是否正常工作
语法
e2fsck [-pacnydfvFV] [-b superblock] [-B blocksize] [-l|-L bad_blocks_file] [-C fd] device
参数说明:
• device : 预备检查的硬盘 partition,例如:/dev/sda1
• -a : 对 partition 做检查,若有问题便自动修复,等同 -p 的功能
• -b : 设定存放 superblock 的位置
• -B : 设定单位 block 的大小
• -c : 检查该partition 是否有坏轨
• -C file : 将检查的结果存到 file 中以便查看
• -d : 列印 e2fsck 的 debug 结果
• -f : 强制检查
• -F : 在开始检查前,将device 的 buffer cache 清空,避免有错误发生
• -l bad_blocks_file : 将有坏轨的block资料加到 bad_blocks_file 里面
• -L bad_blocks_file : 设定坏轨的block资料存到 bad_blocks_file 里面,若无该档则自动产生
• -n : 将档案系统以[唯读]方式开启
• -p : 对 partition 做检查,若有问题便自动修复
• -v : 详细显示模式
• -V : 显示出目前 e2fsck 的版本
• -y : 预先设定所有检查时的问题均回答[是]
实例
检查 /dev/hda5 是否正常,如果有异常便自动修复,并且设定若有问答,均回答[是] :
e2fsck -a -y /dev/hda5
注意 :
大部份使用 e2fsck 来检查硬盘 partition 的情况时,通常都是情形特殊,因此最好先将该 partition umount,然后再执行 e2fsck 来做检查,若是要非要检查 / 时,则请进入 singal user mode 再执行。
ext2ed Linux ext2ed命令是ext2文件系统编辑程序。
ext2ed可直接处理硬盘分区上的数据,这指令只有Red Hat Linux才提供。
语法
ext2ed
一般指令:
• setdevice[设备名称] 指定要处理的设备。
• disablewrite 将ext2ed设为只读的状态。
• enablewrite 将ext2ed设为可读写的状态。
• help[指令] 显示个别指令的帮助。
• next 移至下一个单位,单位会依目前所在的模式而异。
• prev 移至前一个单位,单位会依目前所在的模式而异。
• pgup 移至下一页。
• pgdn 移至上一页。
• set 修改目前的数据,参数会依目前所在的模式而异。
• writedata 在执行此指令之后,才会实际修改分区中的数据。
• ext2进入3种模式的指令
• super 进入main superblock,即Superblock模式。
• group<编号> 进入指定的group,即Group模式。
• cd<目录或文件> 在inode模式下,进入指定的目录或文件,即Inode模式。
• Superblock模式
• gocopy<备份编号> 进入指定的superblock备份。
• setactivecopy 将目前所在的superblock,复制到main superblock。
• Group模式
• blockbitmap 显示目前groupo的区块图。
• inode 进入目前group的第一个inode。
• inodebitmap 显示目前group的inode二进制码。
• Inode模式
• dir 进入目录模式。
• file 进入文件模式。
Fsck Linux fsck(英文全拼:file system check)命令用于检查与修复 Linux 档案系统,可以同时检查一个或多个 Linux 档案系统
语法
fsck [-sACVRP] [-t fstype] [–] [fsck-options] filesys […]
参数 :
• filesys : device 名称(eg./dev/sda1),mount 点 (eg. / 或 /usr)
• -t : 给定档案系统的型式,若在 /etc/fstab 中已有定义或 kernel 本身已支援的则不需加上此参数
• -s : 依序一个一个地执行 fsck 的指令来检查
• -A : 对/etc/fstab 中所有列出来的 partition 做检查
• -C : 显示完整的检查进度
• -d : 列印 e2fsck 的 debug 结果
• -p : 同时有 -A 条件时,同时有多个 fsck 的检查一起执行
• -R : 同时有 -A 条件时,省略 / 不检查
• -V : 详细显示模式
• -a : 如果检查有错则自动修复
• -r : 如果检查有错则由使用者回答是否修复
实例
检查 msdos 档案系统的 /dev/hda5 是否正常,如果有异常便自动修复 :
fsck -t msdos -a /dev/hda5
注意 此指令可与 /etc/fstab 相互参考操作来加以了解。
mke2fs Linux mke2fs命令用于建立ext2文件系统。
语法
mke2fs [-cFMqrSvV][-b <区块大小>][-f <不连续区段大小>][-i <字节>][-N
参数:
• -b<区块大小> 指定区块大小,单位为字节。
• -c 检查是否有损坏的区块。
• -f<不连续区段大小> 指定不连续区段的大小,单位为字节。
• -F 不管指定的设备为何,强制执行mke2fs。
• -i<字节> 指定"字节/inode"的比例。
• -N
• -l<文件> 从指定的文件中,读取文件西中损坏区块的信息。
• -L<标签> 设置文件系统的标签名称。
• -m<百分比值> 指定给管理员保留区块的比例,预设为5%。
• -M 记录最后一次挂入的目录。
• -q 执行时不显示任何信息。
• -r 指定要建立的ext2文件系统版本。
• -R=<区块数> 设置磁盘阵列参数。
• -S 仅写入superblock与group descriptors,而不更改inode able inode bitmap以及block bitmap。
• -v 执行时显示详细信息。
• -V 显示版本信息。
swapon Linux swapon命令用于激活Linux系统中交换空间,Linux系统的内存管理必须使用交换区来建立虚拟内存。
语法
/sbin/swapon -a [-v]
/sbin/swapon [-v] [-p priority] specialfile …
/sbin/swapon [-s]
参数说明:
• -h 请帮帮我
• -V 显示版本讯息
• -s 显示简短的装置讯息
• -a 自动启动所有SWAP装置
• -p 设定优先权,你可以在0到32767中间选一个数字给他。或是在 /etc/fstab 里面加上 pri=[value] ([value]就是0~32767中间一个数字),然后你就可以很方便的直接使用 swapon -a 来启动他们,而且有优先权设定。
swapon 是开启swap.
相对的,便有一个关闭swap的指令,swapoff
sync Linux sync命令用于数据同步,sync命令是在关闭Linux系统时使用的
Linux 系统中欲写入硬盘的资料有的时候为了效率起见,会写到 filesystem buffer 中,这个 buffer 是一块记忆体空间,如果欲写入硬盘的资料存于此 buffer 中,而系统又突然断电的话,那么资料就会流失了,sync 指令会将存于 buffer 中的资料强制写入硬盘中。
语法
sync
fdisk Linux fdisk是一个创建和维护分区表的程序,它兼容DOS类型的分区表、BSD或者SUN类型的磁盘列表。
fdisk [必要参数][选择参数]
必要参数:
• -l 列出素所有分区表
• -u 与"-l"搭配使用,显示分区数目
选择参数:
• -s<分区编号> 指定分区
• -v 版本信息
菜单操作说明
• m :显示菜单和帮助信息
• a :活动分区标记/引导分区
• d :删除分区
• l :显示分区类型
• n :新建分区
• p :显示分区信息
• q :退出不保存
• t :设置分区号
• v :进行分区检查
• w :保存修改
• x :扩展应用,高级功能
实例
显示当前分区情况:
Disk /dev/sda: 10.7 GB, 10737418240 bytes
255 heads, 63 sectors/track, 1305 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sda1 * 1 13 104391 83 Linux
/dev/sda2 14 1305 10377990 8e Linux LVM
Disk /dev/sdb: 5368 MB, 5368709120 bytes
255 heads, 63 sectors/track, 652 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Disk /dev/sdb doesn’t contain a valid partition table
显示SCSI硬盘的每个分区情况
Disk /dev/sda: 10.7 GB, 10737418240 bytes
255 heads, 63 sectors/track, 1305 cylinders, total 20971520 sectors
Units = sectors of 1 * 512 = 512 bytes
Device Boot Start End Blocks Id System
/dev/sda1 * 63 208844 104391 83 Linux
/dev/sda2 208845 20964824 10377990 8e Linux LVM
Disk /dev/sdb: 5368 MB, 5368709120 bytes
255 heads, 63 sectors/track, 652 cylinders, total 10485760 sectors
Units = sectors of 1 * 512 = 512 bytes
Disk /dev/sdb doesn’t contain a valid partition table
mkfs Linux mkfs(英文全拼:make file system)命令用于在特定的分区上建立 linux 文件系统。
使用方式 :
mkfs [-V] [-t fstype] [fs-options] filesys [blocks]
参数 :
• device : 预备检查的硬盘分区,例如:/dev/sda1
• -V : 详细显示模式
• -t : 给定档案系统的型式,Linux 的预设值为 ext2
• -c : 在制做档案系统前,检查该partition 是否有坏轨
• -l bad_blocks_file : 将有坏轨的block资料加到 bad_blocks_file 里面
• block : 给定 block 的大小
实例
在 /dev/hda5 上建一个 msdos 的档案系统,同时检查是否有坏轨存在,并且将过程详细列出来 :
mkfs -V -t msdos -c /dev/hda5
将sda6分区格式化为ext3格式
mfks -t ext3 /dev/sda6
注意:这里的文件系统是要指定的,比如 ext3 ;reiserfs ;ext2 ;fat32 ;msdos 等。
Sfdisk Linux sfdisk命令是硬盘分区工具程序。
sfdisk为硬盘分区工具程序,可显示分区的设置信息,并检查分区是否正常。
语法
sfdisk [-?Tvx][-d <硬盘>][-g <硬盘>][-l <硬盘>][-s <分区>][-V <硬盘>]
参数:
• -?或–help 显示帮助。
• -d<硬盘> 显示硬盘分区的设置。
• -g<硬盘>或–show-geometry<硬盘> 显示硬盘的CHS参数。
• -l<硬盘> 显示后硬盘分区的相关设置。
• -s<分区> 显示分区的大小,单位为区块。
• -T或–list-types 显示所有sfdisk能辨识的文件系统ID。
• -v或–version 显示版本信息。
• -V<硬盘>或–verify<硬盘> 检查硬盘分区是否正常。
• -x或–show-extend 显示扩展分区中的逻辑分区。
实例
显示分区信息:
Disk /dev/sda: 1305 cylinders, 255 heads, 63 sectors/track
Units = cylinders of 8225280 bytes, blocks of 1024 bytes, counting from 0
Device Boot Start End #cyls #blocks Id System
/dev/sda1 * 0+ 12 13- 104391 83 Linux
/dev/sda2 13 1304 1292 10377990 8e Linux LVM
/dev/sda3 0 - 0 0 0 Empty
/dev/sda4 0 - 0 0 0 Empty
Disk /dev/sdb: 652 cylinders, 255 heads, 63 sectors/track
sfdisk: ERROR: sector 0 does not have an msdos signature
/dev/sdb: unrecognized partition
No partitions found
网络通讯
telnet Linux telnet命令用于远端登入。
执行telnet指令开启终端机阶段作业,并登入远端主机。
语法
telnet [-8acdEfFKLrx][-b<主机别名>][-e<脱离字符>][-k<域名>][-l<用户名称>][-n<记录文件>][-S<服务类型>][-X<认证形态>][主机名称或IP地址<通信端口>]
参数说明:
• -8 允许使用8位字符资料,包括输入与输出。
• -a 尝试自动登入远端系统。
• -b<主机别名> 使用别名指定远端主机名称。
• -c 不读取用户专属目录里的.telnetrc文件。
• -d 启动排错模式。
• -e<脱离字符> 设置脱离字符。
• -E 滤除脱离字符。
• -f 此参数的效果和指定"-F"参数相同。
• -F 使用Kerberos V5认证时,加上此参数可把本地主机的认证数据上传到远端主机。
• -k<域名> 使用Kerberos认证时,加上此参数让远端主机采用指定的领域名,而非该主机的域名。
• -K 不自动登入远端主机。
• -l<用户名称> 指定要登入远端主机的用户名称。
• -L 允许输出8位字符资料。
• -n<记录文件> 指定文件记录相关信息。
• -r 使用类似rlogin指令的用户界面。
• -S<服务类型> 设置telnet连线所需的IP TOS信息。
• -x 假设主机有支持数据加密的功能,就使用它。
• -X<认证形态> 关闭指定的认证形态。
实例
登录远程主机
//登录IP为 192.168.0.5 的远程主机
Netconfig Linux netconfig命令用于设置网络环境。
这是Slackware发行版内附程序,它具有互动式的问答界面,让用户轻易完成网络环境的设置。
语法
netconfig
httpd Linux httpd命令是Apache HTTP服务器程序。
httpd为Apache HTTP服务器程序。直接执行程序可启动服务器的服务。
语法
httpd [-hlLStvVX][-c
参数说明:
• -c
• -C
• -d<服务器根目录> 指定服务器的根目录。
• -D<设定文件参数> 指定要传入配置文件的参数。
• -f<设定文件> 指定配置文件。
• -h 显示帮助。
• -l 显示服务器编译时所包含的模块。
• -L 显示httpd指令的说明。
• -S 显示配置文件中的设定。
• -t 测试配置文件的语法是否正确。
• -v 显示版本信息。
• -V 显示版本信息以及建立环境。
• -X 以单一程序的方式来启动服务器。
实例
检查配置文件语法错误
httpd: Could not determine the server’s fully qualified domain name, using 127.0.0.1 for ServerName
Syntax OK
启动httpd
httpd
httpd: Could not determine the server’s fully qualified domain name, using 127.0.0.1 for ServerName
显示编译模块
Compiled in modules:
core.c
prefork.c
http_core.c
mod_so.c
显示配置文件
Maximum number of children alive at the same time
Allowed in *.conf only outside , or
ServerLimit (prefork.c)
Maximum value of MaxClients for this run of Apache
Allowed in *.conf only outside , or
KeepAliveTimeout (http_core.c)
Keep-Alive timeout duration (sec)
Allowed in *.conf only outside , or
MaxKeepAliveRequests (http_core.c)
Maximum number of Keep-Alive requests per connection, or 0 for infinite
Allowed in *.conf only outside , or
KeepAlive (http_core.c)
Whether persistent connections should be On or Off
Allowed in *.conf only outside , or
LoadModule (mod_so.c)
a module name and the name of a shared object file to load it from
Allowed in *.conf only outside , or
LoadFile (mod_so.c)
shared object file or library to load into the server at runtime
Allowed in *.conf only outside , or
Ifconfig Linux ifconfig命令用于显示或设置网络设备。
ifconfig可设置网络设备的状态,或是显示目前的设置。
语法
ifconfig [网络设备][down up -allmulti -arp -promisc][add<地址>][del<地址>][
参数说明:
• add<地址> 设置网络设备IPv6的IP地址。
• del<地址> 删除网络设备IPv6的IP地址。
• down 关闭指定的网络设备。
•
• io_addr 设置网络设备的I/O地址。
• irq
• media<网络媒介类型> 设置网络设备的媒介类型。
• mem_start<内存地址> 设置网络设备在主内存所占用的起始地址。
• metric<数目> 指定在计算数据包的转送次数时,所要加上的数目。
• mtu<字节> 设置网络设备的MTU。
• netmask<子网掩码> 设置网络设备的子网掩码。
• tunnel<地址> 建立IPv4与IPv6之间的隧道通信地址。
• up 启动指定的网络设备。
• -broadcast<地址> 将要送往指定地址的数据包当成广播数据包来处理。
• -pointopoint<地址> 与指定地址的网络设备建立直接连线,此模式具有保密功能。
• -promisc 关闭或启动指定网络设备的promiscuous模式。
• [IP地址] 指定网络设备的IP地址。
• [网络设备] 指定网络设备的名称。
实例
显示网络设备信息
eth0 Link encap:Ethernet HWaddr 00:50:56:0A:0B:0C
inet addr:192.168.0.3 Bcast:192.168.0.255 Mask:255.255.255.0
inet6 addr: fe80::250:56ff:fe0a:b0c/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:172220 errors:0 dropped:0 overruns:0 frame:0
TX packets:132379 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:87101880 (83.0 MiB) TX bytes:41576123 (39.6 MiB)
Interrupt:185 Base address:0x2024
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:2022 errors:0 dropped:0 overruns:0 frame:0
TX packets:2022 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:2459063 (2.3 MiB) TX bytes:2459063 (2.3 MiB)
启动关闭指定网卡
为网卡配置和删除IPv6地址
用ifconfig修改MAC地址
配置IP地址
//给eth0网卡配置IP地址
// 给eth0网卡配置IP地址,并加上子掩码
// 给eth0网卡配置IP地址,加上子掩码,加上个广播地址
启用和关闭ARP协议
设置最大传输单元
//设置能通过的最大数据包大小为 1500 bytes
minicom
mesg
dnsconf Linux dnsconf命令用于设置DNS服务器组态。
语法
dnsconf [–deldomain<域>][–delsecondary<域>][–newdomain<域>][–set<主机>][–setcname<主机>][–setmx<域><主机>][–setns<域><主机>][–unset<主机>]
参数说明:
• --deldomain<域> 删除域。
• --delsecondary<域> 删除次级域。
• --newdomain<域> 新增域。
• --set<主机> 新增主机记录。
• --setcname<主机> 设置。
• --setmx<域><主机> 指定域的邮件主机。
• --setns<域><主机> 指定域的DNS服务器。
• --unset<主机> 删除DNS中某台主机的记录。
wall
netstat Linux netstat 命令用于显示网络状态。
利用 netstat 指令可让你得知整个 Linux 系统的网络情况。
语法
netstat [-acCeFghilMnNoprstuvVwx][-A<网络类型>][–ip]
参数说明:
• -a或–all 显示所有连线中的Socket。
• -A<网络类型>或–<网络类型> 列出该网络类型连线中的相关地址。
• -c或–continuous 持续列出网络状态。
• -C或–cache 显示路由器配置的快取信息。
• -e或–extend 显示网络其他相关信息。
• -F或–fib 显示FIB。
• -g或–groups 显示多重广播功能群组组员名单。
• -h或–help 在线帮助。
• -i或–interfaces 显示网络界面信息表单。
• -l或–listening 显示监控中的服务器的Socket。
• -M或–masquerade 显示伪装的网络连线。
• -n或–numeric 直接使用IP地址,而不通过域名服务器。
• -N或–netlink或–symbolic 显示网络硬件外围设备的符号连接名称。
• -o或–timers 显示计时器。
• -p或–programs 显示正在使用Socket的程序识别码和程序名称。
• -r或–route 显示Routing Table。
• -s或–statistics 显示网络工作信息统计表。
• -t或–tcp 显示TCP传输协议的连线状况。
• -u或–udp 显示UDP传输协议的连线状况。
• -v或–verbose 显示指令执行过程。
• -V或–version 显示版本信息。
• -w或–raw 显示RAW传输协议的连线状况。
• -x或–unix 此参数的效果和指定"-A unix"参数相同。
• --ip或–inet 此参数的效果和指定"-A inet"参数相同。
实例
显示详细的网络状况
显示当前户籍UDP连接状况
显示UDP端口号的使用情况
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
udp 0 0 *:32768 : -
udp 0 0 *:nfs : -
udp 0 0 *:641 : 3006/rpc.statd
udp 0 0 192.168.0.3:netbios-ns : 3537/nmbd
udp 0 0 *:netbios-ns : 3537/nmbd
udp 0 0 192.168.0.3:netbios-dgm : 3537/nmbd
udp 0 0 *:netbios-dgm : 3537/nmbd
udp 0 0 *:tftp : 3346/xinetd
udp 0 0 *:999 : 3366/rpc.rquotad
udp 0 0 *:sunrpc : 2986/portmap
udp 0 0 *:ipp : 6938/cupsd
udp 0 0 *:1022 : 3392/rpc.mountd
udp 0 0 *:638 : 3006/rpc.statd
显示网卡列表
Kernel Interface table
Iface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX-OK TX-ERR TX-DRP TX-OVR Flg
eth0 1500 0 181864 0 0 0 141278 0 0 0 BMRU
lo 16436 0 3362 0 0 0 3362 0 0 0 LRU
显示组播组的关系
IPv6/IPv4 Group Memberships
Interface RefCnt Group
lo 1 ALL-SYSTEMS.MCAST.NET
eth0 1 ALL-SYSTEMS.MCAST.NET
lo 1 ff02::1
eth0 1 ff02::1:ff0a:b0c
eth0 1 ff02::1
显示网络统计信息
Ip:
184695 total packets received
0 forwarded
0 incoming packets discarded
184687 incoming packets delivered
143917 requests sent out
32 outgoing packets dropped
30 dropped because of missing route
Icmp:
676 ICMP messages received
5 input ICMP message failed.
ICMP input histogram:
destination unreachable: 44
echo requests: 287
echo replies: 345
304 ICMP messages sent
0 ICMP messages failed
ICMP output histogram:
destination unreachable: 17
echo replies: 287
Tcp:
473 active connections openings
28 passive connection openings
4 failed connection attempts
11 connection resets received
1 connections established
178253 segments received
137936 segments send out
29 segments retransmited
0 bad segments received.
336 resets sent
Udp:
5714 packets received
8 packets to unknown port received.
0 packet receive errors
5419 packets sent
TcpExt:
1 resets received for embryonic SYN_RECV sockets
ArpFilter: 0
12 TCP sockets finished time wait in fast timer
572 delayed acks sent
3 delayed acks further delayed because of locked socket
13766 packets directly queued to recvmsg prequeue.
1101482 packets directly received from backlog
19599861 packets directly received from prequeue
46860 packets header predicted
14541 packets header predicted and directly queued to user
TCPPureAcks: 12259
TCPHPAcks: 9119
TCPRenoRecovery: 0
TCPSackRecovery: 0
TCPSACKReneging: 0
TCPFACKReorder: 0
TCPSACKReorder: 0
TCPRenoReorder: 0
TCPTSReorder: 0
TCPFullUndo: 0
TCPPartialUndo: 0
TCPDSACKUndo: 0
TCPLossUndo: 0
TCPLoss: 0
TCPLostRetransmit: 0
TCPRenoFailures: 0
TCPSackFailures: 0
TCPLossFailures: 0
TCPFastRetrans: 0
TCPForwardRetrans: 0
TCPSlowStartRetrans: 0
TCPTimeouts: 29
TCPRenoRecoveryFail: 0
TCPSackRecoveryFail: 0
TCPSchedulerFailed: 0
TCPRcvCollapsed: 0
TCPDSACKOldSent: 0
TCPDSACKOfoSent: 0
TCPDSACKRecv: 0
TCPDSACKOfoRecv: 0
TCPAbortOnSyn: 0
TCPAbortOnData: 1
TCPAbortOnClose: 0
TCPAbortOnMemory: 0
TCPAbortOnTimeout: 3
TCPAbortOnLinger: 0
TCPAbortFailed: 3
TCPMemoryPressures: 0
显示监听的套接口
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 *:32769 : LISTEN
tcp 0 0 *:nfs : LISTEN
tcp 0 0 *:644 : LISTEN
tcp 0 0 *:1002 : LISTEN
tcp 0 0 *:netbios-ssn : LISTEN
tcp 0 0 *:sunrpc : LISTEN
tcp 0 0 vm-dev:ipp : LISTEN
tcp 0 0 *:telnet : LISTEN
tcp 0 0 *:601 : LISTEN
tcp 0 0 *:microsoft-ds : LISTEN
tcp 0 0 *:http : LISTEN
tcp 0 0 *:ssh : LISTEN
tcp 0 0 *:https : LISTEN
udp 0 0 *:32768 :
udp 0 0 *:nfs :
udp 0 0 *:641 :
udp 0 0 192.168.0.3:netbios-ns :
udp 0 0 *:netbios-ns :
udp 0 0 192.168.0.3:netbios-dgm :
udp 0 0 *:netbios-dgm :
udp 0 0 *:tftp :
udp 0 0 *:999 :
udp 0 0 *:sunrpc :
udp 0 0 *:ipp :
udp 0 0 *:1022 :
udp 0 0 *:638 :
Active UNIX domain sockets (only servers)
Proto RefCnt Flags Type State I-Node Path
unix 2 [ ACC ] STREAM LISTENING 10621 @/tmp/fam-root-
unix 2 [ ACC ] STREAM LISTENING 7096 /var/run/acpid.socket
unix 2 [ ACC ] STREAM LISTENING 9792 /tmp/.gdm_socket
unix 2 [ ACC ] STREAM LISTENING 9927 /tmp/.X11-unix/X0
unix 2 [ ACC ] STREAM LISTENING 10489 /tmp/ssh-lbUnUf4552/agent.4552
unix 2 [ ACC ] STREAM LISTENING 10558 /tmp/ksocket-root/kdeinit__0
unix 2 [ ACC ] STREAM LISTENING 10560 /tmp/ksocket-root/kdeinit-:0
unix 2 [ ACC ] STREAM LISTENING 10570 /tmp/.ICE-unix/dcop4664-1270815442
unix 2 [ ACC ] STREAM LISTENING 10843 /tmp/.ICE-unix/4735
unix 2 [ ACC ] STREAM LISTENING 10591 /tmp/ksocket-root/klauncherah3arc.slave-socket
unix 2 [ ACC ] STREAM LISTENING 7763 /var/run/iiim/.iiimp-unix/9010
unix 2 [ ACC ] STREAM LISTENING 11047 /tmp/orbit-root/linc-1291-0-1e92c8082411
unix 2 [ ACC ] STREAM LISTENING 11053 /tmp/orbit-root/linc-128e-0-dc070659cbb3
unix 2 [ ACC ] STREAM LISTENING 8020 /var/run/dbus/system_bus_socket
unix 2 [ ACC ] STREAM LISTENING 58927 /tmp/mcop-root/vm-dev-2c28-4beba75f
unix 2 [ ACC ] STREAM LISTENING 7860 /tmp/.font-unix/fs7100
unix 2 [ ACC ] STREAM LISTENING 7658 /dev/gpmctl
unix 2 [ ACC ] STREAM LISTENING 10498 @/tmp/dbus-s2MLJGO5Ci
ping Linux ping命令用于检测主机。
执行ping指令会使用ICMP传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常。
语法
ping [-dfnqrRv][-c<完成次数>][-i<间隔秒数>][-I<网络界面>][-l<前置载入>][-p<范本样式>][-s<数据包大小>][-t<存活数值>][主机名称或IP地址]
参数说明:
• -d 使用Socket的SO_DEBUG功能。
• -c<完成次数> 设置完成要求回应的次数。
• -f 极限检测。
• -i<间隔秒数> 指定收发信息的间隔时间。
• -I<网络界面> 使用指定的网络接口送出数据包。
• -l<前置载入> 设置在送出要求信息之前,先行发出的数据包。
• -n 只输出数值。
• -p<范本样式> 设置填满数据包的范本样式。
• -q 不显示指令执行过程,开头和结尾的相关信息除外。
• -r 忽略普通的Routing Table,直接将数据包送到远端主机上。
• -R 记录路由过程。
• -s<数据包大小> 设置数据包的大小。
• -t<存活数值> 设置存活数值TTL的大小。
• -v 详细显示指令的执行过程。
实例
检测是否与主机连通
PING aries.m.alikunlun.com (114.80.174.110) 56(84) bytes of data.
64 bytes from 114.80.174.110: icmp_seq=1 ttl=64 time=0.025 ms
64 bytes from 114.80.174.110: icmp_seq=2 ttl=64 time=0.036 ms
64 bytes from 114.80.174.110: icmp_seq=3 ttl=64 time=0.034 ms
64 bytes from 114.80.174.110: icmp_seq=4 ttl=64 time=0.034 ms
64 bytes from 114.80.174.110: icmp_seq=5 ttl=64 time=0.028 ms
64 bytes from 114.80.174.110: icmp_seq=6 ttl=64 time=0.028 ms
64 bytes from 114.80.174.110: icmp_seq=7 ttl=64 time=0.034 ms
64 bytes from 114.80.174.110: icmp_seq=8 ttl=64 time=0.034 ms
64 bytes from 114.80.174.110: icmp_seq=9 ttl=64 time=0.036 ms
64 bytes from 114.80.174.110: icmp_seq=10 ttl=64 time=0.041 ms
— aries.m.alikunlun.com ping statistics —
10 packets transmitted, 30 received, 0% packet loss, time 29246ms
rtt min/avg/max/mdev = 0.021/0.035/0.078/0.011 ms
//需要手动终止Ctrl+C
指定接收包的次数
PING aries.m.alikunlun.com (114.80.174.120) 56(84) bytes of data.
64 bytes from 114.80.174.120: icmp_seq=1 ttl=54 time=6.18 ms
64 bytes from 114.80.174.120: icmp_seq=2 ttl=54 time=15.4 ms
— aries.m.alikunlun.com ping statistics —
2 packets transmitted, 2 received, 0% packet loss, time 1016ms
rtt min/avg/max/mdev = 6.185/10.824/15.464/4.640 ms
//收到两次包后,自动退出
多参数使用
PING g.cn (203.208.37.104) 1024(1052) bytes of data.
1032 bytes from bg-in-f104.1e100.net (203.208.37.104): icmp_seq=0 ttl=243 time=62.5 ms
1032 bytes from bg-in-f104.1e100.net (203.208.37.104): icmp_seq=1 ttl=243 time=63.9 ms
1032 bytes from bg-in-f104.1e100.net (203.208.37.104): icmp_seq=2 ttl=243 time=61.9 ms
— g.cn ping statistics —
3 packets transmitted, 3 received, 0% packet loss, time 6001ms
rtt min/avg/max/mdev = 61.959/62.843/63.984/0.894 ms, pipe 2
[root@linux ~]#
//-i 3 发送周期为 3秒 -s 设置发送包的大小 -t 设置TTL值为 255
系统管理
useradd Linux useradd 命令用于建立用户帐号。
useradd 可用来建立用户帐号。帐号建好之后,再用 passwd 设定帐号的密码。而可用 userdel 删除帐号。使用 useradd 指令所建立的帐号,实际上是保存在 /etc/passwd 文本文件中。
语法
useradd [-mMnr][-c <备注>][-d <登入目录>][-e <有效期限>][-f <缓冲天数>][-g <群组>][-G <群组>][-s ][-u ][用户帐号]
或
useradd -D [-b][-e <有效期限>][-f <缓冲天数>][-g <群组>][-G <群组>][-s ]
参数说明:
• -c<备注> 加上备注文字。备注文字会保存在passwd的备注栏位中。
• -d<登入目录> 指定用户登入时的起始目录。
• -D 变更预设值.
• -e<有效期限> 指定帐号的有效期限。
• -f<缓冲天数> 指定在密码过期后多少天即关闭该帐号。
• -g<群组> 指定用户所属的群组。
• -G<群组> 指定用户所属的附加群组。
• -m 自动建立用户的登入目录。
• -M 不要自动建立用户的登入目录。
• -n 取消建立以用户名称为名的群组.
• -r 建立系统帐号。
• -s 指定用户登入后所使用的shell。
• -u 指定用户ID。
实例
添加一般用户
为添加的用户指定相应的用户组
创建一个系统用户
为新添加的用户指定home目录
建立用户且制定ID
Date 时间
Linux date命令可以用来显示或设定系统的日期与时间,在显示方面,使用者可以设定欲显示的格式,格式设定为一个加号后接数个标记,其中可用的标记列表如下:
时间方面:
• % : 印出 %
• %n : 下一行
• %t : 跳格
• %H : 小时(00…23)
• %I : 小时(01…12)
• %k : 小时(0…23)
• %l : 小时(1…12)
• %M : 分钟(00…59)
• %p : 显示本地 AM 或 PM
• %r : 直接显示时间 (12 小时制,格式为 hh:mm:ss [AP]M)
• %s : 从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数
• %S : 秒(00…61)
• %T : 直接显示时间 (24 小时制)
• %X : 相当于 %H:%M:%S
• %Z : 显示时区
日期方面:
• %a : 星期几 (Sun…Sat)
• %A : 星期几 (Sunday…Saturday)
• %b : 月份 (Jan…Dec)
• %B : 月份 (January…December)
• %c : 直接显示日期与时间
• %d : 日 (01…31)
• %D : 直接显示日期 (mm/dd/yy)
• %h : 同 %b
• %j : 一年中的第几天 (001…366)
• %m : 月份 (01…12)
• %U : 一年中的第几周 (00…53) (以 Sunday 为一周的第一天的情形)
• %w : 一周中的第几天 (0…6)
• %W : 一年中的第几周 (00…53) (以 Monday 为一周的第一天的情形)
• %x : 直接显示日期 (mm/dd/yy)
• %y : 年份的最后两位数字 (00.99)
• %Y : 完整年份 (0000…9999)
若是不以加号作为开头,则表示要设定时间,而时间格式为 MMDDhhmm[[CC]YY][.ss],其中 MM 为月份,DD 为日,hh 为小时,mm 为分钟,CC 为年份前两位数字,YY 为年份后两位数字,ss 为秒数。
使用权限:所有使用者。
当您不希望出现无意义的 0 时(比如说 1999/03/07),则可以在标记中插入 - 符号,比如说 date ‘+%-H:%-M:%-S’ 会把时分秒中无意义的 0 给去掉,像是原本的 08:09:04 会变为 8:9:4。另外,只有取得权限者(比如说 root)才能设定系统时间。
当您以 root 身分更改了系统时间之后,请记得以 clock -w 来将系统时间写入 CMOS 中,这样下次重新开机时系统时间才会持续抱持最新的正确值。
语法
date [-u] [-d datestr] [-s datestr] [–utc] [–universal] [–date=datestr] [–set=datestr] [–help] [–version] [+FORMAT] [MMDDhhmm[[CC]YY][.ss]]
参数说明:
• -d datestr : 显示 datestr 中所设定的时间 (非系统时间)
• --help : 显示辅助讯息
• -s datestr : 将系统时间设为 datestr 中所设定的时间
• -u : 显示目前的格林威治时间
• --version : 显示版本编号
显示当前时间
三 5月 12 14:08:12 CST 2010
2010年05月12日 星期三 14时09分02秒
05/12/10
2010年05月12日
14:09:31
14时09分39秒
按自己的格式输出
usr_time: $1:16 下午 -hey
显示时间后跳行,再显示目前日期
date ‘+%T%n%D’
显示月份与日数
date ‘+%B %d’
显示日期与设定时间(12:34:56)
date --date ‘12:34:56’
exit linux exit命令用于退出目前的shell
执行exit可使shell以指定的状态值退出。若不设置状态值参数,则shell以预设值退出。状态值0代表执行成功,其他值代表执行失败。exit也可用在script,离开正在执行的script,回到shell。
语法
exit [状态值]
实例
退出终端
sleep Linux sleep命令可以用来将目前动作延迟一段时间。
使用权限:所有使用者。
语法
sleep [–help] [–version] number[smhd]
参数说明:
• --help : 显示辅助讯息
• --version : 显示版本编号
• number : 时间长度,后面可接 s、m、h 或 d
• 其中 s 为秒,m 为 分钟,h 为小时,d 为日数
实例
休眠5分钟
显示目前时间后延迟 1 分钟,之后再次显示时间
date;sleep 1m;date
groupdel Linux groupdel命令用于删除群组。
需要从系统上删除群组时,可用groupdel(group delete)指令来完成这项工作。倘若该群组中仍包括某些用户,则必须先删除这些用户后,方能删除群组。
语法
groupdel [群组名称]
实例
删除一个群组
Groupmod Linux groupmod命令用于更改群组识别码或名称
需要更改群组的识别码或名称时,可用groupmod指令来完成这项工作。
语法
groupmod [-g <群组识别码> <-o>][-n <新群组名称>][群组名称]
参数:
• -g <群组识别码> 设置欲使用的群组识别码。
• -o 重复使用群组识别码。
• -n <新群组名称> 设置欲使用的群组名称。
实例
修改组名
[[email protected] ~]# groupadd linuxso
[[email protected] ~]# tail -1 /etc/group
linuxso❌500:
[[email protected] ~]# tail -1 /etc/group
linuxso❌500:
[[email protected] ~]# groupmod -n linux linuxso
[[email protected] ~]# tail -1 /etc/group
linux❌500:
kill Linux kill 命令用于删除执行中的程序或工作。
kill 可将指定的信息送至程序。预设的信息为 SIGTERM(15),可将指定程序终止。若仍无法终止该程序,可使用 SIGKILL(9) 信息尝试强制删除程序。程序或工作的编号可利用 ps 指令或 jobs 指令查看。
语法
kill [-s <信息名称或编号>][程序] 或 kill [-l <信息编号>]
参数说明:
• -l <信息编号> 若不加<信息编号>选项,则 -l 参数会列出全部的信息名称。
• -s <信息名称或编号> 指定要送出的信息。
• [程序] [程序]可以是程序的PID或是PGID,也可以是工作编号。
使用 kill -l 命令列出所有可用信号。
最常用的信号是:
• 1 (HUP):重新加载进程。
• 9 (KILL):杀死一个进程。
• 15 (TERM):正常停止一个进程。
实例
杀死进程
强制杀死进程
发送SIGHUP信号,可以使用一下信号
彻底杀死进程
显示信号
Last Linux last 命令用于显示用户最近登录信息。
使用权限:所有使用者。
语法
shell>> last [options]
参数说明:
• -R 省略 hostname 的栏位
• -num 展示前 num 个
• username 展示 username 的登入讯息
• tty 限制登入讯息包含终端机代号
实例
shell>> last -R -2
johnney pts/1 Mon Aug 14 20:42 still logged in
johnney pts/0 Mon Aug 14 19:59 still logged in
wtmp begins Tue Aug 1 09:01:10 2000 ### /var/log/wtmp
shell>> last -2 minery
minery pts/0 140.119.217.115 Mon Aug 14 18:37 - 18:40 (00:03)
minery pts/0 140.119.217.115 Mon Aug 14 17:22 - 17:24 (00:02)
wtmp begins Tue Aug 1 09:01:10 2000
一般显示方法
简略显示,并指定显示的个数
root pts/4 Thu May 13 17:25 still logged in
root pts/2 Thu May 13 17:23 - 17:25 (00:02)
root pts/1 Thu May 13 16:46 still logged in
root pts/7 Thu May 13 15:36 still logged in
root pts/9 Thu May 13 15:35 still logged in
wtmp begins Thu May 13 18:55:40 2014
显示最后一列显示主机IP地址
root pts/4 Thu May 13 17:25 still logged in 192.168.1.10
root pts/2 Thu May 13 17:23 - 17:25 (00:02) 192.168.1.10
root pts/1 Thu May 13 16:46 still logged in 192.168.1.10
root pts/7 Thu May 13 15:36 still logged in 192.168.1.10
root pts/9 Thu May 13 15:35 still logged in 192.168.1.10
wtmp begins Thu May 13 18:55:40 2014
lastb Linux lastb命令用于列出登入系统失败的用户相关信息。
单独执行lastb指令,它会读取位于/var/log目录下,名称为btmp的文件,并把该文件内容
记录的登入失败的用户名单,全部显示出来。
语法
lastb [-adRx][-f <记录文件>][-n <显示列数>][帐号名称…][终端机编号…]
参数说明:
• -a 把从何处登入系统的主机名称或IP地址显示在最后一行。
• -d 将IP地址转换成主机名称。
• -f<记录文件> 指定记录文件。
• -n<显示列数>或-<显示列数> 设置列出名单的显示列数。
• -R 不显示登入系统的主机名称或IP地址。
• -x 显示系统关机,重新开机,以及执行等级的改变等信息。
实例
显示登录失败的用户
root tty7 :1 Thu May 13 11:26 - 11:26 (00:00)
btmp begins Thu May 13 11:26:39 2014
ps Linux ps (英文全拼:process status)命令用于显示当前进程的状态,类似于 windows 的任务管理器。
语法
ps [options] [–help]
参数:
• ps 的参数非常多, 在此仅列出几个常用的参数并大略介绍含义
• -A 列出所有的进程
• -w 显示加宽可以显示较多的资讯
• -au 显示较详细的资讯
• -aux 显示所有包含其他使用者的行程
• au(x) 输出格式 :
• USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
• USER: 行程拥有者
• PID: pid
• %CPU: 占用的 CPU 使用率
• %MEM: 占用的记忆体使用率
• VSZ: 占用的虚拟记忆体大小
• RSS: 占用的记忆体大小
• TTY: 终端的次要装置号码 (minor device number of tty)
• STAT: 该行程的状态:
• D: 无法中断的休眠状态 (通常 IO 的进程)
• R: 正在执行中
• S: 静止状态
• T: 暂停执行
• Z: 不存在但暂时无法消除
• W: 没有足够的记忆体分页可分配
• <: 高优先序的行程
• N: 低优先序的行程
• L: 有记忆体分页分配并锁在记忆体内 (实时系统或捱A I/O)
• START: 行程开始时间
• TIME: 执行的时间
• COMMAND:所执行的指令
实例
PID TTY TIME CMD
1 ? 00:00:02 init
2 ? 00:00:00 kthreadd
3 ? 00:00:00 migration/0
4 ? 00:00:00 ksoftirqd/0
5 ? 00:00:00 watchdog/0
6 ? 00:00:00 events/0
7 ? 00:00:00 cpuset
8 ? 00:00:00 khelper
9 ? 00:00:00 netns
10 ? 00:00:00 async/mgr
11 ? 00:00:00 pm
12 ? 00:00:00 sync_supers
13 ? 00:00:00 bdi-default
14 ? 00:00:00 kintegrityd/0
15 ? 00:00:02 kblockd/0
16 ? 00:00:00 kacpid
17 ? 00:00:00 kacpi_notify
18 ? 00:00:00 kacpi_hotplug
19 ? 00:00:27 ata/0
……省略部分结果
30749 pts/0 00:00:15 gedit
30886 ? 00:01:10 qtcreator.bin
30894 ? 00:00:00 qtcreator.bin
31160 ? 00:00:00 dhclient
31211 ? 00:00:00 aptd
31302 ? 00:00:00 sshd
31374 pts/2 00:00:00 bash
31396 pts/2 00:00:00 ps
显示指定用户信息
PID TTY TIME CMD
1 ? 00:00:02 init
2 ? 00:00:00 kthreadd
3 ? 00:00:00 migration/0
4 ? 00:00:00 ksoftirqd/0
5 ? 00:00:00 watchdog/0
6 ? 00:00:00 events/0
7 ? 00:00:00 cpuset
8 ? 00:00:00 khelper
9 ? 00:00:00 netns
10 ? 00:00:00 async/mgr
11 ? 00:00:00 pm
12 ? 00:00:00 sync_supers
13 ? 00:00:00 bdi-default
14 ? 00:00:00 kintegrityd/0
15 ? 00:00:02 kblockd/0
16 ? 00:00:00 kacpid
……省略部分结果
30487 ? 00:00:06 gnome-terminal
30488 ? 00:00:00 gnome-pty-helpe
30489 pts/0 00:00:00 bash
30670 ? 00:00:00 debconf-communi
30749 pts/0 00:00:15 gedit
30886 ? 00:01:10 qtcreator.bin
30894 ? 00:00:00 qtcreator.bin
31160 ? 00:00:00 dhclient
31211 ? 00:00:00 aptd
31302 ? 00:00:00 sshd
31374 pts/2 00:00:00 bash
31397 pts/2 00:00:00 ps
显示所有进程信息,连同命令行
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 10:22 ? 00:00:02 /sbin/init
root 2 0 0 10:22 ? 00:00:00 [kthreadd]
root 3 2 0 10:22 ? 00:00:00 [migration/0]
root 4 2 0 10:22 ? 00:00:00 [ksoftirqd/0]
root 5 2 0 10:22 ? 00:00:00 [watchdog/0]
root 6 2 0 10:22 ? /usr/lib/NetworkManager
……省略部分结果
root 31302 2095 0 17:42 ? 00:00:00 sshd: root@pts/2
root 31374 31302 0 17:42 pts/2 00:00:00 -bash
root 31400 1 0 17:46 ? 00:00:00 /usr/bin/python /usr/sbin/aptd
root 31407 31374 0 17:48 pts/2 00:00:00 ps -ef
procinfo Linux procinfo命令用于显示系统状态。
procinfo(process information)指令从/proc目录里读取相关数据,将数据妥善整理过后输出到标准输出设备。
语法
procinfo [-abdDfhimsSv][-F <输出文件>][-n <间隔秒数>]
参数说明:
• -a 显示所有信息。
• -b 显示磁盘设备的区块数目,而非存取数目。
• -d 显示系统信息每秒间的变化差额,而非总和的数值。本参数必须配合"-f"参数使用
• -D 此参数效果和指定"-d"参数类似,但内存和交换文件的信息为总和数值。
• -f 进入全画面的互动式操作界面。
• -F<输出文件> 把信息状态输出到文件保存起来,而非预设的标准输出设备。
• -h 在线帮助。
• -i 显示完整的IRP列表。
• -m 显示系统模块和外围设备等相关信息。
• -n<间隔秒数> 设置全画面互动模式的信息更新速度,单位以秒计算。
• -s 显示系统的内存,磁盘空间,IRP和DMA等信息,此为预设值。
• -S 搭配参数"-d"或"-D"使用时,每秒都会更新信息,不论是否有使用参数"-n"。
• -v 显示版本信息。
实例
显示系统状态
Top Linux top命令用于实时显示 process 的动态。
语法
top [-] [d delay] [q] [c] [S] [s] [i] [n] [b]
参数说明:
• d : 改变显示的更新速度,或是在交谈式指令列( interactive command)按 s
• q : 没有任何延迟的显示速度,如果使用者是有 superuser 的权限,则 top 将会以最高的优先序执行
• c : 切换显示模式,共有两种模式,一是只显示执行档的名称,另一种是显示完整的路径与名称
• S : 累积模式,会将己完成或消失的子行程 ( dead child process ) 的 CPU time 累积起来
• s : 安全模式,将交谈式指令取消, 避免潜在的危机
• i : 不显示任何闲置 (idle) 或无用 (zombie) 的行程
• n : 更新的次数,完成后将会退出 top
• b : 批次档模式,搭配 “n” 参数一起使用,可以用来将 top 的结果输出到档案内
实例
显示进程信息
显示完整命令
以批处理模式显示程序信息
以累积模式显示程序信息
设置信息更新次数
top -n 2
//表示更新两次后终止更新显示
设置信息更新时间
//表示更新周期为3秒
显示指定的进程信息
//显示进程号为139的进程信息,CPU、内存占用率等
显示更新十次后退出
top -n 10
使用者将不能利用交谈式指令来对行程下命令
top -s
pstree Linux pstree命令将所有行程以树状图显示,树状图将会以 pid (如果有指定) 或是以 init 这个基本行程为根 (root),如果有指定使用者 id,则树状图会只显示该使用者所拥有的行程
使用权限:所有使用者。
语法
pstree [-a] [-c] [-h|-Hpid] [-l] [-n] [-p] [-u] [-G|-U] [pid|user]
或
pstree -V
参数说明:
• -a 显示该行程的完整指令及参数, 如果是被记忆体置换出去的行程则会加上括号
• -c 如果有重覆的行程名, 则分开列出(预设值是会在前面加上 )
实例
显示进程的关系
pstree
init-±amd
|-apmd
|-atd
|-httpd—10[httpd]
%pstree -p
init(1)-±amd(447)
|-apmd(105)
|-atd(339)
%pstree -c
init-±amd
|-apmd
|-atd
|-httpd-±httpd
| |-httpd
| |-httpd
| |-httpd
…
特别表明在运行的进程
同时显示用户名称
Reboot Linux reboot命令用于用来重新启动计算机。
若系统的 runlevel 为 0 或 6 ,则重新开机,否则以 shutdown 指令(加上 -r 参数)来取代
语法
reboot [-n] [-w] [-d] [-f] [-i]
参数:
• -n : 在重开机前不做将记忆体资料写回硬盘的动作
• -w : 并不会真的重开机,只是把记录写到 /var/log/wtmp 档案里
• -d : 不把记录写到 /var/log/wtmp 档案里(-n 这个参数包含了 -d)
• -f : 强迫重开机,不呼叫 shutdown 这个指令
• -i : 在重开机之前先把所有网络相关的装置先停止
实例
重新启动
Shutdown Linux shutdown命令可以用来进行关机程序,并且在关机以前传送讯息给所有使用者正在执行的程序,shutdown 也可以用来重开机。
使用权限:系统管理者。
语法
shutdown [-t seconds] [-rkhncfF] time [message]
参数说明:
• -t seconds : 设定在几秒钟之后进行关机程序。
• -k : 并不会真的关机,只是将警告讯息传送给所有使用者。
• -r : 关机后重新开机。
• -h : 关机后停机。
• -n : 不采用正常程序来关机,用强迫的方式杀掉所有执行中的程序后自行关机。
• -c : 取消目前已经进行中的关机动作。
• -f : 关机时,不做 fcsk 动作(检查 Linux 档系统)。
• -F : 关机时,强迫进行 fsck 动作。
• time : 设定关机的时间。
• message : 传送给所有使用者的警告讯息。
实例
立即关机
指定 10 分钟后关机
重新启动计算机
Rwho Linux rwho命令用于查看系统用户。
rwho指令的效果类似who指令,但它会显示局域网里所有主机的用户。主机必须提供rwhod常驻服务的功能,方可使用rwho指令。
语法
rwho [-a]
参数说明:
• -a 列出所有的用户,包括闲置时间超过1个小时以上的用户。
实例
显示本地局域网内的所有用户
root snail-hnlinux:pts/2 May 14 17:42
sudo Linux sudo命令以系统管理者的身份执行指令,也就是说,经由 sudo 所执行的指令就好像是 root 亲自执行。
使用权限:在 /etc/sudoers 中有出现的使用者。
语法
sudo -V
sudo -h
sudo -l
sudo -v
sudo -k
sudo -s
sudo -H
sudo [ -b ] [ -p prompt ] [ -u username/#uid] -s
sudo command
参数说明:
• -V 显示版本编号
• -h 会显示版本编号及指令的使用方式说明
• -l 显示出自己(执行 sudo 的使用者)的权限
• -v 因为 sudo 在第一次执行时或是在 N 分钟内没有执行(N 预设为五)会问密码,这个参数是重新做一次确认,如果超过 N 分钟,也会问密码
• -k 将会强迫使用者在下一次执行 sudo 时问密码(不论有没有超过 N 分钟)
• -b 将要执行的指令放在背景执行
• -p prompt 可以更改问密码的提示语,其中 %u 会代换为使用者的帐号名称, %h 会显示主机名称
• -u username/#uid 不加此参数,代表要以 root 的身份执行指令,而加了此参数,可以以 username 的身份执行指令(#uid 为该 username 的使用者号码)
• -s 执行环境变数中的 SHELL 所指定的 shell ,或是 /etc/passwd 里所指定的 shell
• -H 将环境变数中的 HOME (家目录)指定为要变更身份的使用者家目录(如不加 -u 参数就是系统管理者 root )
• command 要以系统管理者身份(或以 -u 更改为其他人)执行的指令
实例
sudo命令使用
$ sudo ls
[sudo] password for hnlinux:
hnlinux is not in the sudoers file. This incident will be reported.
指定用户执行命令
显示sudo设置
$ sudo -L //显示sudo设置
Available options in a sudoers ``Defaults’’ line:
syslog: Syslog facility if syslog is being used for logging
syslog_goodpri: Syslog priority to use when user authenticates successfully
syslog_badpri: Syslog priority to use when user authenticates unsuccessfully
long_otp_prompt: Put OTP prompt on its own line
ignore_dot: Ignore ‘.’ in $PATH
mail_always: Always send mail when sudo is run
mail_badpass: Send mail if user authentication fails
mail_no_user: Send mail if the user is not in sudoers
mail_no_host: Send mail if the user is not in sudoers for this host
mail_no_perms: Send mail if the user is not allowed to run a command
tty_tickets: Use a separate timestamp for each user/tty combo
lecture: Lecture user the first time they run sudo
lecture_file: File containing the sudo lecture
authenticate: Require users to authenticate by default
root_sudo: Root may run sudo
log_host: Log the hostname in the (non-syslog) log file
log_year: Log the year in the (non-syslog) log file
shell_noargs: If sudo is invoked with no arguments, start a shell
set_home: Set $HOME to the target user when starting a shell with -s
always_set_home: Always set $HOME to the target user’s home directory
path_info: Allow some information gathering to give useful error messages
fqdn: Require fully-qualified hostnames in the sudoers file
insults: Insult the user when they enter an incorrect password
requiretty: Only allow the user to run sudo if they have a tty
env_editor: Visudo will honor the EDITOR environment variable
rootpw: Prompt for root’s password, not the users’s
runaspw: Prompt for the runas_default user’s password, not the users’s
targetpw: Prompt for the target user’s password, not the users’s
use_loginclass: Apply defaults in the target user’s login class if there is one
set_logname: Set the LOGNAME and USER environment variables
stay_setuid: Only set the effective uid to the target user, not the real uid
preserve_groups: Don’t initialize the group vector to that of the target user
loglinelen: Length at which to wrap log file lines (0 for no wrap)
timestamp_timeout: Authentication timestamp timeout
passwd_timeout: Password prompt timeout
passwd_tries: Number of tries to enter a password
umask: Umask to use or 0777 to use user’s
logfile: Path to log file
mailerpath: Path to mail program
mailerflags: Flags for mail program
mailto: Address to send mail to
mailfrom: Address to send mail from
mailsub: Subject line for mail messages
badpass_message: Incorrect password message
timestampdir: Path to authentication timestamp dir
timestampowner: Owner of the authentication timestamp dir
exempt_group: Users in this group are exempt from password and PATH requirements
passprompt: Default password prompt
passprompt_override: If set, passprompt will override system prompt in all cases.
runas_default: Default user to run commands as
secure_path: Value to override user’s $PATH with
editor: Path to the editor for use by visudo
listpw: When to require a password for ‘list’ pseudocommand
verifypw: When to require a password for ‘verify’ pseudocommand
noexec: Preload the dummy exec functions contained in ‘noexec_file’
noexec_file: File containing dummy exec functions
ignore_local_sudoers: If LDAP directory is up, do we ignore local sudoers file
closefrom: File descriptors >= %d will be closed before executing a command
closefrom_override: If set, users may override the value of `closefrom’ with the -C option
setenv: Allow users to set arbitrary environment variables
env_reset: Reset the environment to a default set of variables
env_check: Environment variables to check for sanity
env_delete: Environment variables to remove
env_keep: Environment variables to preserve
role: SELinux role to use in the new security context
type: SELinux type to use in the new security context
askpass: Path to the askpass helper program
env_file: Path to the sudo-specific environment file
sudoers_locale: Locale to use while parsing sudoers
visiblepw: Allow sudo to prompt for a password even if it would be visisble
pwfeedback: Provide visual feedback at the password prompt when there is user input
fast_glob: Use faster globbing that is less accurate but does not access the filesystem
umask_override: The umask specified in sudoers will override the user’s, even if it is more permissive
以root权限执行上一条命令
$ sudo !!
以特定用户身份进行编辑文本
$ sudo -u uggc vi ~www/index.html
//以 uggc 用户身份编辑 home 目录下www目录中的 index.html 文件
列出目前的权限
sudo -l
列出 sudo 的版本资讯
sudo -V
gitps Linux gitps命令用于报告程序状况。
gitps(gnu interactive tools process status)是用来报告并管理程序执行的指令,基本上它就是通过ps指令来报告,管理程序,也能通过gitps指令随时中断,删除不必要的程序。因为gitps指令会去执行ps指令,所以其参数和ps指令相当类似。
语法
gitps [acefgjlnrsSTuvwxX][p <程序识别码>][t <终端机编号>][U <帐号名称>]
参数说明:
• a 显示 现行终端机下的所有程序,包括其他用户的程序。
• c 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或是常驻服务的标示.
• e 列出程序时,显示每个程序所使用的环境变量。
• f 用ASCII字符显示树状结构,表达程序间的相互关系。
• g 显示现行终端机下的所有程序,包括群组领导者的程序。
• j 采用工作控制的格式来显示程序状况。
• l 采用纤细的格式来显示程序状况。
• n 以数字来表示USER和WCHAN栏位。
• p<程序识别码> 指定程序识别码,并列出该程序的状况。
• r 只列出现行终端机正在执行中的程序。
• s 采用程序信号的格式显示程序状况。
• S 列出程序时,包括已中断的子程序信息。
• t<终端机机标号> 指定终端机编号,并列出属于该终端机的程序的状况。
• T 显示现行终端机下的所有程序。
• u 以用户为主的格式来显示程序状况。
• U<帐号名称> 列出属于该用户的程序的状况。
• v 采用虚拟内存的格式显示程序状况。
• w 采用宽阔的格式来显示程序状况。
• x 显示所有程序,不以终端机来区分。
• X 采用旧试的Linux i386登陆格式显示程序状况。
实例
显示指定用户信息
Swatch Linux swatch命令用于系统监控程序。
swatch可用来监控系统记录文件,并在发现特定的事件时,执行指定的动作。swatch所监控的事件以及对应事件的动作都存放在swatch的配置文件中。预设的配置文件为拥护根目录下的.swatchrc。然而在Red Hat Linux的预设用户根目录下并没有.swatchrc配置文件,您可将/usr/doc/swatch-2.2/config_files/swatchrc.personal文件复制到用户根目录下的.swatchrc,然后修改.swatchrc所要监控的事件及执行的动作。
语法
swatch [-A <分隔字符>][-c <设置文件>][-f <记录文件>][-I <分隔字符>][-P <分隔字符>][-r <时间>][-t <记录文件>]
参数说明:
• -A<分隔字符> 预设配置文件中,动作的分隔字符,预设为逗号。
• -c<设置文件> 指定配置文件,而不使用预设的配置文件。
• -f<记录文件> 检查指定的记录文件,检查完毕后不会继续监控该记录文件。
• -I<分隔字符> 指定输入记录的分隔字符,预设为换行字符。
• -P<分隔字符> 指定配置文件中,事件的分隔字符,预设为逗号。
• -r<时间> 在指定的时间重新启动。
• -t<记录文件> 检查指定的记录文件,并且会监控加入记录文件中的后继记录。
实例
开启系统监视
Tload Linux tload命令用于显示系统负载状况。
tload指令使用ASCII字符简单地以文字模式显示系统负载状态。假设不给予终端机编号,则会在执行tload指令的终端机显示负载情形。
语法
tload [-V][-d <间隔秒数>][-s <刻度大小>][终端机编号]
参数说明:
• -d<间隔秒数> 设置tload检测系统负载的间隔时间,单位以秒计算。
• -s<刻度大小> 设置图表的垂直刻度大小,单位以列计算。
• -V 显示版本信息。
实例
显示系统负载
Uname Linux uname(英文全拼:unix name)命令用于显示系统信息。
uname 可显示电脑以及操作系统的相关信息。
语法
uname [-amnrsv][–help][–version]
参数说明:
• -a或–all 显示全部的信息。
• -m或–machine 显示电脑类型。
• -n或-nodename 显示在网络上的主机名称。
• -r或–release 显示操作系统的发行编号。
• -s或–sysname 显示操作系统名称。
• -v 显示操作系统的版本。
• --help 显示帮助。
• --version 显示版本信息。
实例
显示系统信息:
Linux iZbp19byk2t6khuqj437q6Z 4.11.0-14-generic #20~16.04.1-Ubuntu SMP Wed Aug 9 09:06:22 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
显示计算机类型:
x86_64
显示计算机名:
runoob-linux
显示操作系统发行编号:
4.11.0-14-generic
显示操作系统名称:
Linux
显示系统版本与时间:
#20~16.04.1-Ubuntu SMP Wed Aug 9 09:06:22 UTC 2017
Userconf Linux userconf命令用于用户帐号设置程序
userconf实际上为linuxconf的符号连接,提供图形界面的操作方式,供管理员建立与管理各类帐号。若不加任何参数,即进入图形界面。
语法
userconf [–addgroup <群组>][–adduser <用户ID><群组><用户名称>][–delgroup <群组>][–deluser <用户ID>][–help]
参数说明:
• --addgroup<群组> 新增群组。
• --adduser<用户ID><群组><用户名称> 新增用户帐号。
• --delgroup<群组> 删除群组。
• --deluser<用户ID> 删除用户帐号。
• --help 显示帮助。
实例
新增用户
Userdel Linux userdel命令用于删除用户帐号。
userdel可删除用户帐号与相关的文件。若不加参数,则仅删除用户帐号,而不删除相关文件。
语法
userdel [-r][用户帐号]
参数说明:
• -r 删除用户登入目录以及目录中所有文件。
实例
删除用户账号
Usermod Linux usermod命令用于修改用户帐号。
usermod可用来修改用户帐号的各项设定。
语法
usermod [-LU][-c <备注>][-d <登入目录>][-e <有效期限>][-f <缓冲天数>][-g <群组>][-G <群组>][-l <帐号名称>][-s ][-u ][用户帐号]
参数说明:
• -c<备注> 修改用户帐号的备注文字。
• -d登入目录> 修改用户登入时的目录。
• -e<有效期限> 修改帐号的有效期限。
• -f<缓冲天数> 修改在密码过期后多少天即关闭该帐号。
• -g<群组> 修改用户所属的群组。
• -G<群组> 修改用户所属的附加群组。
• -l<帐号名称> 修改用户帐号名称。
• -L 锁定用户密码,使密码无效。
• -s 修改用户登入后所使用的shell。
• -u 修改用户ID。
• -U 解除密码锁定。
实例
更改登录目录
改变用户的uid
Who Linux who命令用于显示系统中有哪些使用者正在上面,显示的资料包含了使用者 ID、使用的终端机、从哪边连上来的、上线时间、呆滞时间、CPU 使用量、动作等等。
使用权限:所有使用者都可使用。
语法
who - [husfV] [user]
参数说明:
• -H 或 --heading:显示各栏位的标题信息列;
• -i 或 -u 或 --idle:显示闲置时间,若该用户在前一分钟之内有进行任何动作,将标示成"."号,如果该用户已超过24小时没有任何动作,则标示出"old"字符串;
• -m:此参数的效果和指定"am i"字符串相同;
• -q 或–count:只显示登入系统的帐号名称和总人数;
• -s:此参数将忽略不予处理,仅负责解决who指令其他版本的兼容性问题;
• -w 或-T或–mesg或–message或–writable:显示用户的信息状态栏;
• --help:在线帮助;
• --version:显示版本信息。
实例
显示当前登录系统的用户
root tty7 2014-05-13 12:12 (:0)
root pts/0 2014-05-14 17:09 (:0.0)
root pts/1 2014-05-14 18:51 (192.168.1.17)
root pts/2 2014-05-14 19:48 (192.168.1.17)
显示标题栏
NAME LINE TIME COMMENT
root tty7 2014-05-13 12:12 (:0)
root pts/0 2014-05-14 17:09 (:0.0)
root pts/1 2014-05-14 18:51 (192.168.1.17)
root pts/2 2014-05-14 19:48 (192.168.1.17)
显示用户登录来源
NAME LINE TIME IDLE PID COMMENT
LOGIN tty4 2014-05-13 12:11 852 id=4
LOGIN tty5 2014-05-13 12:11 855 id=5
LOGIN tty2 2014-05-13 12:11 862 id=2
LOGIN tty3 2014-05-13 12:11 864 id=3
LOGIN tty6 2014-05-13 12:11 867 id=6
LOGIN tty1 2014-05-13 12:11 1021 id=1
显示终端属性
NAME LINE TIME COMMENT
root + tty7 2014-05-13 12:12 (:0)
root + pts/0 2014-05-14 17:09 (:0.0)
root - pts/1 2014-05-14 18:51 (192.168.1.17)
root - pts/2 2014-05-14 19:48 (192.168.1.17)
只显示当前用户
NAME LINE TIME COMMENT
root pts/1 2014-05-14 18:51 (192.168.1.17)
精简模式显示
root root root root
Whoami Linux whoami命令用于显示自身用户名称
显示自身的用户名称,本指令相当于执行"id -un"指令。
语法
whoami [–help][–version]
参数说明:
• --help 在线帮助。
• --version 显示版本信息。
实例
显示用户名
root
whois Linux whois命令用于查找并显示用户信息。
whois指令会去查找并显示指定帐号的用户相关信息,因为它是到Network Solutions的WHOIS数据库去查找,所以该帐号名称必须在上面注册方能寻获,且名称没有大小写的差别。
语法
whois [帐号名称]
实例
显示指定用户信息
//查找root用户信息
查询域名描述信息
Whois Server Version 2.0
Domain names in the .com and .net domains can now be registered
with many different competing registrars. Go to http://www.internic.net
for detailed information.
…省略部分内容
查询域名信息
The Registry database contains ONLY .COM, .NET, .EDU domains and
Registrars.
Domain Name … Lx138.COm
Name Server … dns15.hichina.com
dns16.hichina.com
Registrant ID … hc937242545-cn
…省略部分内容
查询域名信息省略法律声明
…省略内容
指定端口查询
…省略内容
Newgrp Linux newgrp 命令用于登入另一个群组。
newgrp 指令类似 login 指令,当它是以相同的帐号,另一个群组名称,再次登入系统。欲使用 newgrp 指令切换群组,您必须是该群组的用户,否则将无法登入指定的群组。单一用户要同时隶属多个群组,需利用交替用户的设置。若不指定群组名称,则 newgrp 指令会登入该用户名称的预设群组。
语法
newgrp [群组名称]
实例
改变群组
Su Linux su(英文全拼:swith user)命令用于变更为其他使用者的身份,除 root 外,需要键入该使用者的密码
使用权限:所有使用者。
语法
su [-fmp] [-c command] [-s shell] [–help] [–version] [-] [USER [ARG]]
参数说明:
• -f 或 --fast 不必读启动档(如 csh.cshrc 等),仅用于 csh 或 tcsh
• -m -p 或 --preserve-environment 执行 su 时不改变环境变数
• -c command 或 --command=command 变更为帐号为 USER 的使用者并执行指令(command)后再变回原来使用者
• -s shell 或 --shell=shell 指定要执行的 shell (bash csh tcsh 等),预设值为 /etc/passwd 内的该使用者(USER) shell
• --help 显示说明文件
• --version 显示版本资讯
• - -l 或 --login 这个参数加了之后,就好像是重新 login 为该使用者一样,大部份环境变数(HOME SHELL USER等等)都是以该使用者(USER)为主,并且工作目录也会改变,如果没有指定 USER ,内定是 root
• USER 欲变更的使用者帐号
• ARG 传入新的 shell 参数
实例
变更帐号为 root 并在执行 ls 指令后退出变回原使用者
su -c ls root
变更帐号为 root 并传入 -f 参数给新执行的 shell
su root -f
变更帐号为 clsung 并改变工作目录至 clsung 的家目录(home dir)
su - clsung
切换用户
[email protected]:~$ whoami //显示当前用户
hnlinux
[email protected]:~$ pwd //显示当前目录
/home/hnlinux
[email protected]:~$ su root //切换到root用户
密码:
[email protected]:/home/hnlinux# whoami
root
[email protected]:/home/hnlinux# pwd
/home/hnlinux
切换用户,改变环境变量
[email protected]:~$ whoami //显示当前用户
hnlinux
[email protected]:~$ pwd //显示当前目录
/home/hnlinux
[email protected]:~$ su - root //切换到root用户
密码:
[email protected]:/home/hnlinux# whoami
root
[email protected]:/home/hnlinux# pwd //显示当前目录
/root
Skill Linux skill命令送个讯号给正在执行的程序,预设的讯息为 TERM (中断),较常使用的讯息为 HUP、INT、KILL、STOP、CONT 和 0。
讯息有三种写法:分别为 -9、-SIGKILL、-KILL,可以使用 -l 或 -L 已列出可使用的讯息。
使用权限:所有使用者。
其他相关的命令:kill
语法
skill [signal to send] [options] 选择程序的规则
一般参数:
• -f 快速模式/尚未完成
• -i 互动模式/ 每个动作将要被确认
• -v 详细输出/ 列出所选择程序的资讯
• -w 智能警告讯息/ 尚未完成
• -n 没有动作/ 显示程序代号
参数:选择程序的规则可以是:终端机代号、使用者名称、程序代号、命令名称。
• -t 终端机代号 ( tty 或 pty )
• -u 使用者名称
• -p 程序代号 ( pid )
• -c 命令名称可使用的讯号
以下列出已知的讯号名称、讯号代号、功能。
名称(代号) 功能/描述
ALRM 14 离开
HUP 1 离开
INT 2 离开
KILL 9 离开/强迫关闭
PIPE 13 离开
POLL 离开
PROF 离开
TERM 15 离开
USR1 离开
USR2 离开
VTALRM 离开
STKFLT 离开/只适用于i386、m68k、arm 和 ppc 硬件
UNUSED 离开/只适用于i386、m68k、arm 和 ppc 硬件
TSTP 停止/产生与内容相关的行为
TTIN 停止/产生与内容相关的行为
TTOU 停止/产生与内容相关的行为
STOP 停止/强迫关闭
CONT 重新启动/如果在停止状态则重新启动,否则忽略
PWR 忽略/在某些系统中会离开
WINCH 忽略
CHLD 忽略
ABRT 6 核心
FPE 8 核心
ILL 4 核心
QUIT 3 核心
SEGV 11 核心
TRAP 5 核心
SYS 核心/或许尚未实作
EMT 核心/或许尚未实作
BUS 核心/核心失败
XCPU 核心/核心失败
XFSZ 核心/核心失败
实例
停止所有在 PTY 装置上的程序
skill -KILL -v pts/*
停止三个使用者 user1、user2、user3
skill -STOP user1 user2 user3
w Linux w命令用于显示目前登入系统的用户信息。
执行这项指令可得知目前登入系统的用户有哪些人,以及他们正在执行的程序。
单独执行 w 指令会显示所有的用户,您也可指定用户名称,仅显示某位用户的相关信息。
语法
w [-fhlsuV][用户名称]
参数说明:
• -f 开启或关闭显示用户从何处登入系统。
• -h 不显示各栏位的标题信息列。
• -l 使用详细格式列表,此为预设值。
• -s 使用简洁格式列表,不显示用户登入时间,终端机阶段作业和程序所耗费的CPU时间。
• -u 忽略执行程序的名称,以及该程序耗费CPU时间的信息。
• -V 显示版本信息。
实例
显示当前用户
w //显示当前用户,不显示登录位置
19:50:14 up 9:27, 4 users, load average: 0.31, 0.26, 0.18
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root tty7 :0 Thu12 31:39m 10:10 0.60s gnome-session
root pts/0 :0.0 17:09 2:18m 15.26s 0.15s bash
root pts/1 192.168.1.17 18:51 1.00s 1.24s 0.14s -bash
root pts/2 192.168.1.17 19:48 60.00s 0.05s 0.05s -bash
不显示登录位置
w -f
19:53:59 up 9:31, 4 users, load average: 0.05, 0.16, 0.15
USER TTY LOGIN@ IDLE JCPU PCPU WHAT
root tty7 Thu12 31:43m 10:10 0.60s gnome-session
root pts/0 17:09 2:21m 15.26s 0.15s bash
root pts/1 18:51 0.00s 1.04s 0.14s -bash
root pts/2 19:48 4:45 0.05s 0.05s -bash
以精简模式显示
w -s
19:54:37 up 9:31, 4 users, load average: 0.24, 0.19, 0.16
USER TTY FROM IDLE WHAT
root tty7 :0 31:43m gnome-session
root pts/0 :0.0 2:22m bash
root pts/1 192.168.1.17 0.00s -bash
root pts/2 192.168.1.17 5:23 -bash
不显示标题
w -h
root tty7 :0 Thu12 31:44m 10:10 0.60s gnome-session
root pts/0 :0.0 17:09 2:23m 15.26s 0.15s bash
root pts/1 192.168.1.17 18:51 0.00s 1.05s 0.14s -bash
root pts/2 192.168.1.17 19:48 5:54 0.05s 0.05s -bash
id Linux id命令用于显示用户的ID,以及所属群组的ID。
id会显示用户以及所属群组的实际与有效ID。若两个ID相同,则仅显示实际ID。若仅指定用户名称,则显示目前用户的ID。
语法
id [-gGnru][–help][–version][用户名称]
参数说明:
• -g或–group 显示用户所属群组的ID。
• -G或–groups 显示用户所属附加群组的ID。
• -n或–name 显示用户,所属群组或附加群组的名称。
• -r或–real 显示实际ID。
• -u或–user 显示用户ID。
• -help 显示帮助。
• -version 显示版本信息。
实例
显示当前用户信息
uid=0(root) gid=0(root) groups=0(root),1(bin),2(daemon),3(sys),4(adm),6(disk),10(wheel) context=root:system_r:unconfined_t
显示用户群组的ID
0
显示所有群组的ID
0 1 2 3 4 5 6 10
显示指定用户信息
Groupadd groupadd 命令用于创建一个新的工作组,新工作组的信息将被添加到系统文件中。
相关文件:
• /etc/group 组账户信息。
• /etc/gshadow 安全组账户信息。
• /etc/login.defs Shadow密码套件配置。
语法
groupadd 命令 语法格式如下:
groupadd [-g gid [-o]] [-r] [-f] group
参数说明:
• -g:指定新建工作组的 id;
• -r:创建系统工作组,系统工作组的组ID小于 500;
• -K:覆盖配置文件 “/ect/login.defs”;
• -o:允许添加组 ID 号不唯一的工作组。
• -f,–force: 如果指定的组已经存在,此选项将失明了仅以成功状态退出。当与 -g 一起使用,并且指定的GID_MIN已经存在时,选择另一个唯一的GID(即-g关闭)。
实例
创建一个新的组,并添加组 ID。
#groupadd -g 344 runoob
此时在 /etc/group 文件中产生一个组 ID(GID)是 344 的项目。
Free 用于显示内存状态
free指令会显示内存的使用情况,包括实体内存,虚拟的交换文件内存,共享内存区段,以及系统核心使用的缓冲区等。
语法
free [-bkmotV][-s <间隔秒数>]
参数说明:
• -b 以Byte为单位显示内存使用情况。
• -k 以KB为单位显示内存使用情况。
• -m 以MB为单位显示内存使用情况。
• -h 以合适的单位显示内存使用情况,最大为三位数,自动计算对应的单位值。单位有:
• B = bytes
• K = kilos
• M = megas
• G = gigas
T = teras
• -o 不显示缓冲区调节列。
• -s<间隔秒数> 持续观察内存使用状况。
• -t 显示内存总和列。
• -V 显示版本信息。
实例
显示内存使用情况
total used free shared buffers cached
Mem: 254772 184568 70204 0 5692 89892
-/+ buffers/cache: 88984 165788
Swap: 524280 65116 459164
以总和的形式显示内存的使用信息
total used free shared buffers cached
Mem: 254772 184868 69904 0 5936 89908
-/+ buffers/cache: 89024 165748
Swap: 524280 65116 459164
Total: 779052 249984 529068
周期性的查询内存使用信息
total used free shared buffers cached
Mem: 254772 187628 67144 0 6140 89964
-/+ buffers/cache: 91524 163248
Swap: 524280 65116 459164
total used free shared buffers cached
Mem: 254772 187748 67024 0 6164 89940
-/+ buffers/cache: 91644 163128
Swap: 524280 65116 459164
系统设置
Clear Linux clear命令用于清除屏幕。
语法
clear
实例
清屏
#clear
Crontab Linux crontab是用来定期执行程序的命令。
当安装完成操作系统之后,默认便会启动此任务调度命令。
crond 命令每分锺会定期检查是否有要执行的工作,如果有要执行的工作便会自动执行该工作。
注意:新创建的 cron 任务,不会马上执行,至少要过 2 分钟后才可以,当然你可以重启 cron 来马上执行。
而 linux 任务调度的工作主要分为以下两类:
• 1、系统执行的工作:系统周期性所要执行的工作,如备份系统数据、清理缓存
• 2、个人执行的工作:某个用户定期要做的工作,例如每隔10分钟检查邮件服务器是否有新信,这些工作可由每个用户自行设置
语法
crontab [ -u user ] file
或
crontab [ -u user ] { -l | -r | -e }
说明:
crontab 是用来让使用者在固定时间或固定间隔执行程序之用,换句话说,也就是类似使用者的时程表。
-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。
参数说明:
• -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv VISUAL joe)
• -r : 删除目前的时程表
• -l : 列出目前的时程表
时间格式如下:
f1 f2 f3 f4 f5 program
• 其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星期中的第几天。program 表示要执行的程序。
• 当 f1 为 * 时表示每分钟都要执行 program,f2 为 * 时表示每小时都要执行程序,其馀类推
• 当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其馀类推
• 当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为 */n 表示每 n 小时个时间间隔执行一次,其馀类推
• 当 f1 为 a, b, c,… 时表示第 a, b, c,… 分钟要执行,f2 为 a, b, c,… 时表示第 a, b, c…个小时要执行,其馀类推
| | | | |
| | | | ±---- 星期中星期几 (0 - 7) (星期天 为0)
| | | ±--------- 月份 (1 - 12)
| | ±-------------- 一个月中的第几天 (1 - 31)
| ±------------------- 小时 (0 - 23)
±------------------------ 分钟 (0 - 59)
使用者也可以将所有的设定先存放在文件中,用 crontab file 的方式来设定执行时间。
实例
每一分钟执行一次 /bin/ls:
50 7 * * * /sbin/service sshd start 意思是每天7:50开启ssh服务
50 22 * * * /sbin/service sshd stop 意思是每天22:50关闭ssh服务
0 0 1,15 * * fsck /home 每月1号和15号检查/home 磁盘
1 * * * * /home/bruce/backup 每小时的第一分执行 /home/bruce/backup这个文件
00 03 * * 1-5 find /home ".xxx" -mtime +4 -exec rm {} ; 每周一至周五3点钟,在目录/home中,查找文件名为.xxx的文件,并删除4天前的文件。
30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30执行一次ls命令
注意:当程序在你所指定的时间执行后,系统会发一封邮件给当前的用户,显示该程序执行的内容,若是你不希望收到这样的邮件,请在每一行空一格之后加上 > /dev/null 2>&1 即可,如:
20 03 * * * . /etc/profile;/bin/sh /var/www/runoob/test.sh > /dev/null 2>&1
脚本无法执行问题
如果我们使用 crontab 来定时执行脚本,无法执行,但是如果直接通过命令(如:./test.sh)又可以正常执行,这主要是因为无法读取环境变量的原因。
解决方法:
• 1、所有命令需要写成绝对路径形式,如: /usr/local/bin/docker。
• 2、在 shell 脚本开头使用以下代码:
• #!/bin/sh
•
• . /etc/profile
. ~/.bash_profile
3、在 /etc/crontab 中添加环境变量,在可执行命令之前添加命令 . /etc/profile;/bin/sh,使得环境变量生效,例如:
20 03 * * * . /etc/profile;/bin/sh /var/www/runoob/test.sh
Depmod Linux depmod命令用于分析可载入模块的相依性。
depmod(depend module)可检测模块的相依性,供modprobe在安装模块时使用。
语法
depmod [-adeisvV][-m <文件>][–help][模块名称]
参数说明:
• -a或–all 分析所有可用的模块。
• -d或debug 执行排错模式。
• -e 输出无法参照的符号。
• -i 不检查符号表的版本。
• -m<文件>或system-map<文件> 使用指定的符号表文件。
• -s或–system-log 在系统记录中记录错误。
• -v或–verbose 执行时显示详细的信息。
• -V或–version 显示版本信息。
• --help 显示帮助。
实例
显示可用模块
Export Linux export 命令用于设置或显示环境变量。
在 shell 中执行程序时,shell 会提供一组环境变量。export 可新增,修改或删除环境变量,供后续执行的程序使用。export 的效力仅限于该次登陆操作。
语法
export [-fnp][变量名称]=[变量设置值]
参数说明:
• -f 代表[变量名称]中为函数名称。
• -n 删除指定的变量。变量实际上并未删除,只是不会输出到后续指令的执行环境中。
• -p 列出所有的shell赋予程序的环境变量。
实例
列出当前所有的环境变量
declare -x HOME=“/root“
declare -x LANG=“zh_CN.UTF-8“
declare -x LANGUAGE=“zh_CN:zh“
declare -x LESSCLOSE=“/usr/bin/lesspipe %s %s“
declare -x LESSOPEN=“| /usr/bin/lesspipe %s“
declare -x LOGNAME=“root“
declare -x LS_COLORS=““
declare -x MAIL=“/var/mail/root“
declare -x OLDPWD
declare -x PATH=“/opt/toolchains/arm920t-eabi/bin:/opt/toolchains/arm920t-eabi/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games“
declare -x PWD=“/root“
declare -x SHELL=“/bin/bash“
declare -x SHLVL=“1“
declare -x SPEECHD_PORT=“6560“
declare -x SSH_CLIENT=“192.168.1.65 1674 22“
declare -x SSH_CONNECTION=“192.168.1.65 1674 192.168.1.3 22“
declare -x SSH_TTY=“/dev/pts/2“
declare -x TERM=“XTERM“
declare -x USER=“root“
declare -x XDG_SESSION_COOKIE=“93b5d3d03e032c0cf892a4474bebda9f-1273864738.954257-340206484“
定义环境变量
declare -x HOME=“/root“
declare -x LANG=“zh_CN.UTF-8“
declare -x LANGUAGE=“zh_CN:zh“
declare -x LESSCLOSE=“/usr/bin/lesspipe %s %s“
declare -x LESSOPEN=“| /usr/bin/lesspipe %s“
declare -x LOGNAME=“root“
declare -x LS_COLORS=““
declare -x MAIL=“/var/mail/root“
declare -x MYENV
declare -x OLDPWD
declare -x PATH=“/opt/toolchains/arm920t-eabi/bin:/opt/toolchains/arm920t-eabi/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games“
declare -x PWD=“/root“
declare -x SHELL=“/bin/bash“
declare -x SHLVL=“1“
declare -x SPEECHD_PORT=“6560“
declare -x SSH_CLIENT=“192.168.1.65 1674 22“
declare -x SSH_CONNECTION=“192.168.1.65 1674 192.168.1.3 22“
declare -x SSH_TTY=“/dev/pts/2“
declare -x TERM=“XTERM“
declare -x USER=“root“
declare -x XDG_SESSION_COOKIE=“93b5d3d03e032c0cf892a4474bebda9f-1273864738.954257-340206484“
定义环境变量赋值
declare -x HOME=“/root“
declare -x LANG=“zh_CN.UTF-8“
declare -x LANGUAGE=“zh_CN:zh“
declare -x LESSCLOSE=“/usr/bin/lesspipe %s %s“
declare -x LESSOPEN=“| /usr/bin/lesspipe %s“
declare -x LOGNAME=“root“
declare -x LS_COLORS=““
declare -x MAIL=“/var/mail/root“
declare -x MYENV=“7“
declare -x OLDPWD
declare -x PATH=“/opt/toolchains/arm920t-eabi/bin:/opt/toolchains/arm920t-eabi/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games“
declare -x PWD=“/root“
declare -x SHELL=“/bin/bash“
declare -x SHLVL=“1“
declare -x SPEECHD_PORT=“6560“
declare -x SSH_CLIENT=“192.168.1.65 1674 22“
declare -x SSH_CONNECTION=“192.168.1.65 1674 192.168.1.3 22“
declare -x SSH_TTY=“/dev/pts/2“
declare -x TERM=“XTERM“
declare -x USER=“root“
declare -x XDG_SESSION_COOKIE=“93b5d3d03e032c0cf892a4474bebda9f-1273864738.954257-340206484“
rpm Linux rpm 命令用于管理套件。
rpm(英文全拼:redhat package manager) 原本是 Red Hat Linux 发行版专门用来管理 Linux 各项套件的程序,由于它遵循 GPL 规则且功能强大方便,因而广受欢迎。逐渐受到其他发行版的采用。RPM 套件管理方式的出现,让 Linux 易于安装,升级,间接提升了 Linux 的适用度。
语法
rpm [-acdhilqRsv][-b<完成阶段><套间档>+][-e<套件挡>][-f<文件>+][-i<套件档>][-p<套件档>+][-U<套件档>][-vv][–addsign<套件档>+][–allfiles][–allmatches][–badreloc][–buildroot<根目录>][–changelog][–checksig<套件档>+][–clean][–dbpath<数据库目录>][–dump][–excludedocs][–excludepath<排除目录>][–force][–ftpproxy<主机名称或IP地址>][–ftpport<通信端口>][–help][–httpproxy<主机名称或IP地址>][–httpport<通信端口>][–ignorearch][–ignoreos][–ignoresize][–includedocs][–initdb][justdb][–nobulid][–nodeps][–nofiles][–nogpg][–nomd5][–nopgp][–noorder][–noscripts][–notriggers][–oldpackage][–percent][–pipe<执行指令>][–prefix<目的目录>][–provides][–queryformat<档头格式>][–querytags][–rcfile<配置档>][–rebulid<套件档>][–rebuliddb][–recompile<套件档>][–relocate<原目录>=<新目录>][–replacefiles][–replacepkgs][–requires][–resign<套件档>+][–rmsource][–rmsource<文件>][–root<根目录>][–scripts][–setperms][–setugids][–short-circuit][–sign][–target=<安装平台>+][–test][–timecheck<检查秒数>][–triggeredby<套件档>][–triggers][–verify][–version][–whatprovides<功能特性>][–whatrequires<功能特性>]
参数说明:
• -a 查询所有套件。
• -b<完成阶段><套件档>+或-t <完成阶段><套件档>+ 设置包装套件的完成阶段,并指定套件档的文件名称。
• -c 只列出组态配置文件,本参数需配合"-l"参数使用。
• -d 只列出文本文件,本参数需配合"-l"参数使用。
• -e<套件档>或–erase<套件档> 删除指定的套件。
• -f<文件>+ 查询拥有指定文件的套件。
• -h或–hash 套件安装时列出标记。
• -i 显示套件的相关信息。
• -i<套件档>或–install<套件档> 安装指定的套件档。
• -l 显示套件的文件列表。
• -p<套件档>+ 查询指定的RPM套件档。
• -q 使用询问模式,当遇到任何问题时,rpm指令会先询问用户。
• -R 显示套件的关联性信息。
• -s 显示文件状态,本参数需配合"-l"参数使用。
• -U<套件档>或–upgrade<套件档> 升级指定的套件档。
• -v 显示指令执行过程。
• -vv 详细显示指令执行过程,便于排错。
• -addsign<套件档>+ 在指定的套件里加上新的签名认证。
• --allfiles 安装所有文件。
• --allmatches 删除符合指定的套件所包含的文件。
• --badreloc 发生错误时,重新配置文件。
• --buildroot<根目录> 设置产生套件时,欲当作根目录的目录。
• --changelog 显示套件的更改记录。
• --checksig<套件档>+ 检验该套件的签名认证。
• --clean 完成套件的包装后,删除包装过程中所建立的目录。
• --dbpath<数据库目录> 设置欲存放RPM数据库的目录。
• --dump 显示每个文件的验证信息。本参数需配合"-l"参数使用。
• --excludedocs 安装套件时,不要安装文件。
• --excludepath<排除目录> 忽略在指定目录里的所有文件。
• --force 强行置换套件或文件。
• --ftpproxy<主机名称或IP地址> 指定FTP代理服务器。
• --ftpport<通信端口> 设置FTP服务器或代理服务器使用的通信端口。
• --help 在线帮助。
• --httpproxy<主机名称或IP地址> 指定HTTP代理服务器。
• --httpport<通信端口> 设置HTTP服务器或代理服务器使用的通信端口。
• --ignorearch 不验证套件档的结构正确性。
• --ignoreos 不验证套件档的结构正确性。
• --ignoresize 安装前不检查磁盘空间是否足够。
• --includedocs 安装套件时,一并安装文件。
• --initdb 确认有正确的数据库可以使用。
• --justdb 更新数据库,当不变动任何文件。
• --nobulid 不执行任何完成阶段。
• --nodeps 不验证套件档的相互关联性。
• --nofiles 不验证文件的属性。
• --nogpg 略过所有GPG的签名认证。
• --nomd5 不使用MD5编码演算确认文件的大小与正确性。
• --nopgp 略过所有PGP的签名认证。
• --noorder 不重新编排套件的安装顺序,以便满足其彼此间的关联性。
• --noscripts 不执行任何安装Script文件。
• --notriggers 不执行该套件包装内的任何Script文件。
• --oldpackage 升级成旧版本的套件。
• --percent 安装套件时显示完成度百分比。
• --pipe<执行指令> 建立管道,把输出结果转为该执行指令的输入数据。
• --prefix<目的目录> 若重新配置文件,就把文件放到指定的目录下。
• --provides 查询该套件所提供的兼容度。
• --queryformat<档头格式> 设置档头的表示方式。
• --querytags 列出可用于档头格式的标签。
• --rcfile<配置文件> 使用指定的配置文件。
• --rebulid<套件档> 安装原始代码套件,重新产生二进制文件的套件。
• --rebuliddb 以现有的数据库为主,重建一份数据库。
• --recompile<套件档> 此参数的效果和指定"–rebulid"参数类似,当不产生套件档。
• --relocate<原目录>=<新目录> 把本来会放到原目录下的文件改放到新目录。
• --replacefiles 强行置换文件。
• --replacepkgs 强行置换套件。
• --requires 查询该套件所需要的兼容度。
• --resing<套件档>+ 删除现有认证,重新产生签名认证。
• --rmsource 完成套件的包装后,删除原始代码。
• --rmsource<文件> 删除原始代码和指定的文件。
• --root<根目录> 设置欲当作根目录的目录。
• --scripts 列出安装套件的Script的变量。
• --setperms 设置文件的权限。
• --setugids 设置文件的拥有者和所属群组。
• --short-circuit 直接略过指定完成阶段的步骤。
• --sign 产生PGP或GPG的签名认证。
• --target=<安装平台>+ 设置产生的套件的安装平台。
• --test 仅作测试,并不真的安装套件。
• --timecheck<检查秒数> 设置检查时间的计时秒数。
• --triggeredby<套件档> 查询该套件的包装者。
• --triggers 展示套件档内的包装Script。
• --verify 此参数的效果和指定"-q"参数相同。
• --version 显示版本信息。
• --whatprovides<功能特性> 查询该套件对指定的功能特性所提供的兼容度。
• --whatrequires<功能特性> 查询该套件对指定的功能特性所需要的兼容度。
实例
安装软件
警告:dejagnu-1.4.2-10.noarch.rpm: V3 DSA 签名:NOKEY, key ID db42a60e
准备…
########################################### [100%]
显示软件安装信息
【第1次更新 教程、类似命令关联】
Insmod Linux insmod(英文全拼:install module)命令用于载入模块。
Linux有许多功能是通过模块的方式,在需要时才载入kernel。如此可使kernel较为精简,进而提高效率,以及保有较大的弹性。这类可载入的模块,通常是设备驱动程序。
语法
insmod [-fkmpsvxX][-o <模块名称>][模块文件][符号名称 = 符号值]
参数说明:
• -f 不检查目前kernel版本与模块编译时的kernel版本是否一致,强制将模块载入。
• -k 将模块设置为自动卸除。
• -m 输出模块的载入信息。
• -o<模块名称> 指定模块的名称,可使用模块文件的文件名。
• -p 测试模块是否能正确地载入kernel。
• -s 将所有信息记录在系统记录文件中。
• -v 执行时显示详细的信息。
• -x 不要汇出模块的外部符号。
• -X 汇出模块所有的外部符号,此为预设置。
实例
加载模块
//向内核加载模块
Set Linux set命令用于设置shell。
set指令能设置所使用shell的执行方式,可依照不同的需求来做设置。
语法
set [±abCdefhHklmnpPtuvx]
参数说明:
• -a 标示已修改的变量,以供输出至环境变量。
• -b 使被中止的后台程序立刻回报执行状态。
• -C 转向所产生的文件无法覆盖已存在的文件。
• -d Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行。使用-d参数可取消。
• -e 若指令传回值不等于0,则立即退出shell。
• -f 取消使用通配符。
• -h 自动记录函数的所在位置。
• -H Shell 可利用"!"加<指令编号>的方式来执行history中记录的指令。
• -k 指令所给的参数都会被视为此指令的环境变量。
• -l 记录for循环的变量名称。
• -m 使用监视模式。
• -n 只读取指令,而不实际执行。
• -p 启动优先顺序模式。
• -P 启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接。
• -t 执行完随后的指令,即退出shell。
• -u 当执行时使用到未定义过的变量,则显示错误信息。
• -v 显示shell所读取的输入值。
• -x 执行指令后,会先显示该指令及所下的参数。
• +<参数> 取消某个set曾启动的参数。
实例
显示环境变量
BASH=/bin/bash
BASH_ARGC=()
BASH_ARGV=()
BASH_LINENO=()
BASH_SOURCE=()
BASH_VERSINFO=([0]=“3” [1]=“00” [2]=“15” [3]=“1” [4]=“release” [5]=“i386-redhat-linux-gnu”)
BASH_VERSION=‘3.00.15(1)-release’
COLORS=/etc/DIR_COLORS.xterm
COLUMNS=99
DIRSTACK=()
EUID=0
GROUPS=()
G_BROKEN_FILENAMES=1
HISTFILE=/root/.bash_history
HISTFILESIZE=1000
HISTSIZE=1000
HOME=/root
HOSTNAME=hnlinux
HOSTTYPE=i386
IFS=$’ ’
INPUTRC=/etc/inputrc
KDEDIR=/usr
LANG=zh_CN.GB2312
LESSOPEN=’|/usr/bin/lesspipe.sh %s’
LINES=34
L
MAIL=/var/spool/mail/root
MAILCHECK=60
OLDPWD=/home/uptech
OPTERR=1
OPTIND=1
OSTYPE=linux-gnu
PATH=/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/crosstools/gcc-3.4.6-glibc-2.3.6/bin
PIPESTATUS=([0]=“2”)
PPID=26005
PROMPT_COMMAND='echo -ne "
Passwd Linux passwd命令用来更改使用者的密码
语法
passwd [-k] [-l] [-u [-f]] [-d] [-S] [username]
必要参数:
• -d 删除密码
• -f 强迫用户下次登录时必须修改口令
• -w 口令要到期提前警告的天数
• -k 更新只能发送在过期之后
• -l 停止账号使用
• -S 显示密码信息
• -u 启用已被停止的账户
• -x 指定口令最长存活期
• -g 修改群组密码
• 指定口令最短存活期
• -i 口令过期后多少天停用账户
选择参数:
• --help 显示帮助信息
• --version 显示版本信息
实例
修改用户密码
Enter new UNIX password: //输入新密码,输入的密码无回显
Retype new UNIX password: //确认密码
passwd: password updated successfully
显示账号密码信息
runoob P 05/13/2010 0 99999 7 -1
删除用户密码
passwd: password expiry information changed.
rdate Linux rdate命令用于显示其他主机的日期与时间。
执行rdate指令,向其他主机询问系统时间并显示出来。
语法
rdate [-ps][主机名称或IP地址…]
参数:
• -p 显示远端主机的日期与时间。
• -s 把从远端主机收到的日期和时间,回存到本地主机的系统时间。
• -u 传输协议使用UDP协议
• -l 使用syslog显示错误信息
• -t<时间> 设置超时时间
Rmmod Linux rmmod(英文全拼:remove module)命令用于删除模块。
执行 rmmod 指令,可删除不需要的模块。Linux 操作系统的核心具有模块化的特性,应此在编译核心时,务须把全部的功能都放如核心。你可以将这些功能编译成一个个单独的模块,待有需要时再分别载入它们。
语法
rmmod [-as][模块名称…]
参数:
• -a 删除所有目前不需要的模块。
• -s 把信息输出至syslog常驻服务,而非终端机界面。
实例
显示已安装的模块
Module Size Used by
cramfs 39042 1
nfsd 238935 11
lockd 64849 1 nfsd
nfs_acl 2245 1 nfsd
auth_rpcgss 33735 1 nfsd
sunrpc 193181 10 nfsd,lockd,nfs_acl,auth_rpcgss
exportfs 3437 1 nfsd
xt_TCPMSS 2931 0
xt_tcpmss 1197 0
xt_tcpudp 2011 0
iptable_mangle 2771 0
ip_tables 9991 1 iptable_mangle
x_tables 14299 4
……省略部分结果
pppoe 8943 0
pppox 2074 1 pppoe
binfmt_misc 6587 1
snd_ens1371 18814 0
gameport 9089 1 snd_ens1371
snd_ac97_codec 100646 1 snd_ens1371
ac97_bus 1002 1 snd_ac97_codec
snd_pcm_oss 35308 0
卸载模块
Checking ppoe for persistent data
安装模块
~# tail -b 30 1.log //显示文件信息
Time Linux time命令的用途,在于量测特定指令执行时所需消耗的时间及系统资源等资讯。
例如 CPU 时间、记忆体、输入输出等等。需要特别注意的是,部分资讯在 Linux 上显示不出来。这是因为在 Linux 上部分资源的分配函式与 time 指令所预设的方式并不相同,以致于 time 指令无法取得这些资料。
语法
time [options] COMMAND [arguments]
参数:
• -o 或 --output=FILE:设定结果输出档。这个选项会将 time 的输出写入 所指定的档案中。如果档案已经存在,系统将覆写其内容。
• -a 或 --append:配合 -o 使用,会将结果写到档案的末端,而不会覆盖掉原来的内容。
• -f FORMAT 或 --format=FORMAT:以 FORMAT 字串设定显示方式。当这个选项没有被设定的时候,会用系统预设的格式。不过你可以用环境变数 time 来设定这个格式,如此一来就不必每次登入系统都要设定一次。
time 指令可以显示的资源有四大项,分别是:
• Time resources
• Memory resources
• IO resources
• Command info
详细的内容如下:
1、Time Resources
E 执行指令所花费的时间,格式是:[hour]:minute:second。请注意这个数字并不代表实际的 CPU 时间。
e 执行指令所花费的时间,单位是秒。请注意这个数字并不代表实际的 CPU 时间。
S 指令执行时在核心模式(kernel mode)所花费的时间,单位是秒。
U 指令执行时在使用者模式(user mode)所花费的时间,单位是秒。
P 执行指令时 CPU 的占用比例。其实这个数字就是核心模式加上使用者模式的 CPU 时间除以总时间。
2、Memory Resources
M 执行时所占用的实体记忆体的最大值。单位是 KB
t 执行时所占用的实体记忆体的平均值,单位是 KB
K 执行程序所占用的记忆体总量(stack+data+text)的平均大小,单位是 KB
D 执行程序的自有资料区(unshared data area)的平均大小,单位是 KB
p 执行程序的自有堆叠(unshared stack)的平均大小,单位是 KB
X 执行程序间共享内容(shared text)的平均值,单位是 KB
Z 系统记忆体页的大小,单位是 byte。对同一个系统来说这是个常数
3、IO Resources
F 此程序的主要记忆体页错误发生次数。所谓的主要记忆体页错误是指某一记忆体页已经置换到置换档(swap file)中,而且已经分配给其他程序。此时该页的内容必须从置换档里再读出来。
R 此程序的次要记忆体页错误发生次数。所谓的次要记忆体页错误是指某一记忆体页虽然已经置换到置换档中,但尚未分配给其他程序。此时该页的内容并未被破坏,不必从置换档里读出来
W 此程序被交换到置换档的次数
c 此程序被强迫中断(像是分配到的 CPU 时间耗尽)的次数
w 此程序自愿中断(像是在等待某一个 I/O 执行完毕,像是磁碟读取等等)的次数
I 此程序所输入的档案数
O 此程序所输出的档案数
r 此程序所收到的 Socket Message
s 此程序所送出的 Socket Message
k 此程序所收到的信号 ( Signal )数量
4、Command Info
C 执行时的参数以及指令名称
x 指令的结束代码 ( Exit Status )
-p or --portability:这个选项会自动把显示格式设定成为:
real %e user %Usys %S:这么做的目的是为了与 POSIX 规格相容。
-v or --verbose:这个选项会把所有程序中用到的资源通通列出来,不但如一般英文语句,还有说明。对不想花时间去熟习格式设定或是刚刚开始接触这个指令的人相当有用。
实例
在以上实例中,执行命令"time date"(见第1行)。
系统先执行命令"date",第2行为命令"date"的执行结果。
第3-6行为执行命令"date"的时间统计结果,其中第4行"real"为实际时间,第5行"user"为用户CPU时间,第6行"sys"为系统CPU时间。
以上三种时间的显示格式均为MMmNN[.FFF]s。
利用下面的指令
time -v ps -aux
我们可以获得执行 ps -aux 的结果和所花费的系统资源。如下面所列的资料:
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.4 1096 472 ? S Apr19 0:04 init
root 2 0.0 0.0 0 0 ? SW Apr19 0:00 [kflushd]
root 3 0.0 0.0 0 0 ? SW Apr19 0:00 [kpiod]
…
root 24269 0.0 1.0 2692 996 pts/3 R 12:16 0:00 ps -aux
Command being timed: “ps -aux”
User time (seconds): 0.05
System time (seconds): 0.06
Percent of CPU this job got: 68%
Elapsed (wall clock) time (h:mm:ss or m:ss): 0:00.16
Average shared text size (kbytes): 0
Average unshared data size (kbytes): 0
Average stack size (kbytes): 0
Average total size (kbytes): 0
Maximum resident set size (kbytes): 0
Average resident set size (kbytes): 0
Major (requiring I/O) page faults: 238
Minor (reclaiming a frame) page faults: 46
Voluntary context switches: 0
Involuntary context switches: 0
Swaps: 0
File system inputs: 0
File system outputs: 0
Socket messages sent: 0
Socket messages received: 0
Signals delivered: 0
Page size (bytes): 4096
Exit status: 0
Setup Linux setup命令设置公用程序,是一个启动图形设置系统的命令
setup 命令:用来配置X,打印设置,时区设置,系统服务,网络配置,配置,防火墙配置,验证配置,鼠标配置。
语法
setup
setup是一个设置公用程序,提供图形界面的操作方式。在setup中可设置7类的选项:
• 1.登陆认证方式
• 2.键盘组态设置
• 3.鼠标组态设置
• 4.开机时所要启动的系统服务
• 5.声卡组态设置
• 6.时区设置
• 7.X Windows组态设置
Gpasswd Linux gpasswd 是 Linux 下工作组文件 /etc/group 和 /etc/gshadow 管理工具,用于将一个用户添加到组或者从组中删除。
语法
gpasswd [可选项] 组名
可选项参数:
• -a:添加用户到组;
• -d:从组删除用户;
• -A:指定管理员;
• -M:指定组成员和-A的用途差不多;
• -r:删除密码;
• -R:限制用户登入组,只有组中的成员才可以用newgrp加入该组。
实例
如系统有个 peter 账户,该账户本身不是 groupname 群组的成员,使用 newgrp 需要输入密码即可。
gpasswd groupname
让使用者暂时加入成为该组成员,之后 peter 建立的文件 group 也会是 groupname。所以该方式可以暂时让 peter 建立文件时使用其他的组,而不是 peter 本身所在的组。
所以使用 gpasswd groupname 设定密码,就是让知道该群组密码的人可以暂时切换具备 groupname 群组功能的。
gpasswd -A peter users
这样 peter 就是 users 群组的管理员,就可以执行下面的操作:
gpasswd -a mary users
gpasswd -a allen users
注意:添加用户到某一个组 可以使用 usermod -G group_name user_name 这个命令可以添加一个用户到指定的组,但是以前添加的组就会清空掉。
所以想要添加一个用户到一个组,同时保留以前添加的组时,请使用 gpasswd 这个命令来添加操作用户:
gpasswd -a user_name group_name
备份压缩
Ar Linux ar命令用于建立或修改备存文件,或是从备存文件中抽取文件
ar可让您集合许多文件,成为单一的备存文件。在备存文件中,所有成员文件皆保有原来的属性与权限。
语法
ar[-dmpqrtx][cfosSuvV][a<成员文件>][b<成员文件>][i<成员文件>][备存文件][成员文件]
参数:
必要参数:
• -d 删除备存文件中的成员文件。
• -m 变更成员文件在备存文件中的次序。
• -p 显示备存文件中的成员文件内容。
• -q 将文件附加在备存文件末端。
• -r 将文件插入备存文件中。
• -t 显示备存文件中所包含的文件。
• -x 自备存文件中取出成员文件。
选项参数:
• a<成员文件> 将文件插入备存文件中指定的成员文件之后。
• b<成员文件> 将文件插入备存文件中指定的成员文件之前。
• c 建立备存文件。
• f 为避免过长的文件名不兼容于其他系统的ar指令指令,因此可利用此参数,截掉要放入备存文件中过长的成员文件名称。
• i<成员文件> 将文件插入备存文件中指定的成员文件之前。
• o 保留备存文件中文件的日期。
• s 若备存文件中包含了对象模式,可利用此参数建立备存文件的符号表。
• S 不产生符号表。
• u 只将日期较新文件插入备存文件中。
• v 程序执行时显示详细的信息。
• V 显示版本信息。
实例
打包文件
[[email protected] ~]# ls //显示当前目录文件
a.c b.c d.c install.log qte
anaconda-ks.cfg c.c Desktop
[[email protected] ~]# ar rv one.bak a.c b.c //打包 a.c b.c文件
ar: 正在创建 one.bak
a - a.c
a - b.c
[[email protected] ~]#
打包多个文件
[[email protected] ~]# ar rv two.bak *.c //打包以.c结尾的文件
ar: 正在创建 two.bak
a - a.c
a - b.c
a - c.c
a - d.c
[[email protected] ~]#
显示打包文件的内容
[[email protected] ~]# ar t two.bak
a.c
b.c
c.c
d.c
[[email protected] ~]#
删除打包文件的成员文件
[[email protected] ~]# ar d two.bak a.c b.c c.c
[[email protected] ~]# ar t two.bak
d.c
bunzip2 Linux bunzip2命令是.bz2文件的解压缩程序。
bunzip2可解压缩.bz2格式的压缩文件。bunzip2实际上是bzip2的符号连接,执行bunzip2与bzip2 -d的效果相同。
语法:bunzip2 [-fkLsvV][.bz2压缩文件]
参数:
• -f或–force 解压缩时,若输出的文件与现有文件同名时,预设不会覆盖现有的文件。若要覆盖,请使用此参数。
• -k或–keep 在解压缩后,预设会删除原来的压缩文件。若要保留压缩文件,请使用此参数。
• -s或–small 降低程序执行时,内存的使用量。
• -v或–verbose 解压缩文件时,显示详细的信息。
• -L,–license,-V或–version 显示版本信息。
实例
解压.bz2文件
bzip2 Linux bzip2命令是.bz2文件的压缩程序。
bzip2采用新的压缩演算法,压缩效果比传统的LZ77/LZ78压缩演算法来得好。若没有加上任何参数,bzip2压缩完文件后会产生.bz2的压缩文件,并删除原始的文件。
语法
bzip2 [-cdfhkLstvVz][–repetitive-best][–repetitive-fast][- 压缩等级][要压缩的文件]
参数:
• -c或–stdout 将压缩与解压缩的结果送到标准输出。
• -d或–decompress 执行解压缩。
• -f或–force bzip2在压缩或解压缩时,若输出文件与现有文件同名,预设不会覆盖现有文件。若要覆盖,请使用此参数。
• -h或–help 显示帮助。
• -k或–keep bzip2在压缩或解压缩后,会删除原始的文件。若要保留原始文件,请使用此参数。
• -s或–small 降低程序执行时内存的使用量。
• -t或–test 测试.bz2压缩文件的完整性。
• -v或–verbose 压缩或解压缩文件时,显示详细的信息。
• -z或–compress 强制执行压缩。
• -L,–license,
• -V或–version 显示版本信息。
• --repetitive-best 若文件中有重复出现的资料时,可利用此参数提高压缩效果。
• --repetitive-fast 若文件中有重复出现的资料时,可利用此参数加快执行速度。
• -压缩等级 压缩时的区块大小。
实例
解压.bz2文件
[[email protected] ~]# bzip2 -v temp.bz2 //解压文件显示详细处理信息
压缩文件
[[email protected] ~]# bzip2 -c a.c b.c c.c
检查文件完整性
[[email protected] ~]# bzip2 -t temp.bz2
bzip2recover Linux bzip2recover命令用来修复损坏的.bz2文件。
bzip2是以区块的方式来压缩文件,每个区块视为独立的单位。因此,当某一区块损坏时,便可利用bzip2recover,试着将文件中的区块隔开来,以便解压缩正常的区块。通常只适用在压缩文件很大的情况。
语法
bzip2recover [.bz2 压缩文件]
实例
修复.bz2文件
Gunzip Linux gunzip命令用于解压文件
gunzip是个使用广泛的解压缩程序,它用于解开被gzip压缩过的文件,这些压缩文件预设最后的扩展名为".gz"。事实上gunzip就是gzip的硬连接,因此不论是压缩或解压缩,都可通过gzip指令单独完成。
语法
参数:
gunzip [-acfhlLnNqrtvV][-s <压缩字尾字符串>][文件…] 或 gunzip [-acfhlLnNqrtvV][-s <压缩字尾字符串>][目录]
• -a或–ascii 使用ASCII文字模式。
• -c或–stdout或–to-stdout 把解压后的文件输出到标准输出设备。
• -f或-force 强行解开压缩文件,不理会文件名称或硬连接是否存在以及该文件是否为符号连接。
• -h或–help 在线帮助。
• -l或–list 列出压缩文件的相关信息。
• -L或–license 显示版本与版权信息。
• -n或–no-name 解压缩时,若压缩文件内含有远来的文件名称及时间戳记,则将其忽略不予处理。
• -N或–name 解压缩时,若压缩文件内含有原来的文件名称及时间戳记,则将其回存到解开的文件上。
• -q或–quiet 不显示警告信息。
• -r或–recursive 递归处理,将指定目录下的所有文件及子目录一并处理。
• -S<压缩字尾字符串>或–suffix<压缩字尾字符串> 更改压缩字尾字符串。
• -t或–test 测试压缩文件是否正确无误。
• -v或–verbose 显示指令执行过程。
• -V或–version 显示版本信息。
实例
解压文件
# gunzip ab.gz
Unarj Linux unarj命令用于解压缩.arj文件
unarj为.arj压缩文件的压缩程序。
语法
unarj [eltx][.arj压缩文件]
参数:
• e 解压缩.arj文件。
• l 显示压缩文件内所包含的文件。
• t 检查压缩文件是否正确。
• x 解压缩时保留原有的路径。
实例
解压.arj文件
Cpio Linux cpio命令用于备份文件。
cpio 是用来建立,还原备份档的工具程序,它可以加入,解开 cpio 或 tar 备份档内的文件。
语法
cpio [-0aABckLovV][-C <输入/输出大小>][-F <备份档>][-H <备份格式>][-O <备份档>][–block-size=<区块大小>][–force-local][–help][–quiet][–version] 或 cpio [-bBcdfikmnrsStuvV][-C <输入/输出大小>][-E <范本文件>][-F <备份档>][-H <备份格式>][-I <备份档>][-M <回传信息>][-R <拥有者><:/.><所属群组>][–block-size=<区块大小>][–force-local][–help][–no-absolute-filenames][–no-preserve-owner][–only-verify-crc][–quiet][–sparse][–version][范本样式…] 或 cpio [-0adkiLmpuvV][-R <拥有者><:/.><所属群组>][–help][–no-preserve-owner][–quiet][–sparse][–version][目的目]
参数:
• -0或–null 接受新增列控制字符,通常配合find指令的"-print0"参数使用。
• -a或–reset-access-time 重新设置文件的存取时间。
• -A或–append 附加到已存在的备份档中,且这个备份档必须存放在磁盘上,而不能放置于磁带机里。
• -b或–swap 此参数的效果和同时指定"-sS"参数相同。
• -B 将输入/输出的区块大小改成5210 Bytes。
• -c 使用旧ASCII备份格式。
• -C<区块大小>或–io-size=<区块大小> 设置输入/输出的区块大小,单位是Byte。
• -d或–make-directories 如有需要cpio会自行建立目录。
• -E<范本文件>或–pattern-file=<范本文件> 指定范本文件,其内含有一个或多个范本样式,让cpio解开符合范本条件的文件,格式为每列一个范本样式。
• -f或–nonmatching 让cpio解开所有不符合范本条件的文件。
• -F<备份档>或–file=<备份档> 指定备份档的名称,用来取代标准输入或输出,也能借此通过网络使用另一台主机的保存设备存取备份档。
• -H<备份格式> 指定备份时欲使用的文件格式。
• -i或–extract 执行copy-in模式,还原备份档。
• -l<备份档> 指定备份档的名称,用来取代标准输入,也能借此通过网络使用另一台主机的保存设备读取备份档。
• -k 此参数将忽略不予处理,仅负责解决cpio不同版本间的兼容性问题。
• -l或–link 以硬连接的方式取代复制文件,可在copy-pass模式下运用。
• -L或–dereference 不建立符号连接,直接复制该连接所指向的原始文件。
• -m或preserve-modification-time 不去更换文件的更改时间。
• -M<回传信息>或–message=<回传信息> 设置更换保存媒体的信息。
• -n或–numeric-uid-gid 使用"-tv"参数列出备份档的内容时,若再加上参数"-n",则会以用户识别码和群组识别码替代拥有者和群组名称列出文件清单。
• -o或–create 执行copy-out模式,建立备份档。
• -O<备份档> 指定备份档的名称,用来取代标准输出,也能借此通过网络 使用另一台主机的保存设备存放备份档。
• -p或–pass-through 执行copy-pass模式,略过备份步骤,直接将文件复制到目的目录。
• -r或–rename 当有文件名称需要更动时,采用互动模式。
• -R<拥有者><:/.><所属群组>或
• ----owner<拥有者><:/.><所属群组> 在copy-in模式还原备份档,或copy-pass模式复制文件时,可指定这些备份,复制的文件的拥有者与所属群组。
• -s或–swap-bytes 交换每对字节的内容。
• -S或–swap-halfwords 交换每半个字节的内容。
• -t或–list 将输入的内容呈现出来。
• -u或–unconditional 置换所有文件,不论日期时间的新旧与否,皆不予询问而直接覆盖。
• -v或–verbose 详细显示指令的执行过程。
• -V或–dot 执行指令时,在每个文件的执行程序前面加上"."号
• --block-size=<区块大小> 设置输入/输出的区块大小,假如设置数值为5,则区块大小为2500,若设置成10,则区块大小为5120,依次类推。
• --force-local 强制将备份档存放在本地主机。
• --help 在线帮助。
• --no-absolute-filenames 使用相对路径建立文件名称。
• --no-preserve-owner 不保留文件的拥有者,谁解开了备份档,那些文件就归谁所有。
• -only-verify-crc 当备份档采用CRC备份格式时,可使用这项参数检查备份档内的每个文件是否正确无误。
• --quiet 不显示复制了多少区块。
• --sparse 倘若一个文件内含大量的连续0字节,则将此文件存成稀疏文件。
• --version 显示版本信息。
实例
制作备份文件
[[email protected] var]# ll //显示当前目录下的文件
总用量 164
drwxr-xr-x 2 root root 4096 2008-03-30 account
drwxr-xr-x 9 root root 4096 2008-03-30 cache
drwxr-xr-x 3 netdump netdump 4096 2008-03-30 crash
drwxr-xr-x 3 root root 4096 2008-03-30 db
drwxr-xr-x 3 root root 4096 2008-03-30 empty
drwxr-xr-x 3 root root 4096 2008-03-30 ftp
drwxrwx–T 2 root gdm 4096 4月 9 20:17 gdm
drwxr-xr-x 25 root root 4096 2008-03-30 lib
drwxr-xr-x 2 root root 4096 2004-08-13 local
drwxrwxr-x 6 root lock 4096 5月 8 15:25 lock
drwxr-xr-x 14 root root 4096 5月 8 15:14 log
lrwxrwxrwx 1 root root 10 2008-03-30 mail -> spool/mail
drwxr-xr-x 2 root root 4096 2004-08-13 nis
drwxr-xr-x 2 root root 4096 2004-08-13 opt
drwxr-xr-x 2 root root 4096 2004-08-13 preserve
drwxr-xr-x 16 root root 4096 5月 8 15:14 run
drwxr-xr-x 16 root root 4096 2008-03-30 spool
drwxrwxrwt 3 root root 4096 1月 13 18:53 tmp
drwx------ 2 root root 4096 2004-07-08 tux
drwxr-xr-x 8 root root 4096 1月 19 19:39 www
drwxr-xr-x 3 root root 4096 2008-03-30 yp
[[email protected] var]# ls | cpio -o >123.cpio //制作备份文件
25 blocks
[[email protected] var]# ll //显示当前目录下的文件
总用量 172
-rw-r–r-- 1 root root 1024 5月 24 13:06 123.cpio
drwxr-xr-x 2 root root 4096 2008-03-30 account
drwxr-xr-x 9 root root 4096 2008-03-30 cache
drwxr-xr-x 3 netdump netdump 4096 2008-03-30 crash
drwxr-xr-x 3 root root 4096 2008-03-30 db
drwxr-xr-x 3 root root 4096 2008-03-30 empty
drwxr-xr-x 3 root root 4096 2008-03-30 ftp
drwxrwx–T 2 root gdm 4096 4月 9 20:17 gdm
drwxr-xr-x 25 root root 4096 2008-03-30 lib
drwxr-xr-x 2 root root 4096 2004-08-13 local
drwxrwxr-x 6 root lock 4096 5月 8 15:25 lock
drwxr-xr-x 14 root root 4096 5月 8 15:14 log
lrwxrwxrwx 1 root root 10 2008-03-30 mail -> spool/mail
drwxr-xr-x 2 root root 4096 2004-08-13 nis
drwxr-xr-x 2 root root 4096 2004-08-13 opt
drwxr-xr-x 2 root root 4096 2004-08-13 preserve
drwxr-xr-x 16 root root 4096 5月 8 15:14 run
drwxr-xr-x 16 root root 4096 2008-03-30 spool
drwxrwxrwt 3 root root 4096 1月 13 18:53 tmp
drwx------ 2 root root 4096 2004-07-08 tux
drwxr-xr-x 8 root root 4096 1月 19 19:39 www
drwxr-xr-x 3 root root 4096 2008-03-30 yp
[[email protected] var]#
解压备份文件
[[email protected] var]# ls | cpio -i -l 123.cpio
解压缩备份文件,并列出详细信息
[[email protected] var]# cpio -t -I 123.cpio
123.cpio
a.c
b.c
c.c
……省略部分结果
强制解压缩
[[email protected] var]# cpio -i -u -I 123.cpio
解压缩时进行反向匹配,指定不解压的文件
[[email protected] var]# cpio -i -I 123.cpio -f *.c
//不解压.c结尾的文件
向指定的.cpio文件添加文件
[[email protected] var]# ls
123.cpio crash ftp local mail preserve tmp yp
account db gdm lock nis run tux
cache empty lib log opt spool www
[[email protected] var]# cpio -o -O 123.cpio -A
db //用户输入 按下Ctrl+D结束输入
1 block
[[email protected] var]#
从标准输入备份文件
[[email protected] test]# ls
a. a.c b.c c.c d.c f.c
[[email protected] test]# cpio -o >123.cpio
a.c //用户输入
b.c
c.c //按下Ctrl+D完成输入
3 block
[[email protected] test]#
复制文件
[[email protected] test]# cpio -p /root
a.c //用户输入
b.c
c.c //按下Ctrl+D完成输入
3 block
Dump Linux dump命令用于备份文件系统。
dump为备份工具程序,可将目录或整个文件系统备份至指定的设备,或备份成一个大文件。
语法
dump [-cnu][-0123456789][-b <区块大小>][-B <区块数目>][-d <密度>][-f <设备名称>][-h <层级>][-s <磁带长度>][-T <日期>][目录或文件系统] 或 dump [-wW]
参数:
• -0123456789 备份的层级。
• -b<区块大小> 指定区块的大小,单位为KB。
• -B<区块数目> 指定备份卷册的区块数目。
• -c 修改备份磁带预设的密度与容量。
• -d<密度> 设置磁带的密度。单位为BPI。
• -f<设备名称> 指定备份设备。
• -h<层级> 当备份层级等于或大于指定的层级时,将不备份用户标示为"nodump"的文件。
• -n 当备份工作需要管理员介入时,向所有"operator"群组中的使用者发出通知。
• -s<磁带长度> 备份磁带的长度,单位为英尺。
• -T<日期> 指定开始备份的时间与日期。
• -u 备份完毕后,在/etc/dumpdates中记录备份的文件系统,层级,日期与时间等。
• -w 与-W类似,但仅显示需要备份的文件。
• -W 显示需要备份的文件及其最后一次备份的层级,时间与日期。
实例
备份文件到磁带
其中"-0"参数指定的是备份等级"-u"要求备份完毕之后将相应的信息存储到文件 /etc/dumpdates 留作记录
Uuencode
Gzexe Linux gzexe命令用于压缩执行文件。
gzexe是用来压缩执行文件的程序。当您去执行被压缩过的执行文件时,该文件会自动解压然后继续执行,和使用一般的执行文件相同。
语法
gzexe [-d][执行文件…]
参数:
• -d 解开压缩文件。
实例
压缩可执行文件
Gzip Linux gzip命令用于压缩文件。
gzip是个使用广泛的压缩程序,文件经它压缩过后,其名称后面会多出".gz"的扩展名。
语法
gzip [-acdfhlLnNqrtvV][-S <压缩字尾字符串>][-<压缩效率>][–best/fast][文件…] 或 gzip [-acdfhlLnNqrtvV][-S <压缩字尾字符串>][-<压缩效率>][–best/fast][目录]
参数:
• -a或–ascii 使用ASCII文字模式。
• -c或–stdout或–to-stdout 把压缩后的文件输出到标准输出设备,不去更动原始文件。
• -d或–decompress或----uncompress 解开压缩文件。
• -f或–force 强行压缩文件。不理会文件名称或硬连接是否存在以及该文件是否为符号连接。
• -h或–help 在线帮助。
• -l或–list 列出压缩文件的相关信息。
• -L或–license 显示版本与版权信息。
• -n或–no-name 压缩文件时,不保存原来的文件名称及时间戳记。
• -N或–name 压缩文件时,保存原来的文件名称及时间戳记。
• -q或–quiet 不显示警告信息。
• -r或–recursive 递归处理,将指定目录下的所有文件及子目录一并处理。
• -S<压缩字尾字符串>或----suffix<压缩字尾字符串> 更改压缩字尾字符串。
• -t或–test 测试压缩文件是否正确无误。
• -v或–verbose 显示指令执行过程。
• -V或–version 显示版本信息。
• -<压缩效率> 压缩效率是一个介于1-9的数值,预设值为"6",指定愈大的数值,压缩效率就会愈高。
• --best 此参数的效果和指定"-9"参数相同。
• --fast 此参数的效果和指定"-1"参数相同。
实例
压缩文件
[[email protected] a]# ls //显示当前目录文件
a.c b.h d.cpp
[[email protected] a]# gzip * //压缩目录下的所有文件
[[email protected] a]# ls //显示当前目录文件
a.c.gz b.h.gz d.cpp.gz
[[email protected] a]#
接范例1, 列出详细的信息
[[email protected] a]# gzip -dv * //解压文件,并列出详细信息
a.c.gz: 0.0% – replaced with a.c
b.h.gz: 0.0% – replaced with b.h
d.cpp.gz: 0.0% – replaced with d.cpp
[[email protected] a]#
接范例1,显示压缩文件的信息
[[email protected] a]# gzip -l *
compressed uncompressed ratio uncompressed_name
24 0 0.0% a.c
24 0 0.0% b.h
26 0 0.0% d.cpp
Lha Linux lha命令用于压缩或解压缩文件。
lha是从lharc演变而来的压缩程序,文件经它压缩后,会另外产生具有".lzh"扩展名的压缩文件。
语法
lha [-acdfglmnpqtuvx][-a <0/1/2>/u0/1/2>][-d][-
参数:
• -a或a 压缩文件,并加入到压缩文件内。
• -a<0/1/2>/u0/1/2> 压缩文件时,采用不同的文件头。
• -c或c 压缩文件,重新建构新的压缩文件后,再将其加入。
• -d或d 从压缩文件内删除指定的文件。
• -d或d 压缩文件,然后将其加入,重新建构,更新压缩文件或,删除原始文件,也就是把文件移到压缩文件中。
• -e或e 解开压缩文件。
• -f或f 强制执行lha命令,在解压时会直接覆盖已有的文件而不加以询问。
• -g或g 使用通用的压缩格式,便于解决兼容性的问题。
• -
• -l或l 列出压缩文件的相关信息。
• -m或m 此参数的效果和同时指定"-ad"参数相同。
• -n或n 不执行指令,仅列出实际执行会进行的动作。
• -o或o 采用lharc兼容格式,将压缩后的文件加入,更新压缩文件。
• -p或p 从压缩文件内输出到标准输出设备。
• -q或q 不显示指令执行过程。
• -t或t 检查备份文件内的每个文件是否正确无误。
• -u或u 更换较新的文件到压缩文件内。
• -u0/1/2>或u0/1/2> 在文件压缩时采用不同的文件头,然后更新到压缩文件内。
• -v或v 详细列出压缩文件的相关信息。
• -
• -x或x 解开压缩文件。
• -z或z 不压缩文件,直接把它加入,更新压缩文件。
实例
缩文件
压缩目录
解压文件到当前目录
Restore Linux restore命令用来还原由dump操作所备份下来的文件或整个文件系统(一个分区)。
restore 指令所进行的操作和dump指令相反,dump操作可用来备份文件,而restore操作则是写回这些已备份的文件。
语法
restore [-cCvy][-b <区块大小>][-D <文件系统>][-f <备份文件>][-s <文件编号>] 或 restore [-chimvy][-b <区块大小>][-f <备份文件>][-s <文件编号>] 或 restore [-crvy][-b <区块大小>][-f <备份文件>][-s <文件编号>] 或 restore [-cRvy][-b <区块大小>][-D <文件系统>][-f <备份文件>][-s <文件编号>] 或 restore [chtvy][-b <区块大小>][-D <文件系统>][-f <备份文件>][-s <文件编号>][文件…] 或 restore [-chmvxy][-b <区块大小>][-D <文件系统>][-f <备份文件>][-s <文件编号>][文件…]
参数:
• -b<区块大小> 设置区块大小,单位是Byte。
• -c 不检查dump操作的备份格式,仅准许读取使用旧格式的备份文件。
• -C 使用对比模式,将备份的文件与现行的文件相互对比。
• -D<文件系统> 允许用户指定文件系统的名称。
• -f<备份文件> 从指定的文件中读取备份数据,进行还原操作。
• -h 仅解出目录而不包括与该目录相关的所有文件。
• -i 使用互动模式,在进行还原操作时,restore指令将依序询问用户。
• -m 解开符合指定的inode编号的文件或目录而非采用文件名称指定。
• -r 进行还原操作。
• -R 全面还原文件系统时,检查应从何处开始进行。
• -s<文件编号> 当备份数据超过一卷磁带时,您可以指定备份文件的编号。
• -t 指定文件名称,若该文件已存在备份文件中,则列出它们的名称。
• -v 显示指令执行过程。
• -x 设置文件名称,且从指定的存储媒体里读入它们,若该文件已存在在备份文件中,则将其还原到文件系统内。
• -y 不询问任何问题,一律以同意回答并继续执行指令。
Tar Linux tar(英文全拼:tape archive )命令用于备份文件 压缩文件。
tar 是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。
语法
tar [-ABcdgGhiklmMoOpPrRsStuUvwWxzZ][-b <区块数目>][-C <目的目录>][-f <备份文件>][-F