IO重定向及管道操作

程序是由指令+数据组成的。换言之,程序是对读入的数据进行处理,再输出数据。数据的输入(Input),输出(Output),简称为IO,在没有指定输入输出的情况下,默认为标准输入和标准输出。打开的文件都有一个文件描述符(fd: file descriptor)表现为一个数字

  • 标准输入:keyborad(键盘), 文件描述符:0
  • 标准输出:monitor(显示屏), 文件描述符:1
  • 标准错误输出:monitor, 文件描述符:2

I/O重定向:改变标准输入与输出的默认位置

标准输出重定向

输出重定向:COMMAND > NEW_POS, COMMAND >> NEW_POS

  • >:覆盖重定向,目标文件中的原有内容会被清除;
  • >>: 追加重定向,新内容会追加至目标文件尾部;
[root@senlong ~]# ls /etc > /tmp/etc.out

注意:覆盖文件内容具有风险

[root@senlong ~]# set -C # 禁止将内容覆盖输出至已有文件中
[root@senlong ~]# ls /etc > /tmp/etc.out
-bash: /tmp/etc.out: cannot overwrite existing file
[root@senlong ~]# ls /etc >| /tmp/etc.out # 强制覆盖
[root@senlong ~]# set +C # 允许将内容覆盖输出至已有文件中

标准错误输出重定向

  • 2>: 覆盖重定向错误输出数据流;
  • 2>>: 追加重定向错误输出数据流;

标准输出和错误输出各自定向至不同位置: COMMAND > /path/to/file.out 2> /path/to/error.out 这种写法会创建两个文件,一个为空

合并标准输出和错误输出为同一个数据流进行重定向:只会生成一个文件

  • &>:覆盖重定向
  • &>>:追加重定向
[root@senlong tmp]# echo $PATH &> /tmp/path.out

标准输入重定向

输入重定向:<

tr命令:转换或删除字符 默认接受键标准输入(键盘输入)

[root@senlong tmp]# tr abc ABC # 将abc转成ABC
hello
hello
alpha  
AlphA
[root@senlong tmp]# cat test
hello world
[root@senlong tmp]# tr eo EO < ./test
hEllO wOrld

HERE Documentation:<< 创建文档

  • cat << EOF
  • cat > /path/to/somefile << EOF
[root@senlong tmp]# cat << EOF
> how are you?
> how old are you?
> EOF
how are you?
how old are you?
[root@senlong tmp]# cat >> /tmp/test.out << EOF
> how are you?
> how old are you?
> EOF
[root@senlong tmp]# cat /tmp/test.out 
how are you?
how old are you?

tee命令

同时在显示屏和文件中输出:一路输入,两路输出

tee [OPTION]... [FILE]...

[root@senlong tmp]# tee /tmp/tee.out
hello
hello
world
world
[root@senlong tmp]# cat /tmp/tee.out 
hello
world

管道 |

COMMAND1 | COMMAND2 | COMMAND3 |...

Note:最后一个命令会在当前shell进程的子shell进程中执行;

[root@senlong tmp]# echo $PATH | tr 'a-z' 'A-Z'
/USR/LIB/GOLANG/BIN/LINUX_AMD64:/USR/LOCAL/SBIN:/USR/LOCAL/BIN:/SBIN:/BIN:/USR/SBIN:/USR/BIN:/ROOT/BIN:/USR/LOCAL/GIT/BIN:/ROOT/BIN
[root@senlong tmp]# echo $PATH | tr 'a-z' 'A-Z' | tr -d 'U'
/SR/LIB/GOLANG/BIN/LINX_AMD64:/SR/LOCAL/SBIN:/SR/LOCAL/BIN:/SBIN:/BIN:/SR/SBIN:/SR/BIN:/ROOT/BIN:/SR/LOCAL/GIT/BIN:/ROOT/BIN

练习

1.将/etc/passwd文件中的前5行内容转换为大写后保存至/tmp/passwd.out文件中

[root@senlong tmp]# head -n 5 /etc/passwd | tr 'a-z' 'A-Z' > /tmp/passwd.out
[root@senlong tmp]# cat /tmp/passwd.out 
ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH
BIN:X:1:1:BIN:/BIN:/SBIN/NOLOGIN
DAEMON:X:2:2:DAEMON:/SBIN:/SBIN/NOLOGIN
ADM:X:3:4:ADM:/VAR/ADM:/SBIN/NOLOGIN
LP:X:4:7:LP:/VAR/SPOOL/LPD:/SBIN/NOLOGIN

2.将登录至当前系统上用户信息中的后3行的信息转换为大写后保存至/tmp/who.out文件中

[root@senlong tmp]# who | tail -n 3 | tr 'a-z' 'A-Z' > /tmp/who.out
[root@senlong tmp]# cat /tmp/who.out 
ROOT     PTS/0        2017-01-16 17:05 (10.0.2.2)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大内老A

[WCF权限控制]从两个重要的概念谈起:Identity与Principal[上篇]

在安全领域,认证和授权是两个重要的主题。认证是安全体系的第一道屏障,守护着整个应用或者服务的第一道大门。当访问者叩门请求进入的时候,认证体系通过验证对方提供凭证...

1949
来自专栏派森公园

docker的reap问题

在使用docker容器的时候,应该了解“PID1僵尸进程reap”问题。如果使用的时候不加注意,可能会导致出现一些意想不到的问题。

893
来自专栏猿人谷

Oracle RAC基本维护指令

所有实例和服务的状态 $ srvctl status database -d orcl Instance orcl1 is running on node l...

1947
来自专栏Seebug漏洞平台

Vivotek 摄像头远程栈溢出漏洞分析及利用

近日,Vivotek 旗下多款摄像头被曝出远程未授权栈溢出漏洞,攻击者发送特定数据可导致摄像头进程崩溃。

4467
来自专栏Laoqi's Linux运维专列

每日shell练习题

2682
来自专栏信安之路

利用DNS协议回显数据

这个问题已经是去年提出的了,之前也看到过,在 CTF 题目环境中利用过却对原理不慎了解,在公司大佬们的帮助下成功了理解了一波原理。

600
来自专栏乐沙弥的世界

MySQL 用户与权限管理

    MySQL权限系统的主要功能是证实连接到一台给定主机的用户,并且赋予该用户在数据库上的相关DML,DQL权限。MySQL存取控制包含2个阶段,一是服务器...

621
来自专栏安富莱嵌入式技术分享

【安富莱】【RL-TCPnet网络教程】第10章 RL-TCPnet网络协议栈移植(FreeRTOS)

本章教程为大家讲解RL-TCPnet网络协议栈的FreeRTOS操作系统移植方式,学习了第6章讲解的底层驱动接口函数之后,移植就比较容易了,主要是添加库文件、配...

722
来自专栏比原链

Derek解读Bytom源码-启动与停止

Gitee地址:https://gitee.com/BytomBlockchain/bytom

873
来自专栏Java成神之路

Saiku_学习_02_Schema Workbench 开发mdx和模式文件

saiku的查询都是通过cube来进行的。因此每当我们要进行一次多维度查询时,都要先修改xml、上传、重启才能生效,不仅效率低,还不利于学习和理解MDX和模式文...

774

扫码关注云+社区