Linux的重定向与管道详解程序员

(1).输出重定向

  定义:将命令的标准输出结果保存到指定的文件中,而不是直接显示在显示器上。

  输出重定向使用>和>>操作符。

  语法:cmd > filename,表示将标准输出写入文件,如果此文件已存在,将覆盖原文件的内容。如果不存在,则新建该文件。

     cmd >> filename,表示将标准输出追加到文件,如果文件不存在,则新建该文件。

实例1:查看当前主机的CPU类型保存到cpu.txt文件中,而不是直接显示到屏幕上。

//如果想要直接查看CPU信息 
[[email protected] ~]$ cat /proc/cpuinfo 
//那么相应的输出重定向如下 
[[email protected] ~]$ cat /proc/cpuinfo > cpu.txt 

实例2:将内核版本信息追加到cpu.txt

//如果想要查看系统基本信息 
[[email protected] ~]$ uname -r 
3.10.0-957.5.1.el7.x86_64 
[[email protected] ~]$ uname -a 
Linux xuexi 3.10.0-957.5.1.el7.x86_64 #1 SMP Fri Feb 1 14:54:57 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux 
//那么相应的追加如下 
[[email protected] ~]$ uname -a >> cpu.txt 

实例3:清空一个文件

[[email protected] ~]$ > cpu.txt  

(2).输入重定向

   定义:将命令中接收输入的途径有默认键盘改为其他文件,而不是等待从键盘输入。

  输入重定向使用<操作符。

实例:

[[email protected] ~]$ grep root /etc/passwd 
root:x:0:0:root:/root:/bin/bash 
operator:x:11:0:operator:/root:/sbin/nologin 
[[email protected] ~]$ grep root < /etc/passwd 
root:x:0:0:root:/root:/bin/bash 
operator:x:11:0:operator:/root:/sbin/nologin 

mysql数据库导入数据,格式如下

[[email protected] ~]$ mysql -uroot -p123456789 < a.sql 

(3).EOF

  EOF本意是End Of File,表明到了文件末尾。EOF通常与<<结合使用,<<EOF表示后续的输入作为子命令或子shell的输入,知道遇到EOF,再次返回主shell,可将其理解为分界符。既然是分界符,那么形式自然不是固定的,这里可以将EOF进行自定义,但是前后的分界符必须成对出现且不能和shell命令冲突。

 实例1:

[[email protected] ~]$ cat > a.txt << EOF 
> This is a file. 
> EOF 
[[email protected] ~]$ cat a.txt  
This is a file. 
[[email protected] ~]$ cat >> a.txt << EOF 
> My name is xf. 
> EOF 
[[email protected] ~]$ cat a.txt  
This is a file. 
My name is xf. 
[[email protected] ~]$ cat > b.txt << ccc 
> This is a file. 
> EOF 
> ccc 
[[email protected] ~]$ cat b.txt  
This is a file. 
EOF

实例2:在脚本中我们可以通过重定向输入来打印消息菜单。可以自定义。

[[email protected] ~]$ vim c.sh 
//文件内容如下 
#! /bin/bash 
 
cat << EOF 
=================================== 
mysql 
httpd 
oracle 
=================================== 
EOF 
//保存退出 
[[email protected] ~]$ chmod +x c.sh 
[[email protected] ~]$ ./c.sh  
=================================== 
mysql 
httpd 
oracle 
=================================== 

(4).错误重定向

  定义:将命令执行过程中出现的错误信息(选项或参数错误)保存到指定文件,而不是直接显示到显示器。

  错误重定向使用2>和2>>操作符(2表示的是标准错误的文件描述符)

  语法:cmd 2> filename,表示将标准错误写入文件,如果此文件已存在,将覆盖原文件的内容。如果不存在,则新建该文件。

     cmd 2>> filename,表示将标准错误追加到文件,如果文件不存在,则新建该文件。

  在实际应用中,错误重定向可以用于收集执行的错误信息,为排错提供依据;对于shell脚本还可以将无关紧要的错误信息重定向到空文件/dev/null,以保持脚本输出的简洁。

实例1:将错误显示的内容与正确显示的内容分开

[[email protected] ~]$ ls /etc/passwd xxxx 
ls: 无法访问xxxx: 没有那个文件或目录 
/etc/passwd 
[[email protected] ~]$ ls /etc/passwd xxxx > a.txt 
ls: 无法访问xxxx: 没有那个文件或目录 
[[email protected] ~]$ cat a.txt  
/etc/passwd 
[[email protected] ~]$ ls /etc/passwd xxxx 2> a.txt  
/etc/passwd 
[[email protected] ~]$ cat a.txt  
ls: 无法访问xxxx: 没有那个文件或目录 

实例2:正确的内容写入一个文件,错误的内容写入另一个文件

[[email protected] ~]$ ll /etc/passwd xxxx > right.txt 2> err.txt 
[[email protected] ~]$ cat right.txt  
-rw-r--r--. 1 root root 2257 2月  13 16:19 /etc/passwd 
[[email protected] ~]$ cat err.txt  
ls: 无法访问xxxx: 没有那个文件或目录 

(5).null黑洞和zero空文件

  把/dev/null看做“黑洞”,所有写入它的内容都会永远丢失。而尝试从该文件读取内容也什么都读不到。然而/dev/null对命令行和脚本都非常有用。

   /dev/zero在类UNIX操作系统中,是一个特殊的文件,当你读它时,它会提供无限的空字符(NULL,ASCII NUL,0x00)。典型用法是用它来产生一个特定大小的空白文件。

实例1:使用dd命令产生一个50M的空白文件,空白文件可以临时当做设备文件使用

[[email protected] ~]$ dd if=/dev/zero of=1.txt bs=M count=50 
记录了50+0 的读入 
记录了50+0 的写出 
52428800字节(52 MB)已复制,0.0508383 秒,1.0 GB/秒 
[[email protected] ~]$ ll -h 1.txt  
-rw-rw-r--. 1 xf xf 50M 2月  26 10:17 1.txt 
[[email protected] ~]$ cat 1.txt  
[[email protected] ~]$  

  /dev/zero也可以用于清除分区头。

(6).&>和>&符号

  &表示等同于的意思。除了&>和>&以外还有&>>

实例1:把标准输出与标准错误写入到同一个文件,此实例使用&>和>&有多种写法

[[email protected] ~]$ ls /tmp xxxx >1.txt 2>&1 
[[email protected] ~]$ ls /tmp xxxx 2>2.txt 1>&2 
[[email protected] ~]$ ls /tmp xxxx &> 3.txt 
[[email protected] ~]$ ls /tmp xxxx >& 4.txt 
[[email protected] ~]$ cat 1.txt  
ls: 无法访问xxxx: 没有那个文件或目录 
/tmp: 
ssh-2yPDLej8lp2k 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-bolt.service-3sZXoj 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-chronyd.service-rUnYOY 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-colord.service-go7dw4 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-cups.service-o7nKmx 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-fwupd.service-GN4Clw 
systemd-private-fb4d19bcb21b4301aa41f11d24a7deab-rtkit-daemon.service-59x6Qx 
tracker-extract-files.0 
tracker-extract-files.1000 
VMwareDnD 
vmware-root_6784-2823359541 
vmware-root_6814-2822835244 
vmware-root_6819-3879179857 
vmware-root_6821-3879048790 
vmware-root_6829-3845623896 
vmware-root_6834-2865236895 
vmware-root_6839-3854340548 
vmware-root_6843-3879573071 
vmware-root_6844-2831682966 
vmware-root_6849-4156467083 
vmware-root_6850-3100130775 
vmware-root_6851-4148143625 
vmware-root_6855-4156336012 
vmware-root_6863-4122911106 
vmware-root_6874-3099737545 
vmware-root_6883-4147619377 
vmware-root_6889-4122255805 
yum_save_tx.2019-02-21.14-15.ehxi5q.yumtx 
yum_save_tx.2019-02-25.09-56.0qBBLA.yumtx 
yum_save_tx.2019-02-26.10-23.gFGrHz.yumtx 
[[email protected] ~]$ diff 1.txt 2.txt  
[[email protected] ~]$ diff 1.txt 3.txt  
[[email protected] ~]$ diff 1.txt 4.txt  

实例2:把标准输出与标准错误追加到文件中

[[email protected] ~]$ ll > 1.txt 
[[email protected] ~]$ cat 1.txt  
总用量 0 
-rw-rw-r--. 1 xf xf 0 2月  26 13:34 1.txt 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 公共 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 模板 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 视频 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 图片 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 文档 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 下载 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 音乐 
drwxr-xr-x. 2 xf xf 6 11月 19 13:29 桌面 
[[email protected] ~]$ ls /tmp xxxx &>>1.txt 
[[email protected] ~]$ cat 1.txt  
总用量 0 
-rw-rw-r--. 1 xf xf 0 2月  26 13:34 1.txt 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 公共 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 模板 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 视频 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 图片 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 文档 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 下载 
drwxr-xr-x. 2 xf xf 6 9月   6 11:43 音乐 
drwxr-xr-x. 2 xf xf 6 11月 19 13:29 桌面 
ls: 无法访问xxxx: 没有那个文件或目录 
/tmp: 
ssh-7dArISEgeS0O 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-bolt.service-UElQVL 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-chronyd.service-oIQjdt 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-colord.service-8hFZOp 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-cups.service-7i8U0x 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-fwupd.service-SWULra 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-rtkit-daemon.service-jYXFJl 
tracker-extract-files.0 
tracker-extract-files.1000 
VMwareDnD 
vmware-root_6784-2823359541 
vmware-root_6814-2822835244 
vmware-root_6819-3879179857 
vmware-root_6821-3879048790 
vmware-root_6829-3845623896 
vmware-root_6834-2865236895 
vmware-root_6839-3854340548 
vmware-root_6843-3879573071 
vmware-root_6844-2831682966 
vmware-root_6849-4156467083 
vmware-root_6850-3100130775 
vmware-root_6851-4148143625 
vmware-root_6855-4156336012 
vmware-root_6863-4122911106 
vmware-root_6874-3099737545 
vmware-root_6883-4147619377 
vmware-root_6889-4122255805 
yum_save_tx.2019-02-21.14-15.ehxi5q.yumtx 
yum_save_tx.2019-02-25.09-56.0qBBLA.yumtx 
yum_save_tx.2019-02-26.10-23.gFGrHz.yumtx 

实例3:shell脚本中的/dev/null 2>&1是什么意思呢?

[[email protected] ~]$ ls /etc/passwd >/dev/null 2>&1

注:将标准输出和标准错误全部重定向到/dev/null中,也就是将产生的所有信息丢弃。

 (7).管道符|的使用

  语法: command -a | command -b | command -c | …

注意:1、管道命令只处理前一个命令标准输出,不处理标准错误

   2、管道右边的命令,必须是一个能够接收前一个命令的标准输出的数据流的命令才行

   3、管道可以把两个命令连起来,它可以连接多个命令使用

实例1:对应注意1

[[email protected] ~]$ ls /tmp xxxx 
ls: 无法访问xxxx: 没有那个文件或目录 
/tmp: 
ssh-7dArISEgeS0O 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-bolt.service-UElQVL 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-chronyd.service-oIQjdt 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-colord.service-8hFZOp 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-cups.service-7i8U0x 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-fwupd.service-SWULra 
systemd-private-6596f9db642a46ae9174a8ca3ace2009-rtkit-daemon.service-jYXFJl 
tracker-extract-files.0 
tracker-extract-files.1000 
VMwareDnD 
vmware-root_6784-2823359541 
vmware-root_6814-2822835244 
vmware-root_6819-3879179857 
vmware-root_6821-3879048790 
vmware-root_6829-3845623896 
vmware-root_6834-2865236895 
vmware-root_6839-3854340548 
vmware-root_6843-3879573071 
vmware-root_6844-2831682966 
vmware-root_6849-4156467083 
vmware-root_6850-3100130775 
vmware-root_6851-4148143625 
vmware-root_6855-4156336012 
vmware-root_6863-4122911106 
vmware-root_6874-3099737545 
vmware-root_6883-4147619377 
vmware-root_6889-4122255805 
yum_save_tx.2019-02-21.14-15.ehxi5q.yumtx 
yum_save_tx.2019-02-25.09-56.0qBBLA.yumtx 
yum_save_tx.2019-02-26.10-23.gFGrHz.yumtx 
[[email protected] ~]$ ls /tmp xxxx | grep /tmp 
ls: 无法访问xxxx: 没有那个文件或目录  //可以看到标准错误没有被处理,仍然输出 
/tmp: 

实例2:对应注意3

[[email protected] ~]$ ps -aux | grep sshd 
root       7418  0.0  0.2 112860  4312 ?        Ss   13:19   0:00 /usr/sbin/sshd -D 
xf        10913  0.0  0.0 112728   988 pts/0    S+   14:39   0:00 grep --color=auto sshd 
[[email protected] ~]$ ps -aux | grep sshd | grep root 
root       7418  0.0  0.2 112860  4312 ?        Ss   13:19   0:00 /usr/sbin/sshd -D 

(8).tee

tee [选项] [文件]

选项:

-a,--append 内容追加到给定的文件而非覆盖 
-i,--ignore-interrupts 忽略中断信号 
--help 帮助 
--version 版本信息 

  将标准输入复制到每个指定文件,并显示到标准输出

实例1:将磁盘使用的信息写入文件

[[email protected] ~]$ df -h | tee disk.log 
文件系统        容量  已用  可用 已用% 挂载点 
/dev/sda3        17G  4.7G   13G   28% / 
devtmpfs        975M     0  975M    0% /dev 
tmpfs           991M     0  991M    0% /dev/shm 
tmpfs           991M   11M  980M    2% /run 
tmpfs           991M     0  991M    0% /sys/fs/cgroup 
/dev/sr0        4.2G  4.2G     0  100% /mnt 
/dev/sda1      1014M  276M  739M   28% /boot 
tmpfs           199M   20K  199M    1% /run/user/1000 
[[email protected] ~]$ cat disk.log  
文件系统        容量  已用  可用 已用% 挂载点 
/dev/sda3        17G  4.7G   13G   28% / 
devtmpfs        975M     0  975M    0% /dev 
tmpfs           991M     0  991M    0% /dev/shm 
tmpfs           991M   11M  980M    2% /run 
tmpfs           991M     0  991M    0% /sys/fs/cgroup 
/dev/sr0        4.2G  4.2G     0  100% /mnt 
/dev/sda1      1014M  276M  739M   28% /boot 
tmpfs           199M   20K  199M    1% /run/user/1000 

实例2:将磁盘使用的信息追加到文件

[[email protected] ~]$ df -h | tee -a disk.log 
文件系统        容量  已用  可用 已用% 挂载点 
/dev/sda3        17G  4.7G   13G   28% / 
devtmpfs        975M     0  975M    0% /dev 
tmpfs           991M     0  991M    0% /dev/shm 
tmpfs           991M   11M  980M    2% /run 
tmpfs           991M     0  991M    0% /sys/fs/cgroup 
/dev/sr0        4.2G  4.2G     0  100% /mnt 
/dev/sda1      1014M  276M  739M   28% /boot 
tmpfs           199M   20K  199M    1% /run/user/1000 
[[email protected] ~]$ cat disk.log  
文件系统        容量  已用  可用 已用% 挂载点 
/dev/sda3        17G  4.7G   13G   28% / 
devtmpfs        975M     0  975M    0% /dev 
tmpfs           991M     0  991M    0% /dev/shm 
tmpfs           991M   11M  980M    2% /run 
tmpfs           991M     0  991M    0% /sys/fs/cgroup 
/dev/sr0        4.2G  4.2G     0  100% /mnt 
/dev/sda1      1014M  276M  739M   28% /boot 
tmpfs           199M   20K  199M    1% /run/user/1000 
文件系统        容量  已用  可用 已用% 挂载点 
/dev/sda3        17G  4.7G   13G   28% / 
devtmpfs        975M     0  975M    0% /dev 
tmpfs           991M     0  991M    0% /dev/shm 
tmpfs           991M   11M  980M    2% /run 
tmpfs           991M     0  991M    0% /sys/fs/cgroup 
/dev/sr0        4.2G  4.2G     0  100% /mnt 
/dev/sda1      1014M  276M  739M   28% /boot 
tmpfs           199M   20K  199M    1% /run/user/1000 

注:可以用来记录日志

 

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/2820.html

(0)
上一篇 2021年7月16日
下一篇 2021年7月16日

相关推荐

发表回复

登录后才能评论