首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

《鸟哥的Linux私房菜》笔记整理Part.2

四、Bash shell的操作环境

1.路径与命令查找顺序

如果一个命令被下达时,到底是是哪一个同名的命令来运行呢?基本上,命令运行顺序如下所示:

(1)以相对/绝对路径执行指令,例如『/bin/ls』或『./ls』;

(2)由alias找到该指令来执行;

(3)由bash内建的(builtin)指令来执行;

(4)通过$PATH这个变量的顺序搜寻到的第一个指令来执行。

2.bash的登录与欢迎信息:/etc/issue, /etc/motd

打开/etc/issue就可以看到登录界面信息,比如我的写的就是:Ubuntu 18.04 LTS \n \l。issue里面各代码的涵义如下:

还有一个是/etc/issue.net,这个是提供给telnet远程登录程序的。如果想要让使用者登录以后获取一些信息,可以将信息加入到/etc/motd里面去。

3.bash的环境配置文件

系统有一些环境配置文件案的存在,让bash在启动时直接读取这些配置文件,以规划好bash的操作环境,而这些配置文件又可以分为全体系统的配置文件以及用户个人偏好配置文件。要注意的是,我们前几个小节谈到的命令别名啦、自定义变量啦,在你注销bash后就会失效,所以你想要保留你的设定,就得要将这些设定写入配置文件才行。

(1)login shell与non-login shell

login shell:取得bash时需要完整的登录流程的,就称为login shell。举例来说,你要由tty1~tty6登入,需要输入用户的账号与密码,此时取得的bash就称为“login shell”。

non-login shell:取得 bash界面的方法不需要重复登录的操作。

因为这两个取得bash的情况中,读取的配置文件数据并不一样,所以需要介绍一下这两个shell。

login shell读取这两个配置文件:

①/etc/profile:这是系统整体的配置,你最好不要修改这个文件;

②~/.bash_profile或~/.bash_login或~/.profile:属于使用者个人设定,你要改自己的数据,就写入这里。

(2)/etc/profile(只有login shell才会读取)

这个配置文件可以利用用户的标识符(UID)来决定很多重要的变量数据,这也是每个用户登入取得bash时一定会读取的配置文件。所以如果你想要帮所有用户配置整体环境,那就是改这里。不过,尽量不要修改这个配置文件。这个文件配置的变量主要有

除了以上之外,该文件还会去调用外部的配置文件。在CentOS 7.x的默认配置下,会依次调用以下文件:

①/etc/profile.d/*.sh;

②/etc/locale.conf

③/usr/share/bash-completion/completions/*

bash的login shell情况下所读取的整体环境配置文件其实只有/etc/profile

(3)~/.bash_profile(login shell才会读取)

在login shell的bash环境中,所读取的个人偏好配置文件其实主要有三个,依序分别是

①~/.bash_profile

②~/.bash_login

③~/.profile

其实 bash的login shell设定只会读取上面三个文件中的一个,而读取的顺序则是依照上面的顺序。

最后看一下整个login shell的读取流程:

图4.1 login shell读取流程

(4)source:读入环境配置文件的命令

由于/etc/profile与~/.bash_profile都是在取得loginshell的时候才会读取的配置文件,所以,如果你将自己的偏好设定写入上述的文件后,通常都是得注销再登入后,该设定才会生效。那么,能不能直接读取配置文件而不注销登入呢?可以的!那就得要利用source这个指令了。

命令使用格式如下:

利用source或小数点(.)都可以将配置文件的内容读进来目前的shell环境中。

(5)~/.bashrc(non-login shell读取的配置文件)

当读取non-login shell的时候,该bash仅仅会读取~/.bashrc这个配置文件。

(6)其他相关配置文件

①/etc/man_db.conf:规范了使用man的时候,man page的路径到哪里去寻找。

②~/.bash_history。

③~/.bash_logout:当退出bash后,系统完成什么操作后再离开。

4.终端机的环境设置:stty,set

如何查阅目前的一些按键内容呢?可以利用stty(settingtty终端机的意思)呢!stty也可以帮助设定终端机的输入按键代表意义。

下面举一个例子

几个重要的代表意义是:

①intr:送出一个interrupt(中断)的信号给目前正在run的程序;

②quit:送出一个quit的信号给目前正在run的程序;

③erase:向后删除字符,

④kill:删除在目前指令列上的所有文字;

⑤eof:Endoffile的意思,代表『结束输入』。

⑥start:在某个程序停止后,重新启动他的output

⑦stop:停止目前屏幕的输出;

⑧susp:送出一个terminalstop的信号给正在run的程序。

bash还有自己的一些终端机预设值,使用set来设置。set能够显示变量,还能够棒我们设置整个命令输入/输出环境。

最后整理一下bash里面的快捷键及功能

5.通配符与特殊符号

通配符如下表所示。

特殊符号如下

五、数据流复位向

数据流复位向就是将某个命令执行后应该要出现在屏幕上的数据传输到其他地方去。

standard output(标准输出)指的是命令执行所回传的正确信息。standard error output(标准错误输出)指的是命令执行失败后,所回传的错误信息。

不管正确还是错误的数据都是预设输出到屏幕上。可以通过数据复位向将标准输出(stdout)和标准错误输出(stderr)分别传送到其它文件或设备中区。而所传输的特殊字符如下所示:

①标准输入(stdin):代码为0,使用

②标准输出(stdout):代码为1,使用>或>>;

③标准错误输出(stderr):代码为2,使用2>或2>>。

关于标准输出和标准错误输出还有以下要说明的:

①1>:以覆盖的方法将『正确的数据』输出到指定的文件或设备上;

②1>>:以累加的方法将『正确的数据』输出到指定的文件或设备上;

③2>:以覆盖的方法将『错误的数据』输出到指定的文件或设备上;

④2>>:以累加的方法将『错误的数据』输出到指定的文件或设备上。

如果我知道错误信息会发生,所以要将错误信息忽略掉而不显示或者储存该如何去做呢?这个时候/dev/null就很重要的,正如null所表达的。例如下:

如果我们先将正确和错误的信息统统写入到同一个文件呢?是不是可以这样呢?

答案是不行的 ,因为由于两段数据同时写入一个文件,又没有使用特殊的语法,此时两段数据可能会交叉写入该文件内,造成次序的错乱。因此,可以使用下面的语法:2>&1,或者&>!。一般情况下,用前者。

standard input是指将原本需要由键盘输入的数据,改由文件内容来输入。如果我们用cat直接将输入的信息输出的catfile中,且当由键盘输入eof时,该次输入就结束。例如

利用

什么时候需要使用数据流复位向呢?如下:

①屏幕输出的信息很重要,而且我们需要将他存下来的时候;

②后台执行中的程序,不希望他干扰屏幕正常的输出结果时;

③一些系统的例行命令 (例如写在/etc/crontab中的文件)的执行结果,希望他可以存下来时;

④一些执行命令的可能已知错误信息时,想以『 2> /dev/null 』将他丢掉时;

⑤错误信息与正确信息需要分别输出时。

1.命令执行的判断依据:;,&&,||

(1)cmd;cmd

利用;可以不考虑指令的相关性连续下达指令。

(2)$?(命令回传值)与&&或||

在Linux下,若执行成功回传0,否则回传非0。

由于指令是一个接着一个去执行的,因此,如果真要使用判断,那么这个&&与||的顺序就不能搞错。

格式为:

command1 && command2 || command3

六、管道命令

管道命令使用的是“|”这个界定符号,这个命令与连续执行命令是不一样的!

管道命令仅能够处理经由前面一个命令传来的正确信息,也就是standard output的信息,对于standard error并没有直接处理的能力。因此其示意图如下所示。

图6.1 管道命令的处理示意图

在每个管道后面接的第一个数据必定是『命令』。而且这个命令必须要能够接受standard input的数据才行,这样的指令才可以是为『管线命令』。

1.选取命令:cut,grep

将一段数据经过分析后,取出我们想要的,或者经由关键字分析,取出我们想要的那行。要注意,选取信息通常针对逐行来分析。

(1)cut

cut主要的用途在于将『同一行里面的数据进行分解!』最常使用在分析一些数据或文字数据的时候!这是因为有时候我们会以某些字符当作分割的参数,然后来将数据加以切割,以取得我们所需要的数据。

举例如下:

图6.2 示例用法

(2)grep是分析一行信息,若当中有我们需要的信息,则将该行拿出来。使用方法如下所示:

2.排序命令:sort,wc,uniq

(1)sort

(2)uniq

这个指令用来将『重复的行删除掉只显示一个』。

(3)wc:显示文件有多少行,多少字符等。

3.双向复位向:tee

tee的工作流程示意图如下图所示。

图6.3 tee的工作流程示意图

使用方法如下所示。

4.字符转换命令:tr,col,join,paste,expand

(1)tr可以用来删除一段信息当中的文字,或者是进行文字信息的替换。

(2)col

(3)join

处理『两个文件当中,有 "相同数据" 的那一行,才将他加在一起』。

(4)paste:两行连着一起,中间以TAB隔开。

(5)expand:将TAB按键转换成空白键。

5.分割命令:split

split将大文件分割为小文件。使用方法如下。

6.参数替代:xargs

xargs可以读入stdin的数据,并且以空格符或断行字符作为分辨,将stdin的资料分隔成为arguments。

7.关于减号–的用途

在管道命令当中,常常会使用到前一个指令的stdout作为这次的stdin,某些指令需要用到文件名来进行处理时,该stdin与stdout可以利用减号”-“来替代,举例来说:

上面这个例子是说:『我将/home里面的文件给他打包,但打包的数据不是记录到文件,而是传送到stdout;经过管道后,将tar-cvf-/home传送给后面的tar-xvf-』。后面的这个-则是取用前一个指令的stdout,因此,我们就不需要使用filename了。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190217G0YHMX00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券