神奇高效的Linux命令行

1、为何要学linux命令

Linux是由命令行组成的操做系统,精髓在命令行,不管图形界面发展到什么水平,命令行方式的操做永远是不会变的。Linux命令有许多强大的功能:从简单的磁盘操做、文件存取,到进行复杂的多媒体图像和流媒体文件的制做,都离不开命令行。虽然Linux也有桌面系统,可是X-window也只是运行在命令行模式下的一个应用程序。linux

所以,能够说命令是学习Linux系统的基础,在很大程度上学习Linux就是学习命令,不少Linux高手其实都是玩儿命令很熟练的人。shell

也许对于刚刚从Windows系统进入Linux学习的初学者来讲,马上进入枯燥的命令学习实在太难,可是一旦学会就爱不释手。由于它的功能实在太强大了。bash

有不少初学者都会遇到这么一个问题,本身对系统的每一个命令都很熟悉,可是在系统出现故障的时候,就无从下手了,甚至不知道在何时用什么命令去检查系统,这是不少Linux新手最无奈的事情了。说到底,就是学习的理论知识没有很好地与系统实际操做相结合。网络

不少Linux知识,例如每一个命令的参数含义,在书本上说得很清楚,看起来也很容易理解,可是一旦组合起来使用,却并不那么容易,没有屡次的动手练习,其中的技巧是没法彻底掌握的。运维

人类大脑不像计算机的硬盘,除非硬盘坏掉或者硬盘被格式化,不然储存的资料将永远记忆在硬盘中,并且时刻能够调用。而在人类记忆的曲线中,必需要不断地重复练习才会将一件事情记得比较牢。学习Linux也同样,若是没法坚持学习的话,就会学了后面的,忘记了前面的。还有些Linux初学者也学了不少Linux知识,可是因为长期不用,致使学过的东西在很短的时间内又忘记了,长此以往,失去了学习的信心。ide

可见,要培养本身的实战技能,只有勤于动手,肯于实践,这也是学好Linux的根本。函数

遇到问题,首先想到的应该是如何本身去解决这个问题,解决方式有不少,好比看书查资料、网络搜索引擎搜索和浏览技术论坛等,经过这几种方式,90%的问题都能获得解决。linux运维

独立思考并解决问题,不但锻炼了本身独立解决问题的能力,在技术上也能获得快速提升。若是经过以上方式实在解决不了的话,能够向人询问,获得答案后要思考为什么这么作,而后作笔记记录解决过程。最忌讳的方式是只要遇到问题,就去问人,虽然这样可能会很快解决问题,可是长久下去遇到问题就会依赖别人,技术上也不会进步。学习

2、shell真的很重要

shell的本意是“壳”的意思,其实已经很形象地说明了shell在Linux系统中的做用。shell就是围绕在Linux内核以外的一个“壳”程序,用户在操做系统上完成的全部任务都是经过shell与Linux系统内核的交互来实现的。咱们应该熟悉DOS系统中command.com程序,shell的功能与此相似,可是shell的功能更增强大,更加好用。this

各类操做系统都有本身的shell。以DOS为例,它的shell就是command.com程序。DOS下还出现了不少第三方命令解释程序,例如4DOS、NDOS等,这些命令解释程序彻底能够取代标准的command.com程序。一样,Linux下除了默认的Bourne again shell(bash),还有不少其余的shell,例如C shell(csh)、Korn shell(ksh)、Bourne shell(sh)和Tenex C shell(tcsh)等。每一个版本的shell功能基本相同,但各有千秋,如今的Linux系统发行版通常都以bash做为默认的shell。

shell自己是一个C语言编写的程序,是用户和操做系统内核之间通讯的桥梁。shell既是一种命令解释程序,又是一种功能强大的解释型程序设计语言。做为命令解释程序,shell解释用户输入的命令,而后提交到内核处理,最后把结果返回给用户。

为了加快命令的运行,同时更有效地定制shell程序,shell中定义了一些内置的命令,通常咱们把shell自身解释执行的命令称为内置命令,例以下面咱们将要讲到的cd、pwd、exit和echo等命令,都是属于bash的内置命令。当用户登陆系统后,shell以及内置命令就被系统载入到内存,而且一直运行,直到用户退出系统为止。除了内置命令,Linux系统上还有不少可执行文件。可执行文件相似于Windows下的.exe文件,这些可执行文件也能够做为shell命令来执行。其实Linux上不少命令都不是shell的内置命令,例如ls就是一个可执行文件,存放在/bin/ls中。这些命令与shell内置命令不一样,只有当它们被调用时,才由系统装入内存执行。

当用户登陆系统后,若是是登陆字符界面,将出现shell命令提示符。“#”表示登陆的用户是系统超级用户,“*”表示登陆到系统的是普通用户。shell执行命令解释的具体过程为:用户在命令行输入命令提交后,shell程序首先检测是否为内置命令,若是是,就经过shell内部的解释器将命令解释为系统调用,而后提交给内核执行;若是不是shell内置的命令,那么shell会按照用户给出的路径或者根据系统环境变量的配置信息在硬盘寻找对应的命令,而后将其调入内存,最后再将其解释为系统调用,提交给内核执行。

最后shell仍是强大的解释型程序设计语言,它定义了各类选项和变量,几乎支持高级程序语言的全部程序结构,例如变量、函数、表达式和循环等。利用shell能够编写shell脚本程序,相似于Windows/DOS下的批处理文件,可是shell功能更加完善,更增强大。

3、shell中的通配符、重定向、管道和引用

Linux下的各类shell的主要区别在于命令行的语法。对于一些普通的命令,各个shell版本的语法基本相同,只有在编写一个shell脚本或者使用一些shell高级特性的时候,各个版本shell的差别才会显示出来。

shell语法分析是指shell的对命令的扫描处理过程,也就是把命令或者用户输入的内容分解成要处理的各个部分的操做。在Linux系统下,shell语法分析包含不少的内容,例如重定向、文件名扩展和管道等。

本节咱们以bash为例,介绍如下shell命令的语法分析。

3.1.shell的命令格式

用户登陆系统后,shell命令行启动。shell遵循必定的语法格式将用户输入的命令进行分析解释并传递给系统内核。shell命令的通常格式为:

command [options]   [arguments]

根据习惯,咱们通常把具备以上格式的字符串称为命令行。命令行是用户与shell之间对话的基本单位。

? command:表示命令的名称。
? options:表示命令的选项。
? arguments:表示命令的参数。

在命令行中,选项是包含一个或多个字母的代码,主要用于改变命令的执行方式。通常在选项前面有一个“-”符号,用于区别参数。例如:

[root@WEBServer ~]#ls -a

ls命令加上-a选项后,列出当前目录下的全部文件(包含隐藏文件)。若是ls不加“-a”选项,则仅仅显示当前目录下的文件名和目录(不显示隐藏文件)。

通常命令都有不少选项,能够单独列出它们,也能够在“-”后面把须要的选项都列出来,例如,

ls –a –l

也能够写成:

ls –al

不少命令均可以接受参数。参数就是在选项后面紧跟的一个或多个字符串,这些字符串指定了命令的操做对象,如文件或者目录。例如,要显示/etc目录下的全部文件及信息,可用如下命令:

[root@WEBServer ~]#ls –al  /etc

特殊状况下,有些命令能够不带参数,例如ls命令,而有些必须带参数。当参数不够时,shell就会给出错误提示。例如,mv命令至少须要两个参数。

[root@WEBServer ~]#mv  mylinux1.txt  mylinux.txt

在shell的一个命令行中,还能够输入多个命令,用分号将各个命令分开,例如:

[root@WEBServer ~]#ls –al;cp mylinux1.txt  mylinux2.txt

相反也能够在多行中输入一个命令,用“\”将一个命令持续到下一行:

[root@WEBServer ~]#cp –i \
>mylinux1.txt \
> mylinux2.txt

3.二、shell的通配符

通配符主要是为了方便用户对文件或者目录的描述,例如用户仅仅须要以“.sh”结尾的文件时,使用通配符就能很方便地实现。各个版本的shell都有通配符,这些通配符是一些特殊的字符,用户能够在命令行的参数中使用这些字符,进行文件名或者路径名的匹配。shell将把与命令行中指定的匹配规则符合的全部文件名或者路径名做为命令的参数,而后执行这个命令。

bash中经常使用的通配符有“*”、“?”、“[]”。

(1)“*”——匹配任意一个或多个字符

例如:

[root@WEBServer ~]#ls *.txt

这个命令是列出当前目录中全部以“.txt”结尾的文件(除去以“.”开头的文件)。

[root@WEBServer ~]#cp doc/* /opt

表示将doc目录下的全部文件(除去以“.”开头的文件)拷贝到/opt目录下。

[root@WEBServer ~]#ls –al /etc/*/*.conf

列出/etc目录的子目录下全部以“.conf”结尾的文件。在/etc目录下的以“.conf”结尾文件将不会列出。

(2)“?”——匹配任意单一字符

例如:

[root@WEBServer ~]#ls ab?.txt

将列出当前目录下以ab开头,随后一个字母是任意字符,接着以“.txt”结尾的文件。

[root@WEBServer ~]#ls ab??.txt

将列出当前目录下以ab开头,随后的两个字母是任意字符,接着以“.txt”结尾的文件。

(3)“[]”——匹配任何包含在方括号内的单字符
例如:

[root@WEBServer ~]#ls /dev/sda[12345]
/dev/sda1  /dev/sda2  /dev/sda3  /dev/sda4  /dev/sda5

上面列出了在/dev目录下以sda开头,第4个字符是一、二、三、4或5的全部文件。

[root@WEBServer ~]#ls /dev/sda[1-5]

在方括号中“1-5”给出了匹配的范围,与上面一条命令彻底等效。

(4)通配符的组合使用

在Linux下,通配符也能够组合使用,例如:

[root@WEBServer ~]#ls [0-9]?.conf

列出当前目录下以数字开头,随后一个是任意字符,接着以“.conf”结尾的全部文件。

[root@WEBServer ~]#ls [xyz]*.txt

列出当前目录下以x、y或z开头,最后以“.txt”结尾的文件。

3.三、shell的重定向

Linux下系统打开3个文件,即标准输入、标准输出和标准错误输出。用户的shell将键盘设为默认的标准输入,默认的标准输出和标准错误输出为屏幕。也就是用户从键盘输入命令,而后将结果和错误信息输出到屏幕。

所谓的重定向,就是不使用系统默认的标准输入输出,而是从新指定,所以重定向分为输入重定向、输出重定向和错误输出重定向。要实现重定向就须要了解重定向操做符,shell就是根据重定向操做符来决定重定向操做的。

一、输入重定向

输入重定向用于改变命令的输入源,利用输入重定向,就能够将一个文件的内容做为命令的输入,而不从键盘输入。

用于输入重定向的操做符有“<”和“<<”。例如:

[root@WEBServer ~]#wc </etc/shadow
40   40 1169

用wc命令统计输入给它的文件/etc/inittab的行数、单词数和字符数。
还有一种输入重定向“<<”,这种重定向告诉shell,当前命令的标准输入为来自命令行中一对分隔号之间的内容。例如:

[root@WEBServer ~]#wc << aa
> # Default runlevel. The runlevels used by RHS are:
> #   0 - halt (Do NOT set initdefault to this)
> #   1 - Single user mode
> #   2 - Multiuser, without NFS (The same as 3, if you do not have networking)
> #   3 - Full multiuser mode
> #   4 - unused
> #   5 - X11
> #   6 - reboot (Do NOT set initdefault to this)
> aa
  8  65 303

上面的命令将一对分隔号aa之间的内容做为wc命令的输入。分隔号能够是任意字符。shell将在第一个分隔号后开始读取内容,直到出现另外一个分隔号读取结束,而后将内容送给wc命令处理。

二、输出重定向

输出重定向是将命令的输出结果不在屏幕输出,而是输出到一个指定文件中。

在Linux下输出重定向用得不少,例如,某个命令的输出很长,一个屏幕没法显示完毕,咱们能够将命令的输出指定到一个文件,而后用more命令查看这个文件,从而获得命令输出的完整信息。

用于输出重定向的操做符有“>”和“>>”。

例如:

[root@WEBServer ~]#ps –ef >ps.txt

将ps –ef输出的系统运行进程信息所有输入到了ps.txt文件,而不输出到屏幕,能够用more命令查看ps.txt文件中系统运行的进程信息。

[root@WEBServer ~]#more file1 file2 file3 >file

more命令是查看文件的内容,上面的命令是将file一、file2和file3的内容所有输出到file文件中,相似于文件内容的合并。

若是在“>”后面指定的文件不存在的话,shell就会自动重建一个;若是文件存在的话,那么这个文件原有的内容将被覆盖;若是不想覆盖存在的文件,可使用“>>”操做符。例如:

[root@WEBServer ~]#ls –al /etc/* >>/root/install.log

将/etc目录及其子目录下的全部文件信息追加到/root/install.log文件的后面。/root/install.log文件原来的内容仍然存在。

三、错误重定向

错误重定向和标准输出重定向同样,可使用操做符“2>”和“2>>”实现对错误输出的重定向。例如:

[root@WEBServer ~]#tar zxvf text.tar.gz 2> error.txt

tar是打包命令,能够在屏幕上看到tar的解压过程。若是“text.tar.gz”是个损坏的压缩包,就会把错误信息输出到error.txt文件。

3.四、shell的管道

管道能够把不少命令链接起来,能够把第1个命令的输入看成第2个命令的输出,第2个命令的输出看成第3个命令的输入,依此类推。所以,管道的做用就是把一个命令的输出看成下一个命令的输入,而不通过任何中间文件。
经过管道符“|”能够创建一个管道链接,例如:

[root@WEBServer ~]# ls -al /etc/* |more

表示将/etc目录以及子目录下的全部文件分屏显示。

[root@WEBServer ~]#ps -ef|grep httpd|wc –l

这个命令是查看系统中正在运行的httpd进程,并计算httpd的进程数。

3.五、shell中的引用

在bash中有不少特殊字符,这些字符自己就具备特殊含义。若是在shell的参数中使用它们,就会出现问题。Linux中使用了“引用”技术来忽略这些字符的特殊含义,引用技术就是通知shell将这些特殊字符看成普通字符处理。shell中用于引用的字符有转义字符“\”、单引号“'”、双引号“" "”。

一、转义字符“\”

若是将“\”放到特殊字符前面,shell就忽略这些特殊字符的原有含义,看成普通字符对待,例如:

[root@WEBServer ~]#ls
abc?*  C:\backup
[root@WEBServer ~]#mv abc\?\*  abc
[root@WEBServer ~]#mv C\:\\backup backup

上面是将abc?*重命令为abc,将C:\backup重命名为backup。由于文件名中含有特殊字符,全部都使用了转义字符“\”。

二、单引号“'”

将字符串放到一对单引号之间,那么字符串中全部字符的特殊含义将被忽略,例如:

[root@WEBServer ~]#mv C\:\\backup backup
[root@WEBServer ~]#mv 'C:\backup'  backup

上面两条命令彻底等效。

三、双引号“" "”

双引号的引用与单引号基本相同,包含在双引号内的大部分特殊字符能够看成普通字符处理,可是仍有一些特殊字符即便用双引号括起来,也仍然保留本身的特殊含义,好比“$”、“\”和“`”。

[root@WEBServer ~]#str="The \$SHELL Current shell is $SHELL"
[root@WEBServer ~]#str1="\$$SHELL"
[root@WEBServer ~]#echo $str
The $SHELL Current shell is /bin/bash
[root@WEBServer ~]#echo $str1
$/bin/bash

从上面输出能够看出,“$”和“\”在双引号内仍然保留了特殊含义。

[root@WEBServer ~]# str="This hostname is `hostname`" 
[root@WEBServer ~]# echo $str
This hostname is WEBServer

上面的输出中,字符“`”在双引号中也保留了本身特殊含义。

看到了吧,shell很厉害吧,linux运维工做更多的是与shell打交道,因此学会shell,是学好linux运维的根本。

如何深刻学习shell技能

说了这么多,那么问题来了,怎么能快速学好shell,可以编写高质量的shell脚本提升运维效率呢,我将多年来企业一线工做经验进行了总结和提炼,写成了专栏《神奇高效的Linux命令行》点击前往,15篇文章打通shell任通二脉,让经验和案例说话:

专栏《神奇高效的Linux命令行》点击前往

此专栏能学到什么技能:

神奇高效的Linux命令行

相关文章
相关标签/搜索