> 输出重定向

  • 重定向输出 >

  • >> 追加

目 录

  • 1、 >正确定向等同于1>

  • 2、 2> 错误定向

  • 3. &> 把错误导成正确的{洗钱}

  • 4. 正确的变成错误的

  • 5. > 覆盖

  • 6. 举一反三

最近学的命令中学到了一些很有意思的命令,分享一下j_0047.gif


重定向输出

最初见到这个符号是在学习终端的时候,那么各个终端之间是如何交流的呢?那么就用到了这个符号>

在这里采取的是远程控制的方法,所以以虚拟终端为例

对于两个终端 dev/pts/0   /dev/pts/1

设备dev/pts/0给设备/dev/pts/1发出Hello

在设备/dev/pts/0上发出命令     echo Hello! > /dev/pts/1

wKiom1l0KhaiIMYhAAAZiXxn23o719.png

那么便在设备/dev/pts/1上收到消息Hello!(类似于qq消息中的私聊)

wKioL1l0KiXTPs2XAAAYE8d23Cw935.png

还有另一种广播的方式

wall Hi

每个终端都会收到打招呼 Hi(类似于qq消息中的群发)。很有意思吧,可以试一下。j_0007.gif

1、 > 正确定向等同于 1>

我们一般键盘输入信息,输出的结果都是默认在终端上输出

查看I/O 设备

cd /dev/fd/

ls –l

0  标准输入 (默认输入来自键盘)

1  标准输出  (默认输出都是终端)    

2  标准错误  (默认输出都是终端)

那么当我们不想输出在终端上,想导出一个文件,方便以后查看,便需要输出重定向了。的作用就是把原本要输出在终端上的信息重定向导出到指定的地方。

我们知道/etc/passwd 存放着我们用户登录的信息,而/app/passwd 这个是不存在的,我们就以这两个为例子,终端还是dev/pts/0   /dev/pts/1

单独查看会显示一下结果

ls /app/passwd  /etc/passwd

wKiom1l0KkST7eWvAAAkzkI85dc418.png

 ls /app/passwd /etc/passwd > /dev/pts/1

wKiom1l0Kq7RQuDLAAAwCzs5Z1M444.png

wKiom1l0Kr-A4C8jAAAWgIkYd4E468.png

结论: 可以看出在/dev/pts/0 上只显示出错误的结果,因为/dev/pts/0把正确结果重定向输出到/dev/pts/1    > 只导出了正确的结果

2、  > 错误定向

还是相同的例子           

 ls /app/passwd /etc/passwd  2> dev/pts/1

wKiom1l0KxihAU8EAAAjQcYzFBs767.png

wKiom1l0KyexbCJMAAA0o-pGDHU711.png

结论:可以看出可以看出在/dev/pts/0上只显示出正确的结果,/dev/pts/0把错误结果重定向输出到/dev/pts/1    2> 只导出了错误的结果

那么有把正确和错误的都输出去吗,当然可以

3、  &> 把错误导成正确的{洗钱}

(1)   ls /app/passwd /etc/passwd > dev/pts/1  2>&1(老一代)

wKioL1l0K-aRV_eyAAAjC1vkKyg478.png

wKiom1l0K_qDGASqAAArSOYhXK0266.png

结论:可以看出在/dev/pts/0上不显示,/dev/pts/0把全部重定向输出到/dev/pts/12>&1 一般在老版本的CentOS上用,接下来的是在新的版本上才有的。

(2)  ls /app/passwd /etc/passwd  &> /dev/pts/1

 wKiom1l0LAnDGM11AAAi-TvBBUM521.png

wKioL1l0LDLCu1WVAAAmQq-WFfs351.png

4、当然还可以把正确的变成错误的

ls /app/passwd/etc/passwd > dev/pts/1  1>&2

wKiom1l0LKmiKENpAAAzaIBiLwY469.png

把正确的变成错误的都显示出来

5、 >  覆盖      

 (1)  例:  > a.txt  =touch a.txt 创建新文件a.txt

wKiom1l0LPeBlOJQAAAaw-UO4Nc135.png

 (2)  当已有文件存在时会怎样呢??

现在就以a.txt为例,首先我们在a.txt中写入内容Hello

echo Hello >a.txt

wKioL1l0LQKyfJj3AAAYcoruVYs346.png

然后我们再将Hi apple!以同样的方式再写一遍

echo Hi apple>a.txt

wKiom1l0LRDCmAxHAAAZcNN-lHI126.png

3)那么我们现实中必定会有不想覆盖的文件,而我们想要继续在原文件后面追加,那么便需要>>了。

在后面追加Hello water

echo Hello water >>a.txt

wKioL1l0LRzxwoL7AAAnU2dYmbE809.png

(4)如果在工作中,我们想要在文件中追加内容时>>,却不小心只写入就执行了,那么我们的文件被覆盖了,因此就有了,禁止覆盖的命令,set –C

让我们试一下吧,首先输入set–C 然后再输入覆盖命令

wKioL1l0LVaitG25AAAq1GInvpE718.png

如果我们想一次强制覆盖   >|

wKioL1l0LWLBeN8yAAAeK4DRag0043.png

当然我们也可以解除这种禁止 set +C ,很好理解禁止 –C  ,解除+C

wKiom1l0LW7SuJl-AAAosanxveM971.png

6、当然可以举一反三

>>  追加正确的内容

2>> 追加错误的内容

&>> 全部追加

() 合并 echo abc ;echo 123> b.txt 可以一次显示两条信息

wKioL1l0LXqR_3zhAAAbymwZx64057.png

结合以前所学的符号,命令,都会有新的发现。大家可以共同探讨。

原创文章,作者:guanman,如若转载,请注明出处:http://www.178linux.com/84711

(0)
guanmanguanman
上一篇 2017-08-13
下一篇 2017-08-13

相关推荐

  • bash脚本循环语句用法练习

    bash脚本循环语句用法练习 1、使用循环语句写一个脚本,实现打印出来国际象棋的棋盘 #方法1:使用until循环语句实现 [root@liang7 bin]# cat chess-until.sh  #!/bin/bash #Author:liang #Version:1.0 #Description:Print&n…

    Linux干货 2016-08-24
  • 使用mysql-mmm实现高可用mysql读写分离

    MMM介绍:  MMM全称为Multi-Master Replication Manager for MySQL,即为主主复制管理器;根据MMM官网介绍,其工作原理类似于lvs,都是利用vip地址;但lvs只有一个组件便可以正常工作,而MMM则使用三个组件,分别是mysql-mmm、mysql-mmm-agent、mysql-mmm-monitor…

    Linux干货 2015-08-04
  • N22-Dexter-第二周博客作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示?    Linux上的文件管理类命令有cp,rm,mv    cp命令:copy    常用选项:       -i:交互式复制,即覆盖之前提醒用户确认;     &nbsp…

    Linux干货 2016-08-24
  • 编写脚本

        1、  编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPV4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。                      …

    2017-04-13
  • Linux用户与权限管理

    由于Linux是多用户、多任务系统,出于一些需要,当我们创建的文件希望对一部分用户开放,对一部分用户隐藏的时候应该怎么办呢?这样的话,就需要涉及到Linux系统中对用户以及对文件权限的管理。 一、相关文件 在Linux中,一切配置文件都是以文本文档的方式来保存的,同样用户的信息也保存在系统的一些文件中,其位置为/etc/passwd。此文件只有root用户具…

    Linux干货 2016-08-05
  • Linux下常用安全策略设置的六个方法

    安全第一”对于linux管理界乃至计算机也都是一个首要考虑的问题。加密的安全性依赖于密码本身而非算法!而且,此处说到的安全是指数据的完整性,由此,数据的认证安全和完整性高于数据的私密安全,也就是说数据发送者的不确定性以及数据的完整性得不到保证的话,数据的私密性当无从谈起! 1. 禁止系统响应任何从外部/内部来的ping请求攻击者一般首先通过ping命令检测此…

    Linux干货 2017-07-31