1. ls
    ls 命令是 linux 下最常用的命令,ls 命令就是 list 的缩写。 ls 用来打印出当前目录的清单。如果 ls 指定其他目录,那么就会显示指定目录里的文件及文件夹清单。 通过 ls 命令不仅可以查看 linux 文件夹包含的文件,而且可以查看文件权限(包括目录、文件夹、文件权限)查看目录信息等等。
    (1)命令格式
    ls [选项] [目录名]
    (2)常用参数
    参数
    描述
    -a
    –all 列出目录下的所有文件,包括以 . 开头的隐含文件
    -l
    除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来
    -d
    –directory 将目录象文件一样显示,而不是显示其下的文件
    -h
    –human-readable 以容易理解的格式列出文件大小 (例如 1K 234M 2G)
    -t
    以文件修改时间排序

  2. cd
    cd / 根目录
    cd ~ 用户目录
    cd .. 父目录
    cd – 上一次目录

  3. pwd
    1. Linux 中用 pwd 命令来查看“当前工作目录”的完整路径。 简单得说,每当你在终端进行操作时,你都会有一个当前工作目录。 在不太确定当前位置时,就会使用 pwd 来判定当前目录在文件系统内的确切位置。 pwd 命令是 Print Working Directory 的缩写。
      (1)命令格式
      pwd [选项]
      (2)常用参数
      参数
      描述
      -P
      显示实际物理路径,而非使用连接(link)路径
      -L
      当目录为连接路径时,显示连接路径

  4. mv
    mv 命令功能是用来移动文件或更改文件名,是 Linux 系统下常用的命令,经常用来备份文件或者目录。 mv 命令根据第二个参数类型(是目标文件还是目标目录),决定执行将文件重命名或将其移至一个新的目录中。当第二个参数类型是文件时,mv 命令完成文件重命名,此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名。当第二个参数是已存在的目录名称时,源文件或目录参数可以有多个,mv 命令将各参数指定的源文件均移至目标目录中。 mv 命令是 move 的缩写。
    (1)命令格式
    mv [选项] 源文件或目录 目标文件或目录
    (2)常用参数
    参数
    描述
    -b –back
    若需覆盖文件,则覆盖前先行备份
    -f –force
    如果目标文件已经存在,不会询问而直接覆盖
    -i –interactive
    若目标文件已经存在时,就会询问是否覆盖
    -u –update
    若目标文件已经存在,且源文件比较新,才会更新
    -t –target
    该选项适用于移动多个源文件到一个目录的情况,此时目标目录在前,源文件在后

  5. mkdir

    mkdir 命令用来创建指定名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录。 mkdir 命令是 make directory 的缩写。
    (1)命令格式
    mkdir [选项] 目录
    (2)常用参数
    参数
    描述
    -m –mode=模式
    设定权限<模式>
    -p –parents
    可以是一个路径名称。若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录
    -v –verbose
    每次创建新目录都显示信息

  6. rm

    rm 是常用的命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录及其下的所有文件及子目录均删除。对于链接文件,只是删除了链接,原有文件均保持不变。
    rm 是一个危险的命令,使用的时候要特别当心,尤其对于新手,否则整个系统就会毁在这个命令(比如在/(根目录)下执行 rm * -rf)。所以,我们在执行 rm 之前最好先确认一下在哪个目录,到底要删除什么东西,操作时保持高度清醒的头脑。
    rm 命令是 remove 的缩写。
    (1)命令格式
    rm [选项] 文件或目录
    (2)常用参数

    参数
    描述
    -f –force
    忽略不存在的文件,从不给出提示
    -i –interactive
    进行交互式删除
    -r –recursive
    指示 rm 将参数中列出的全部目录和子目录均递归地删除
    -v –verbose
    详细显示进行的步骤

  7. cp
    cp 命令用来复制文件或者目录,是 Linux 系统中最常用的命令之一。一般情况下,shell 会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i 参数。但是如果是在 shell 脚本中执行 cp 时,没有-i 参数时不会询问是否覆盖。这说明命令行和 shell 脚本的执行方式有些不同。 cp 命令是 copy 的缩写。
    (1)命令格式
    cp [选项] 源文件 目录 cp [选项] -t 目录 源文件
    (2)常用参数
    参数
    描述
    -t –target-directory
    指定目标目录
    -i –interactive
    覆盖前询问(使前面的 -n 选项失效)
    -n –no-clobber
    不要覆盖已存在的文件(使前面的 -i 选项失效)
    -s –symbolic-link
    对源文件建立符号链接,而非复制文件
    -f –force
    强行复制文件或目录, 不论目的文件或目录是否已经存在
    -u –update
    使用这项参数之后,只会在源文件的修改时间较目的文件更新时,或是对应的目的文件并不存在,才复制文件

  8. cat
    cat 命令的功能是将文件或标准输入组合输出到标准输出。这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用。 cat 命令是 concatenate 的缩写。
    (1)命令格式
    cat [选项] [文件]
    (2)常用参数
    参数
    描述
    -A –show-all
    等价于 -vET
    -b –number-nonblank
    对非空输出行编号
    -e
    等价于 -vE
    -E –show-ends
    在每行结束处显示 $
    -n –number
    对输出的所有行编号,由 1 开始对所有输出的行数编号
    -s –squeeze-blank
    有连续两行以上的空白行,就代换为一行的空白行
    -t
    与 -vT 等价
    -T –show-tabs
    将跳格字符显示为 ^I
    -u
    (被忽略)
    -v –show-nonprinting
    使用 ^ 和 M- 引用,除了 LFD 和 TAB 之外

  9. nl
    1. nl 命令在 linux 系统中用来计算文件中行号。nl 可以将输出的文件内容自动的加上行号。其默认的结果与 cat -n 有点不太一样, nl 可以将行号做比较多的显示设计,包括位数与是否自动补齐 0 等等的功能。
      nl 命令是 number of lines 的缩写。
      (1)命令格式
      nl [选项] [文件]
      (2)常用参数
      参数
      描述
      -b
      指定行号指定的方式,主要有两种:
      -b a
      表示不论是否为空行,也同样列出行号(类似 cat -n)
      -b t
      如果有空行,空的那一行不要列出行号(默认值)
      -n
      列出行号表示的方法,主要有三种:
      -n ln
      行号在屏幕的最左方显示
      -n rn
      行号在自己栏位的最右方显示,且不加 0
      -n rz
      行号在自己栏位的最右方显示,且加 0
      -w
      行号栏位的占用的位数

  10. more
    1. more 命令,功能类似 cat ,cat 命令是将整个文件的内容从上到下显示在屏幕上。 more 命令会一页一页的显示,方便使用者逐页阅读,而最基本的指令就是按空白键(space)往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能 。more 命令从前向后读取文件,因此在启动时就加载整个文件。
      (1)命令格式
      more [选项] 文件
      (2)常用参数
      参数
      描述
      +n
      从笫 n 行开始显示
      -n
      定义屏幕大小为 n 行
      +/pattern
      在每个档案显示前搜寻该字串(pattern),然后从该字串前两行之后开始显示
      -c
      从顶部清屏,然后显示
      -d
      提示“Press space to continue,’q’ to quiet”,禁用响铃功能
      -p
      通过清除窗口而不是滚屏来对文件进行换页,与-c 选项相似
      -s
      把连续的多个空行显示为一行
      -u
      把文件内容中的下画线去掉
      (3)常用操作
      符号
      描述
      =
      输出当前行的行号
      q
      退出 more
      空格键
      向下滚动一屏
      b
      返回上一屏

  11. less
    1. less 工具也是对文件或其它输出进行分页显示的工具,应该说是 linux 正统查看文件内容的工具,功能极其强大。
      (1)命令格式
      less [选项] 文件
      (2)常用参数
      参数
      描述
      -e
      当文件显示结束后,自动离开
      -f
      强迫打开特殊文件,例如外围设备代号、目录和二进制文件
      -i
      忽略搜索时的大小写
      -m
      显示类似 more 命令的百分比
      -N
      显示每行的行号
      -s
      显示连续空行为一行
      (3)常用操作
      符号
      描述
      /字符串
      向下搜索“字符串”的功能
      ?字符串
      向上搜索“字符串”的功能
      n
      重复前一个搜索(与 / 或 ? 有关)
      N
      反向重复前一个搜索(与 / 或 ? 有关)
      b
      向前翻一页
      d
      向后翻半页
      q
      退出 less 命令
      空格键
      向后翻一页
      向上键
      向上翻动一行
      向下键
      向下翻动一行
      (4)常用范例
      less 与 cat 和 more 的区别:
      cat 命令功能:用于显示整个文件的内容,单独使用没有翻页功能。因此经常和 more 命令搭配使用,cat 命令还有就是可以将数个文件合并成一个文件的功能。
      more 命令功能:让画面在显示满一页时暂停,此时可按空格健继续显示下一个画面,或按 q 键停止显示。
      less 命令功能:less 命令的用法与 more 命令类似,也可以用来浏览超过一页的文件。所不同的是 less 命令除了可以按空格键向下显示文件外,还可以利用上下键来卷动文件。当要结束浏览时,只要在 less 命令的提示符“:”下按 q 键即可。
      其实这三个命令除了 cat 命令有合并文件的功能,其余功能上相近,只是从浏览习惯和显示方式上有所不同。

  12. which
    1. which 命令的作用是,在 PATH 变量指定的路径中搜索可执行文件的所在位置。它一般用来确认系统中是否安装了指定的软件。
      (1)命令格式
      which 可执行文件名称

  13. whereis
    1. whereis 命令主要用于定位可执行文件、源代码文件、帮助文件在文件系统中的位置。whereis 命令还具有搜索源代码、指定备用搜索路径和搜索不寻常项的能力。
      whereis 命令查找速度非常快,这是因为它根本不是在磁盘中漫无目的乱找,而是在一个数据库中(/var/lib/mlocate/)查询。这个数据库是 Linux 系统自动创建的,包含有本地所有文件的信息,并且每天通过自动执行 updatedb 命令更新一次。也正是因为这个数据库要每天才更新一次,就会使得 whereis 命令的搜索结果有时候会不准确,比如刚添加的文件可能搜不到。
      (1)命令格式
      whereis [选项] 文件
      (2)常用参数
      参数
      描述
      -b
      定位可执行文件
      -m
      定位帮助文件
      -s
      定位源代码文件
      -u
      搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件
      -B
      指定搜索可执行文件的路径
      -M
      指定搜索帮助文件的路径
      -S
      指定搜索源代码文件的路径

  14. locate 命令(ubuntu才有)
    1. locate 命令跟 whereis 命令类似,且它们使用的是相同的数据库。但 whereis 命令只能搜索可执行文件、联机帮助文件和源代码文件,如果要获得更全面的搜索结果,可以使用 locate 命令。
      locate 命令使用了十分复杂的匹配语法,可以使用特殊字元(如’*’和’?’)来指定需要查找的样本。
      (1)命令格式
      locate [选项] [搜索字符串]
      (2)常用参数
      参数
      描述
      -q
      安静模式,不会显示任何错误讯息
      -n
      至多显示 n 个输出
      -r
      使用正规表达式做寻找的条件
      -V
      显示版本讯息

  15. find
    1. find 命令主要作用是沿着文件层次结构向下遍历,匹配符合条件的文件,并执行相应的操作。Linux 下 find 命令提供了相当多的查找条件,功能很强大,对应的学习难度也比较大。
      (1)命令格式
      find [选项] [搜索路径] [表达式]
      默认路径是当前目录,默认表达式为-print。
      表达式可能由下列成份组成:操作符、选项、测试表达式以及动作。
      (2)常用参数
      参数
      描述
      -print
      find 命令将匹配的文件输出到标准输出
      -exec
      find 命令对匹配的文件执行该参数所给出的 shell 命令
      -name
      按照文件名查找文件
      -type
      查找某一类型的文件
      -prune
      使用这一选项可以使 find 命令不在当前指定的目录中查找,如果同 时使用-depth 选项,那么-prune 将被 find 命令忽略
      -user
      按照文件属主来查找文件
      -group
      按照文件所属的组来查找文件
      -mtime -n +n
      按照文件的更改时间来查找文件,-n 表示文件更改时间距现在小于 n天,+n 表示文件更改时间距现在大于 n 天,find 命令还有-atime 和 -ctime 选项

  16. xargs
    1. 我们可以用管道将一个命令的 stdout(标准输出)重定向到另一个命令的 stdin(标准输入)。但有些命令只能以命令行参数的形式接收数据,而无法通过 stdin 接收数据流。在这种情况下,无法通过管道将数据重定向给这些命令。
      这时 xargs 就可以发挥它的作用了,xargs 命令可以从标准输入接收输入,并把输入转换为一个特定的参数列表。
      (1)命令格式
      command | xargs [选项] [command]
      xargs 命令应该紧跟在管道操作符之后,因为它以标准输入作为主要的源数据流。
      (2)常用参数
      参数
      描述
      -n
      指定每行最大的参数数量
      -d
      指定分隔符
      (3)常用范例

  17. wc
    1. wc 命令是一个统计的工具,主要用来显示文件所包含的行、字和字节数。
      wc 命令是 word count 的缩写。
      (1)命令格式
      wc [选项] [文件]
      (2)常用参数
      参数
      描述
      -c
      统计字节数
      -l
      统计行数
      -m
      统计字符数,这个标志不能与 -c 标志一起使用
      -w
      统计字数,一个字被定义为由空白、跳格或换行字符分隔的字符串
      -L
      打印最长行的长度

  18. grep
    1. grep 是个很强大的命令,用来找到文件中的匹配文本,并且能够接受正则表达式和通配符,同时可以用多个 grep 命令选项来生成各种格式的输出。
      grep 的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。
      grep 可用于 shell 脚本,因为 grep 通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回 0,如果搜索不成功,则返回 1,如果搜索的文件不存在,则返回 2。我们利用这些返回值就可进行一些自动化的文本处理工作。
      (1)命令格式
      grep [选项] pattern [file]
      (2)常用参数
      参数
      描述
      -c
      计算找到 ‘搜寻字符串'(即 pattern) 的次数
      -i
      忽略大小写的不同,所以大小写视为相同
      -n
      输出行号
      -v
      反向选择,打印不匹配的行
      -r
      递归搜索
      –color=auto
      将找到的关键词部分加上颜色显示
      正则表达式是一种符号表示法,被用来识别文本模式。在某种程度上,它们与匹配文件和路径名的 shell 通配符比较相似,但其规模更大。许多命令行工具和大多数的编程语言都支持正则表达式,以此来帮助解决文本操作问题。
      正则表达式元字符由以下字符组成:
      ^ $ . [ ] { } – ? * + ( ) | \

  19. cut
    1. cut 命令是一个将文本按列进行切分的小工具,它可以指定分隔每列的定界符。
      如果一行数据包含多个字段(多列),现在想要提取其中的一列或多列,这是 cut 命令就可以大显身手了。
      (1)命令格式
      cut [选项] [文件名]
      (2)常用参数
      参数
      描述
      -b
      以字节为单位进行分割
      -c
      以字符为单位进行分割
      -d
      自定义分隔符,默认为制表符
      -f
      自定义字段
      –complement
      抽取整个文本行,除了那些由 -c 或 -f 选项指定的文本

  20. paste
    1. paste 命令的功能正好与 cut 相反。它会添加一个或多个文本列到文件中,而不是从文件中抽取文本列。它通过读取多个文件,然后把每个文件中的字段整合成单个文本流,输入到标准输出。
      (1)命令格式
      paste [选项] [文件名]
      (2)常用参数
      参数
      描述
      -s
      将每个文件合并成行而不是按行粘贴
      -d
      自定义分隔符,默认为制表符

  21. tr
    1. tr 命令常被用来更改字符。我们可以把它看作是一种基于字符的查找和替换操作。换字是一种把字符从一个字母转换为另一个字母的过程。tr 从标准输入中替换、缩减和/或删除字符,并将结果写到标准输出。
      tr 只能通过 stdin(标准输入),而无法通过命令行参数来接受输入。
      tr 是 translate(转换)的缩写。
      (1)命令格式
      tr [选项] SET1 SET2
      将来自 stdin 的输入字符从 SET1 映射到 SET2,并将其输出写入 stdout(标准输出)。SET1 和 SET2 是字符类或字符集。如果两个字符集的长度不相等,那么 SET2 会不断重复其最后一个字符,直到长度与 SET1 相同。如果 SET2 的长度大于 SET1,那么在 SET2 中超出 SET1 的那部分字符则全部被忽略。
      (2)常用参数
      参数
      描述
      -d
      删除匹配 SET1 的内容,并不作替换

  22. sort
    1. 同文本文件打交道时,总避不开排序,那是因为对于文本处理任务而言,排序(sort)可以起到不小的作用。sort 命令能够帮助我们对文本文件和 stdin 进行排序操作。通常,它会结合其他命令来生成所需要的输出。
      (1)命令格式
      sort [选项] [文件名]
      (2)常用参数
      参数
      描述
      -n
      基于字符串的长度来排序,使用此选项允许根据数字值排序,而不是字母值
      -k
      指定排序关键字
      -b
      默认情况下,对整行进行排序,从每行的第一个字符开始。这个选项导致 sort 程序忽略每行开头的空格,从第一个非空白字符开始排序
      -m
      只合并多个输入文件
      -r
      按相反顺序排序,结果按照降序排列,而不是升序
      -t
      自定义分隔符,默认为制表符
      (3)常用范例

  23. join
    1. join 命令类似于 paste,它会往文件中添加列,但是它使用了独特的方法来完成。一个 join 操作通常与关系型数据库有关联,在关系型数据库中来自多个享有共同关键域的表格的数据结合起来,得到一个期望的结果。这个 join 命令执行相同的操作,它把来自于多个基于共享关键域的文件的数据结合起来。
      通俗地说,就是将两个文件中指定栏位相同的行连接起来,即按照两个文件中共同拥有的某一列,将对应的行拼接成一行。
      (1)命令格式
      join [选项] 文件 1 文件 2
      (2)常用参数
      参数
      描述
      -j FIELD
      等同于 -1 FIELD -2 FIELD,-j 指定一个域作为匹配字段
      -1 FIELD
      以 file1 中 FIELD 字段进行匹配
      -2 FIELD
      以 file2 中 FIELD 字段进行匹配
      -t
      自定义分隔符,默认为制表符

  24. comm
    1. 通常比较文本文件的内容很有帮助。对于系统管理员和软件开发者来说,这个尤为重要。一名系统管理员可能,例如,需要拿现有的配置文件与先前的版本做比较,来诊断一个系统错误。同样的,一名程序员经常需要查看程序的修改。
      comm 命令将逐行比较已经排序的两个文件。显示结果包括 3 列:第 1 列为只在第一个文件中找到的行,第 2 列为只在第二个文件中找到的行,第 3 列为两个文件的共有行。
      注意,comm 命令和 join、uniq 命令一样,只能用于已经排过序的数据。
      (1)命令格式
      comm [选项] 文件 1 文件 2
      (2)常用参数
      参数
      描述
      -1
      不输出文件 1 特有的行
      -2
      不输出文件 2 特有的行
      -3
      不输出两个文件共有的行

  25. diff
    1. 类似 comm 命令,diff 命令被用来监测文件之间的差异。然而,diff 是一款更加复杂的工具,它支持许多输出格式,并且一次能处理许多文本文件。软件开发员经常使用 diff 程序来检查不同程序源码版本之间的更改,diff 能够递归地检查源码目录,经常称之为源码树。diff 程序的一个常见用例是创建 diff 文件或者补丁,它会被其它程序使用,例如 patch 程序(我们后面会讲到),来把文件从一个版本转换为另一个版本。
      diff 在命令行中打印每一个行的改动,并且 diff 是 svn、cvs、git 等版本控制工具不可或缺的一部分。
      diff 命令是 differential 的缩写。
      (1)命令格式
      diff [选项] 文件
      (2)常用参数
      参数
      描述
      -c
      上下文模式,显示全部内文,并标出不同之处
      -u
      统一模式,以合并的方式来显示文件内容的不同
      -a
      只会逐行比较文本文件
      -N
      在比较目录时,若文件 A 仅出现在某个目录中,预设会显示:Only in 目录。 若使用-N 参数,则 diff 会将文件 A 与一个空白的文件比较
      -r
      递归比较目录下的文件

  26. df
    1. linux 中 df 命令的功能是用来检查 linux 服务器的文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。
      df 命令是 disk free 的缩写。
      (1)命令格式
      df [选项] 文件
      (2)常用参数
      参数
      描述
      -a
      全部文件系统列表
      -h
      方便阅读方式显示
      -i
      显示 inode 信息
      -T
      文件系统类型
      -t<文件系统类型>
      只显示选定文件系统的磁盘信息
      -x<文件系统类型>
      不显示选定文件系统的磁盘信息
      (3)常用范例

  27. du
    1. linux 中 du 命令也是查看使用空间的,但是与 df 命令不同的是 Linux du 命令是对文件和目录磁盘使用的空间的查看。
      du 命令是 disk usage 的缩写。
      (1)命令格式
      du [选项] 文件
      (2)常用参数
      参数
      描述
      -a
      显示目录中个别文件的大小。
      -b
      显示目录或文件大小时,以 byte 为单位。
      -c
      除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和。
      -k
      以 KB(1024bytes)为单位输出。
      -m
      以 MB 为单位输出。
      -s
      仅显示总计,只列出最后加总的值。
      -h
      以 K,M,G 为单位,提高信息的可读性

  28. time
    1. time 命令常用于测量一个命令的运行时间,包括实际使用时间(real time)、用户态使用时间(the process spent in user mode)、内核态使用时间(the process spent in kernel mode)。
      实际时间: 从 command 命令行开始执行到运行终止的时间。
      用户态使用时间:命令执行完成花费的用户 CPU 时间,即命令在用户态中执行时间总和。
      内核态使用时间:命令执行完成花费的系统 CPU 时间,即命令在核心态中执行时间总和。
      (1)命令格式
      time 命令
      (2)常用范例

 

 

发表评论