Linux必须学会的60个命令

Linux系统信息存放在文件里,文件与普通的公务文件相似。每一个文件都有本身的名字、内容、存放地址及其它一些管理信息,如文件的用户、文件的大小等。文件能够是一封信、一个通信录,或者是程序的源语句、程序的数据,甚至能够包括可执行的程序和其它非正文内容。Linux文件系统具备良好的结构,系统提供了不少文件处理程序。这里主要介绍经常使用的文件处理命令。
  file 1.做用file经过探测文件内容判断文件类型,使用权限是全部用户。
  2.格式file [options]文件名3.[options]主要参数-v:在标准输出后显示版本信息,而且退出。
  -z:探测压缩过的文件类型。
  -L:容许符合链接。
  -f name:从文件namefile中读取要分析的文件名列表。
  4.简单说明使用file命令能够知道某个文件到底是二进制(ELF格式)的可执行文件,仍是Shell Script文件,或者是其它的什么格式。file能识别的文件类型有目录、Shell脚本、英文文本、二进制可执行文件、C语言源文件、文本文件、DOS的可执行文件。
  5.应用实例若是咱们看到一个没有后缀的文件grap,可使用下面命令:
  $ file grap grap:English text 此时系统显示这是一个英文文本文件。须要说明的是,file命令不能探测包括图形、音频、视频等多媒体文件类型。
  mkdir 1.做用mkdir命令的做用是创建名称为dirname的子目录,与MS DOS下的md命令相似,它的使用权限是全部用户。
  2.格式mkdir [options]目录名3.[options]主要参数-m,--mode=模式:设定权限< 模式>,与chmod相似。
  -p,--parents:须要时建立上层目录;若是目录早已存在,则不看成错误。
  -v,--verbose:每次建立新目录都显示信息。
  --version:显示版本信息后离开。
  4.应用实例在进行目录建立时能够设置目录的权限,此时使用的参数是“-m”。假设要建立的目录名是“tsk”,让全部用户都有rwx(即读、写、执行的权限),那么可使用如下命令:
  $ mkdir-m 777 tsk grep 1.做用grep命令能够指定文件中搜索特定的内容,并将含有这些内容的行标准输出。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是全部用户。
  2.格式grep [options] 3.主要参数[options]主要参数:
  -c:只输出匹配行的计数。
  -I:不区分大小写(只适用于单字符)。
  -h:查询多文件时不显示文件名。
  -l:查询多文件时只输出包含匹配字符的文件名。
  -n:显示匹配行及行号。
  -s:不显示不存在或无匹配文本的错误信息。
  -v:显示不包含匹配文本的全部行。
  pattern正则表达式主要参数:
  :忽略正则表达式中特殊字符的原有含义。
  ^:匹配正则表达式的开始行。
  $:匹配正则表达式的结束行。
  < :从匹配正则表达式的行开始。
  >:到匹配正则表达式的行结束。
  [ ]:单个字符,如[A]即A符合要求。
  [ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求。
  。:全部的单个字符。
  *:有字符,长度能够为0。
  正则表达式是Linux/Unix系统中很是重要的概念。正则表达式(也称为“regex”或“regexp”)是一个能够描述一类字符串的模式(Pattern)。若是一个字符串能够用某个正则表达式来描述,咱们就说这个字符和该正则表达式匹配(Match)。这和DOS中用户可使用通配符“*”表明任意字符相似。在Linux系统上,正则表达式一般被用来查找文本的模式,以及对文本执行“搜索-替换”操做和其它功能。
  4.应用实例查询DNS服务是平常工做之一,这意味着要维护覆盖不一样网络的大量IP地址。有时IP地址会超过2000个。若是要查看nnn.nnn网络地址,可是却忘了第二部分中的其他部分,只知到有两个句点,例如nnn nn..。要抽取其中全部nnn.nnn IP地址,使用[0-9 ]{3 }.[0-0{3}。含义是任意数字出现3次,后跟句点,接着是任意数字出现3次,后跟句点。
  $grep '[0-9 ]{3 }.[0-0{3}' ipfile 补充说明,grep家族还包括fgrep和egrep。fgrep是fix grep,容许查找字符串而不是一个模式;egrep是扩展grep,支持基本及扩展的正则表达式,但不支持q模式范围的应用及与之相对应的一些更加规范的模式。
  dd 1.做用dd命令用来复制文件,并根据参数将数据转换和格式化。
  2.格式dd [options] 3.[opitions]主要参数bs=字节:强迫ibs=< 字节>及obs=< 字节>。
  cbs=字节:每次转换指定的< 字节>。
  conv=关键字:根据以逗号分隔的关键字表示的方式来转换文件。
  count=块数目:只复制指定< 块数目>的输入数据。
  ibs=字节:每次读取指定的< 字节>。
  if=文件:读取< 文件>内容,而非标准输入的数据。
  obs=字节:每次写入指定的< 字节>。
  of=文件:将数据写入< 文件>,而不在标准输出显示。
  seek=块数目:先略过以obs为单位的指定< 块数目>的输出数据。
  skip=块数目:先略过以ibs为单位的指定< 块数目>的输入数据。
  4.应用实例
  dd命令经常用来制做Linux启动盘。先找一个可引导内核,令它的根设备指向正确的根分区,而后使用dd命令将其写入软盘:
  $ rdev vmlinuz /dev/hda $dd if=vmlinuz of=/dev/fd0
  上面代码说明,使用rdev命令将可引导内核vmlinuz中的根设备指向/dev/hda,请把“hda”换成本身的根分区,接下来用dd命令将该内核写入软盘。
  find 1.做用find命令的做用是在目录中搜索文件,它的使用权限是全部用户。
  2.格式find [path][options][expression] path指定目录路径,系统从这里开始沿着目录树向下查找文件。它是一个路径列表,相互用空格分离,若是不写path,那么默认为当前目录。
  3.主要参数[options]参数:
  -depth:使用深度级别的查找过程方式,在某层指定目录中优先查找文件内容。
  -maxdepth levels:表示至多查找到开始目录的第level层子目录。level是一个非负数,若是level是0的话表示仅在当前目录中查找。
  -mindepth levels:表示至少查找到开始目录的第level层子目录。
  -mount:不在其它文件系统(如Msdos、Vfat等)的目录和文件中查找。
  -version:打印版本。
  [expression]是匹配表达式,是find命令接受的表达式,find命令的全部操做都是针对表达式的。它的参数很是多,这里只介绍一些经常使用的参数。
  —name:支持统配符*和?。
  -atime n:搜索在过去n天读取过的文件。
  -ctime n:搜索在过去n天修改过的文件。
  -group grpoupname:搜索全部组为grpoupname的文件。
  -user用户名:搜索全部文件属主为用户名(ID或名称)的文件。
  -size n:搜索文件大小是n个block的文件。
  -print:输出搜索结果,而且打印。
  4.应用技巧find命令查找文件的几种方法:
  (1)根据文件名查找例如,咱们想要查找一个文件名是lilo.conf的文件,可使用以下命令:
  find /-name lilo.conf find命令后的“/”表示搜索整个硬盘。
  (2)快速查找文件根据文件名查找文件会遇到一个实际问题,就是要花费至关长的一段时间,特别是大型Linux文件系统和大容量硬盘文件放在很深的子目录中时。若是咱们知道了这个文件存放在某个目录中,那么只要在这个目录中往下寻找就能节省不少时间。好比smb.conf文件,从它的文件后缀“.conf”能够判断这是一个配置文件,那么它应该在/etc目录内,此时可使用下面命令:
  find /etc-name smb.conf 这样,使用“快速查找文件”方式能够缩短期。
  (3)根据部分文件名查找方法有时咱们知道只某个文件包含有abvd这4个字,那么要查找系统中全部包含有这4个字符的文件能够输入下面命令:
  find /-name '*abvd*'
  输入这个命令之后,Linux系统会将在/目录中查找全部的包含有abvd这4个字符的文件(其中*是通配符),好比abvdrmyz等符合条件的文件都能显示出来。
  (4)使用混合查找方式查找文件
  find命令可使用混合查找的方法,例如,咱们想在/etc目录中查找大于500000字节,而且在24小时内修改的某个文件,则可使用-and (与)把两个查找参数连接起来组合成一个混合的查找方式。
  find /etc -size +500000c -and -mtime +1
  mv 1.做用mv命令用来为文件或目录更名,或者将文件由一个目录移入另外一个目录中,它的使用权限是全部用户。该命令如同DOS命令中的ren和move的组合。
  2.格式mv[options]源文件或目录目标文件或目录3.[options]主要参数-i:交互方式操做。若是mv操做将致使对已存在的目标文件的覆盖,此时系统询问是否重写,要求用户回答“y”或“n”,这样能够避免误覆盖文件。
  -f:禁止交互操做。mv操做要覆盖某个已有的目标文件时不给任何指示,指定此参数后i参数将再也不起做用。
  4.应用实例(1)将/usr/cbu中的全部文件移到当前目录(用“.”表示)中:
  $ mv /usr/cbu/ * . (2)将文件cjh.txt重命名为wjz.txt:
  $ mv cjh.txt wjz.txt ls 1.做用ls命令用于显示目录内容,相似DOS下的dir命令,它的使用权限是全部用户。
  2.格式ls [options][filename] 3.options主要参数-a,--all:不隐藏任何以“.”字符开始的项目。
  -A,--almost-all:列出除了“.”及“..”之外的任何项目。
  --author:印出每一个文件著做者。
  -b,--escape:以八进制溢出序列表示不可打印的字符。
  --block-size=大小:块以指定< 大小>的字节为单位。-B,--ignore-backups:不列出任何以~字符结束的项目。
  -f:不进行排序,-aU参数生效,-lst参数失效。
  -F,--classify:加上文件类型的指示符号(*/=@|其中一个)。
  -g:like-l, but do not list owner。
  -G,--no-group:inhibit display of group information。
  -i,--inode:列出每一个文件的inode号。
  -I,--ignore=样式:不印出任何符合Shell万用字符< 样式>的项目。
  -k:即--block-size=1K。
  -l:使用较长格式列出信息。
  -L,--dereference:当显示符号连接的文件信息时,显示符号连接所指示的对象,而并不是符号连接自己的信息。
  -m:全部项目以逗号分隔,并填满整行行宽。
  -n,--numeric-uid-gid:相似-l,但列出UID及GID号。
  -N,--literal:列出未经处理的项目名称,例如不特别处理控制字符。
  -p,--file-type:加上文件类型的指示符号(/=@|其中一个)。
  -Q,--quote-name:将项目名称括上双引号。
  -r,--reverse:依相反次序排列。
  -R,--recursive:同时列出全部子目录层。
  -s,--size:以块大小为序。
  diff 1.做用diff命令用于两个文件之间的比较,并指出二者的不一样,它的使用权限是全部用户。
  2.格式diff [options]源文件目标文件3.[options]主要参数-a:将全部文件看成文本文件来处理。
  -b:忽略空格形成的不一样。
  -B:忽略空行形成的不一样。
  -c:使用纲要输出格式。-H:利用试探法加速对大文件的搜索。
  -I:忽略大小写的变化。
  -n --rcs:输出RCS格式。
  cmp 1.做用cmp(“compare”的缩写)命令用来简要指出两个文件是否存在差别,它的使用权限是全部用户。
  2.格式cmp[options]文件名3.[options]主要参数-l:将字节以十进制的方式输出,并方便将两个文件中不一样的以八进制的方式输出。
  cat 1.做用cat(“concatenate”的缩写)命令用于链接并显示指定的一个和多个文件的有关信息,它的使用权限是全部用户。
  2.格式cat [options]文件1文件2……
  3.[options]主要参数-n:由第一行开始对全部输出的行数编号。
  -b:和-n类似,只不过对于空白行不编号。
  -s:当遇到有连续两行以上的空白行时,就代换为一行的空白行。
  4.应用举例(1)cat命令一个最简单的用处是显示文本文件的内容。例如,咱们想在命令行看一下README文件的内容,可使用命令:
  $ cat README (2)有时须要将几个文件处理成一个文件,并将这种处理的结果保存到一个单独的输出文件。cat命令在其输入上接受一个或多个文件,并将它们做为一个单独的文件打印到它的输出。例如,把README和INSTALL的文件内容加上行号(空白行不加)以后,将内容附加到一个新文本文件File1中:
  $ cat README INSTALL File1 (3)cat还有一个重要的功能就是能够对行进行编号,见图2所示。这种功能对于程序文档的编制,以及法律和科学文档的编制很方便,打印在左边的行号使得参考文档的某一部分变得容易,这些在编程、科学研究、业务报告甚至是立法工做中都是很是重要的。
  对行进行编号功能有-b(只能对非空白行进行编号)和-n(能够对全部行进行编号)两个参数:
  $ cat -b /etc/named.conf
  ln 1.做用ln命令用来在文件之间建立连接,它的使用权限是全部用户。
  2.格式ln [options]源文件[连接名] 3.参数-f:链结时先将源文件删除。
  -d:容许系统管理者硬链结本身的目录。
  -s:进行软链结(Symbolic Link)。
  -b:将在链结时会被覆盖或删除的文件进行备份。
  连接有两种,一种被称为硬连接(Hard Link),另外一种被称为符号连接(Symbolic Link)。默认状况下,ln命令产生硬连接。
  硬链接指经过索引节点来进行的链接。在Linux的文件系统中,保存在磁盘分区中的文件不论是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。通常这种链接就是硬链接。硬链接的做用是容许一个文件拥有多个有效路径名,这样用户就能够创建硬链接到重要文件,以防止“误删”的功能。其缘由如上所述,由于对应该目录的索引节点有一个以上的链接。只删除一个链接并不影响索引节点自己和其它的链接,只有当最后一个链接被删除后,文件的数据块及目录的链接才会被释放。也就是说,文件才会被真正删除。
  与硬链接相对应,Lnux系统中还存在另外一种链接,称为符号链接(Symbilc Link),也叫软链接。软连接文件有点相似于Windows的快捷方式。它其实是特殊文件的一种。在符号链接中,文件其实是一个文本文件,其中包含的有另外一文件的位置信息。
  动手练习
  上面咱们介绍了Linux文件处理命令,下面介绍几个实例,你们能够动手练习一下刚才讲过的命令。
  1.利用符号连接快速访问关键目录
  符号连接是一个很是实用的功能。假设有一些目录或文件须要频繁使用,但因为Linux的文件和目录结构等缘由,这个文件或目录在很深的子目录中。好比,Apache Web服务器文档位于系统的/usr/local/httpd/htdocs中,而且不想每次都要从主目录进入这样一个长的路径之中(实际上,这个路径也很是不容易记忆)。
  为了解决这个问题,能够在主目录中建立一个符号连接,这样在须要进入该目录时,只需进入这个连接便可。
  为了能方便地进入Web服务器(/usr/local/httpd/htdocs)文档所在的目录,在主目录下可使用如下命令:$ ln -s /usr/local/httpd/htdocs gg
  这样每次进入gg目录就可访问Web服务器的文档,之后若是再也不访问Web服务器的文档时,删除gg便可,而真正的Web服务器的文档并无删除。
  2.使用dd命令将init.rd格式的root.ram内容导入内存dd if=/dev/fd0 of=floppy.fd dd if=root.ram of=/dev/ram0 # 3.grep命令系统调用
  grep是Linux/Unix中使用最普遍的命令之一,许多Linux系统内部均可以调用它。
  (1)若是要查询目录列表中的目录,方法以下:
  $ ls -l | grep '∧d'
  (2)若是在一个目录中查询不包含目录的全部文件,方法以下:
  $ ls -l | grep '∧[∧d]'
  (3)用find命令调用grep,如全部C源代码中的“Chinput”,方法以下:
  $find /ZhXwin -name *.c -exec grep -q -s Chinput {} ;-printnode

相关文章
相关标签/搜索