红帽7 管道符、重定向与环境变量

1、输入输出重定向

标准输入重定向(STDIN,文件描述符为0):默认从键盘输入,也可从其他文件或命令中输入。

标准输出重定向(STDOUT,文件描述符为1):默认输出到屏幕。

错误输出重定向(STDERR,文件描述符为2):默认输出到屏幕。

输出重定向:命令信息输出到文件

命令 > 文件 将标准输出重定向到一个文件中(清空原有文件的数据)
命令 2> 文件 将错误输出重定向到一个文件中(清空原有文件的数据)
命令 >> 文件 将标准输出重定向到一个文件中(追加到原有内容的后面)
命令 2>> 文件 将错误输出重定向到一个文件中(追加到原有内容的后面)
命令 >> 文件 2>&1

命令 &>> 文件
将标准输出与错误输出共同写入到文件中(追加到原有内容的后面)
[root@localhost Desktop]# ifconfig > a.txt
[root@localhost Desktop]# ls
a  a.py  a.txt
[root@localhost Desktop]# cat a.txt 
eno16777728: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.150.132  netmask 255.255.255.0  broadcast 192.168.150.255
        inet6 fe80::20c:29ff:fe57:f30f  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:57:f3:0f  txqueuelen 1000  (Ethernet)
        RX packets 223  bytes 21003 (20.5 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 230  bytes 22480 (21.9 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 6  bytes 560 (560.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 6  bytes 560 (560.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
把报错信息输入到文件中
[root@localhost Desktop]# ls -l tt.txt     #没有这个文件,报错
ls: cannot access tt.txt: No such file or directory


[root@localhost Desktop]# ls -l tt.txt 2> f.txt
[root@localhost Desktop]# ls
a  a.py  a.txt  f.txt
[root@localhost Desktop]# cat f.txt 
ls: cannot access tt.txt: No such file or directory
View Code

 

输入重定向:文件信息导入到命令(使用较少)

符号 作用
命令 < 文件 将文件作为命令的标准输入
命令 << 分界符 从标准输入中读入,直到遇见分界符才停止
命令 < 文件1 > 文件2 将文件1作为命令的标准输入并将标准输出到文件2
[root@localhost Desktop]# ls
a  a.py  a.txt
[root@localhost Desktop]# wc -l < a
18    

统计了a文件中有多少行
View Code

2、管道符

管道命令符的作用也可以用一句话来概括“把前一个命令原本要输出到屏幕的标准正常数据当作是后一个命令的标准输入”。同时按下键盘上的Shift+\键即可输入管道符,其执行格式为“命令A | 命令B”。

例如,通过匹配关键词/sbin/nologin找出所有被限制登录系统的用户,并且统计文本行数

找出被限制登录用户的命令是grep "/sbin/nologin" /etc/passwd;

统计文本行数的命令则是wc -l。

现在用管道符则可以合并为一条命令

[root@localhost Desktop]# grep /sbin/nologin /etc/passwd | wc -l
33

在修改用户密码时,通常都需要输入两次密码以进行确认,通过把管道符和passwd命令的--stdin参数相结合,我们可以用一条命令来完成密码重置操作

[root@linuxprobe ~]# echo "hello" | passwd --stdin root
Changing password for user root.
passwd: all authentication tokens updated successfully.

3、命令行的通配符

顾名思义,通配符就是通用的匹配信息的符号,比如星号(*)代表匹配零个或多个字符,问号(?)代表匹配单个字符,中括号内加上数字[0-9]代表匹配0~9之间的单个数字的字符,而中括号内加上字母[abc]则是代表匹配a、b、c三个字符中的任意一个字符,[a-z] 表示统配小写字符,[A-Z]表示统配大写字符。

匹配所有在/dev目录中且以sda开头的文件:

[root@localhost Desktop]# ls -l /dev/sda*
brw-rw----. 1 root disk 8, 0 Sep  7 14:18 /dev/sda
brw-rw----. 1 root disk 8, 1 Sep  7 14:18 /dev/sda1
brw-rw----. 1 root disk 8, 2 Sep  7 14:18 /dev/sda2

如果只想查看文件名为sda开头,但是后面还紧跟其他某一个字符的文件的相关信息,该怎么操作呢?这时就需要用到问号来进行通配了。

[root@localhost Desktop]# ls -l /dev/sda?
brw-rw----. 1 root disk 8, 1 Sep  7 14:18 /dev/sda1
brw-rw----. 1 root disk 8, 2 Sep  7 14:18 /dev/sda2

除了使用[0-9]来匹配0~9之间的单个数字,也可以用[1,3,5]这样的方式仅匹配这三个指定数字中的一个,若没有匹配到,则不会显示出来

[root@localhost Desktop]# ls -l /dev/sda[0-9]
brw-rw----. 1 root disk 8, 1 Sep  7 14:18 /dev/sda1
brw-rw----. 1 root disk 8, 2 Sep  7 14:18 /dev/sda2
[root@localhost Desktop]# ls -l /dev/sda[1,3,5]
brw-rw----. 1 root disk 8, 1 Sep  7 14:18 /dev/sda1

4、常用的转义字符

4个最常用的转义字符如下所示。

反斜杠(\):使反斜杠后面的一个变量变为单纯的字符串。

单引号(''):转义其中所有的变量为单纯的字符串。

双引号(""):保留其中的变量属性,不进行转义处理。

反引号(``):把其中的命令执行后返回结果。

例如,定义一个变量price,赋值为5,要输出 price is $5

[root@localhost Desktop]# price=5
[root@localhost Desktop]# echo "price is $price"
price is 5
[root@localhost Desktop]# echo "price is $$price"
price is 2633price

输出两个$符号则为取当前进程的编号

正确输入为:
[root@localhost Desktop]# echo "price is \$$price"
price is $5

5、重要的环境变量

变量是计算机系统用于保存可变值的数据类型。在Linux系统中,变量名称一般都是大写的,这是一种约定俗成的规范。我们可以直接通过变量名称来提取到对应的变量值。Linux系统中的环境变量是用来定义系统运行环境的一些参数,比如每个用户不同的家目录、邮件存放位置等。

在用户执行了一条命令之后,Linux系统中到底发生了什么事情呢?简单来说,命令在Linux中的执行分为4个步骤

第1步:判断用户是否以绝对路径或相对路径的方式输入命令(如/bin/ls),如果是的话则直接执行。

第2步:Linux系统检查用户输入的命令是否为“别名命令”,即用一个自定义的命令名称来替换原本的命令名称。

可以用alias命令来创建一个属于自己的命令别名,格式为“alias 别名=命令”。

[root@localhost Desktop]# alias c='clear'
[root@localhost Desktop]# alias 
alias c='clear'
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
View Code

若要取消一个命令别名,则是用unalias命令,格式为“unalias 别名”。

第3步:Bash解释器判断用户输入的是内部命令还是外部命令。内部命令是解释器内部的指令,会被直接执行;而用户在绝大部分时间输入的是外部命令。可以使用“type 命令名称”来判断用户输入的命令是内部命令还是外部命令。 

第4步:系统在多个路径中查找用户输入的命令文件,而定义这些路径的变量叫作PATH,作用是告诉Bash解释器待执行的命令可能存放的位置,然后Bash解释器就会乖乖地在这些位置中逐个查找。PATH是由多个路径值组成的变量,每个路径值之间用冒号间隔,对这些路径的增加和删除操作将影响到Bash解释器对Linux命令的查找。

给PATH变量添加一个路径

[root@localhost ~]# echo $PATH
/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin
[root@localhost ~]# PATH=$PATH:/root/bin
[root@localhost ~]# echo $PATH
/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/root/bin

  Linux系统中最重要的10个环境变量

变量名称 作用
HOME 用户的主目录(即家目录)
SHELL 用户在使用的Shell解释器名称
HISTSIZE 输出的历史命令记录条数
HISTFILESIZE 保存的历史命令记录条数
MAIL 邮件保存路径
LANG 系统语言、语系名称
RANDOM 生成一个随机数字
PS1 Bash解释器的提示符
PATH 定义解释器搜索用户执行命令的路径
EDITOR 用户默认的文本编辑器

 

 

 

 

 

 

 

 

 

 

 

 

 

 

可以使用env命令来查看到Linux系统中所有的环境变量

但是,这样的变量不具有全局性,作用范围也有限,默认情况下不能被其他用户使用。如果工作需要,可以使用 export 命令将其提升为全局变量,这样其他用户也就可以使用它了

 

posted @ 2018-09-07 15:57  烛爻  阅读(365)  评论(0编辑  收藏  举报