1.重定向概述
1.什么是重定向
将原本要输出到屏幕的数据信息,重新定向到某个指定的文件中。比如:每天凌晨定时备份数据,希望将备份数据的结果保存到某个文件中。这样第二天通过查看文件的内容就知道昨天备份的数据是成功还是失败。
2.为何要使用重定向
1.当屏幕输出的信息很重要,而且希望保存重要的信息时;
2.后台执行中的程序,不希望他干扰屏幕正常的输出结果时;
3.系统的例行命令, 例如定时任务的执行结果,希望可以存下来时;
4.一些执行命令,我们已经知道他可能出现错误信息, 想将他直接丢弃时;
5.错误日志与正确日志需要分别输出至不同的文件保存时;
3.学习重定向的预备知识,标准输入与输出
当运行一个程序时通常会自动打开三个标准文件,分别是标准输入、标准输出、错误输出
名称 | 文件描述符 | 作用 |
---|---|---|
标准输入(STDIN) | 0 | 默认是键盘,也可以是文件或其他命令的输出。 |
标准输出(STDOUT) | 1 | 默认输出到屏幕。 |
错误输出(STDERR) | 2 | 默认输出到屏幕。 |
文件名称(filename) | 3+ |
进程将从标准输入中得到数据,将正常输出打印至屏幕终端,将错误的输出信息也打印至屏幕终端。
PS: 进程是使用文件描述符(file descriptors)
来管理打开的文件
以 cat 命令为例, cat 命令的功能是从命令行给出的文件中读取数据,并将这些数据直接送到标准输出。若使用如下命令:
1 | #会把文件/etc/passwd的内容输出显示到屏幕上 |
但如果 使用 cat 命令没有跟上输入的文件名,那么cat命令则会通过命令行标准输入中读取数据, 并将其送到标准输出。
1 | [root@lqz ~]# cat |
下面了解一下标准输入输出过程
1 | #持续追踪查看文件内容 |
2.输出重定向
输出重定向,改变输出内容的位置。输出重定向有如下几种方式,如表格所示
类型 | 操作符 | 用途 |
---|---|---|
标准覆盖输出重定向 | > | 将程序输出的正确结果输出到指定的文件中,会覆盖文件原有的内容 |
标准追加输出重定向 | >> | 将程序输出的正确结果以追加的方式输出到指定文件,不会覆盖原有文件 |
错误覆盖输出重定向 | 2> | 将程序的错误结果输出到执行的文件中,会覆盖文件原有的内容 |
错误追加输出重定向 | 2>> | 将程序输出的错误结果以追加的方式输出到指定文件,不会覆盖原有文件 |
标准输入重定向 | << | 将命令中接收输入的途径由默认的键盘更改为指定的文件或命令 |
案例1: 标准输出重定向(每次都会覆盖文件)
1 | #标准输出重定向, 先清空,后写入, 如果文件不存在则创建 |
案例2: 标准输出重定向(会往文件的尾部在添加内容)
1 | #标准追加输出重定向, 向配置文件末尾追加内容 |
案例3: 错误输出重定向
1 | #正确输出以及错误输出重定向至一个文件 |
案例4: 正确和错误都输入到相同位置
1 | #将标准输出和标准错误输出重定向到同一个文件, 混合输出 |
案例5: 正确和错误都输入到相同位置
1 | #重定向到相同的位置 |
案例6: 重定向到空设备/dev/null
1 | #将产生的任何数据放入黑洞设备,则视为丢弃。 |
案例7: 脚本中使用重定向 (了解即可)
1 | [root@lqz ~]# vim ping.sh |
案例8: 脚本中使用重定向 (了解即可)
1 | [root@lqz ~]# vim ping2.sh |
3.输入重定向
输入重定向,即原本从键盘等上获得的输入信息,重定向由命令的输出作为输入。< 等价 0<
案例1: 从文件中读入输入的操作
1 | #没有改变输入的方向,默认键盘 |
案例2: 无法形容案例,请看实际操作
1 | #没有改变输入的方向,默认键盘,此时等待输入 |
案例3: 无法形容案例,请看实际操作
1 | [root@lqz ~]# dd if=/dev/zero of=/file1.txt bs=1M count=20 |
案例4: mysql如何恢复备份,了解即可,不用关注。
1 | [root@lqz ~]# mysql -uroot -p123 < bbs.sql |
案例5: 利用重定向建立多行数据的文件
1 | #手动执行 shell 命令 |
案例6: 脚本中打印菜单的一种使用方法。
1 | [root@lqz ~]# vim vm.sh |
案例7: 两条命令同时重定向
1 | [root@lqz ~]# ls; date &>/dev/null |
扩展点: subshell 了解即可
1 | [root@lqz ~]# cd /boot; ls |
4.进程管道技术
1.什么是管道
管道操作符号 “|” ,主要用来连接左右两个命令, 将左侧的命令的标准输出, 交给右侧命令的标准输入
PS: 无法传递标准错误输出至后者命令
2.管道流程示意图
格式: cmd1 | cmd2 [...|cmdn]
3.管道使用案例
案例1: 将/etc/passwd 中的用户按 UID 大小排序
1 | [root@lqz ~]# sort -t":" -k3 -n /etc/passwd |
案例2: 统计当前/etc/passwd 中用户使用的 shell 类型
1 | #思路:取出第七列(shell) | 排序(把相同归类)| 去重 |
案例4: 统计网站的访问情况 top 20
1 | #思路: 打印所有访问的连接 | 过滤访问网站的连接 | 打印用户的 IP | 排序 | 去重 |
案例5: 打印当前所有 IP
1 | [root@lqz ~]# ip addr |grep 'inet ' |awk '{print $2}' |awk -F"/" '{print $1}' |
案例6: 打印根分区已用空间的百分比(仅打印数字)
1 | [root@lqz ~]# df |grep '/$' |awk '{print $5}' |awk -F"%" '{print $1}' |
PS: 管道命令符能让大家能进一步掌握命令之间的搭配使用方法,进一步提高命令输出值的处理效率。
4.管道中的tee技术
1 | #选项: -a追加 |
重定向与 tee 有他们在使用过程中有什么区别
1 | [root@lqz ~]# date > date.txt #直接将内容写入date.txt文件中 |
5.xargs参数传递,主要让一些不支持管道的命令可以使用管道技术
1 | # which cat|xargs ls- l |
点击上方按钮,请我喝杯咖啡!
扫描二维码,分享此文章