1.重定向概述
什么是重定向
将原本要输出到屏幕的数据信息,重新定向到某个指定的文件中。比如:每天凌晨定时备份数据,希望将备份数据的结果保存到某个文件中。这样第二天通过查看文件的内容就知道昨天备份的数据是成功还是失败。为何要使用重定向
1.当屏幕输出的信息很重要,而且希望保存重要的信息时;
2.后台执行中的程序,不希望他干扰屏幕正常的输出结果时;
3.系统的例行命令, 例如定时任务的执行结果,希望可以存下来时;
4.一些执行命令,我们已经知道他可能出现错误信息, 想将他直接丢弃时;
5.错误日志与正确日志需要分别输出至不同的文件保存时;学习重定向的预备知识,标准输入与输出
当运行一个程序时通常会自动打开三个标准文件,分别是标准输入、标准输出、错误输出
名称 | 文件描述符 | 作用 |
---|---|---|
标准输入(stdin) | 0 | 默认是键盘,也可以是文件或者其他命令的输出 |
标准输出(stdout) | 1 | 默认输出到屏幕 |
错误输出(stderr) | 2 | 默认输出到屏幕 |
文件名称(filename) | 3+ |
进程将从标准输入中得到数据,将正常输出打印至屏幕终端,将错误的输出信息也打印至屏幕终端。
PS: 进程是使用文件描述符(file descriptors)来管理打开的文件
- 标准输入输出
#持续追踪查看文件内容
[root@localhost ~]# tail -f /etc/passwd
ctrl+z 将进程转到后台
#查看运行的进程
[root@localhost ~]# ps
PID TTY TIME CMD
8028 pts/0 00:00:00 bash
8089 pts/0 00:00:00 tail
8104 pts/0 00:00:00 ps
#查看tail命令的pid,6885进程下的文件描述符
[root@localhost ~]# ls -l /proc/8089/fd
total 0
lrwx------. 1 root root 64 Aug 9 16:49 0 -> /dev/pts/0
lrwx------. 1 root root 64 Aug 9 16:49 1 -> /dev/pts/0
lrwx------. 1 root root 64 Aug 9 16:48 2 -> /dev/pts/0
lr-x------. 1 root root 64 Aug 9 16:49 3 -> /etc/passwd
lr-x------. 1 root root 64 Aug 9 16:49 4 -> anon_inode:inotify
#Linux查看标准输入输出设备
[root@localhost ~]# ls -l /dev/std*
lrwxrwxrwx. 1 root root 15 Aug 9 08:28 /dev/stderr -> /proc/self/fd/2
lrwxrwxrwx. 1 root root 15 Aug 9 08:28 /dev/stdin -> /proc/self/fd/0
lrwxrwxrwx. 1 root root 15 Aug 9 08:28 /dev/stdout -> /proc/self/fd/1
2.输出重定向
输出重定向,改变输出内容的位置。输出重定向有如下几种方式,如表格所示
类型 | 操作符 | 用途 |
---|---|---|
标准覆盖输出重定向 | > | 将程序输出的正确结果输出到指定的文件中,会覆盖文件原有的内容 |
标准追加输出重定向 | >> | 将程序输出的正确结果以追加的方式输出到指定文件,不会覆盖原有文件 |
错误覆盖输出重定向 | 2> | 将程序的错误结果输出到执行的文件中,会覆盖文件原有的内容 |
错误追加输出重定向 | 2>> | 将程序输出的错误结果以追加的方式输出到指定文件,不会覆盖原有文件 |
标准输入重定向 | << | 将命令中接收输入的途径由默认的键盘更改为指定的文件或命令 |
-
1示例:标准输出重定向(每次都会覆盖文件)
#标准输出重定向, 先清空,后写入, 如果文件不存在则创建
[root@localhost ~]# ifconfig eth0 > abc
- 2示例:标准输出重定向(会往文件的尾部在添加内容)
#标准追加输出重定向, 向配置文件末尾追加内容
[root@localhost ~]# echo "This is network conf" >> if
-
3示例:错误输出重定向
#正确输出以及错误输出重定向至一个文件
[root@localhost ~]# useradd zj
[root@localhost ~]# su - zj
#将标准输出和标准错误输出重定向到不同文件
[zj@localhost ~]$ find /etc -name "*.conf" 1>a 2>b
-
4示例:正确和错误都输入到相同位置
#将标准输出和标准错误输出重定向到同一个文件, 混合输出
[zj@localhost ~]$ find /etc -name "*.conf" &>ab
#合并两个文件内容至一个文件
[zj@localhost ~]$ cat a b > c
-
5示例:重定向到空设备/dev/null
#将产生的任何数据放入黑洞设备,则视为丢弃。
[root@localhost ~]# ls /root /error >ab 2>/dev/null
[root@localhost ~]# ls /root /error >ab &>/dev/null
- 6示例:脚本中使用重定向
[root@localhost ~]# vim ping2.sh
ping -c1 10.0.0.1 &>/dev/null
if [ $? -eq 0 ];then
echo "10.0.0.1 is up." >>up.txt
else
echo "10.0.0.1 is down." >>down.txt
fi
[root@localhost ~]# chmod +x ping2.sh
[root@localhost ~]# ./ping2.sh
3.输入重定向
输入重定向,即原本从键盘等上获得的输入信息,重定向由命令的输出作为输入。< 等价 0<
- 从文件中读入输入的操作
[root@localhost ~]# echo "1231231" > 1.txt
[root@localhost ~]# cat 1.txt
1231231
[root@localhost ~]# cat >3.txt
12312
312312
123312
[root@localhost ~]# cat 3.txt
12312
312312
123312
- 两条命令同时重定向
[root@localhost ~]# ls; date &>/dev/null
[root@localhost ~]# ls &>/dev/null; date &>/dev/null
[root@localhost ~]# (ls; date) &>/dev/null
#后台执行
[root@localhost ~]# (while :; do date; sleep 2; done) &
[1] 6378
[root@localhost ~]# (while :; do date; sleep 2; done) &>date.txt &
[root@localhost ~]# jobs
[1]+ 运行中 ( while :; do date; sleep 2;
done ) &>/date.txt &
4.进程管道技术
- 什么是管道
管道操作符号 "|" ,主要用来连接左右两个命令, 将左侧的命令的标准输出, 交给右侧命令的标准输入
PS: 无法传递标准错误输出至后者命令
- 示例:统计当前/etc/passwd 中用户使用的 shell 类型
#思路:取出第七列(shell) | 排序(把相同归类)| 去重
[root@localhost ~]# awk -F: '{print $7}' /etc/passwd
[root@localhost ~]# awk -F: '{print $7}' /etc/passwd |sort
[root@localhost ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq
[root@localhost ~]# awk -F: '{print $7}' /etc/passwd |sort |uniq -c
-
管道中的tee技术
#选项: -a追加
[root@localhost ~]# ip addr |grep 'inet ' |tee ip.txt |awk -F"/" '{print $1}' |awk '{print $2}'
127.0.0.1
10.0.0.100
[root@localhost ~]# cat ip.txt
inet 127.0.0.1/8 scope host lo
inet 10.0.0.100/24 brd 192.168.69.255 scope global ens32
- xargs参数传递,主要让一些不支持管道的命令可以使用管道技术
# which cat|xargs ls- l
# ls |xargs rm -fv
# ls |xargs cp -rvt /tmp/ -或-> ls | xargs -I {} cp -rv {} /tmp/
# ls |xargs mv -t /tmp/ -或-> ls | xargs -I {} mv {} /tmp