来自:编程珠玑(微信号:shouwangxiansheng)

前言

有时候我们常看到类似这样的脚本调用:

./test.sh  > log.txt 2>&1

这里的2>&1是什么意思?该如何理解?
先说结论:上面的调用表明将./test.sh的输出重定向到log.txt文件中,同时将标准错误也重定向到log.txt文件中。

有何妙用

(如果已经明白是什么作用,可跳过此小节)
上面到底是什么意思呢?我们来看下面的例子,假如有脚本test.sh:

#!/bin/bash
date         #打印当前时间
while true   #死循环
do#每隔2秒打印一次sleep 2whatthis    #不存在的命令echo -e "std output"
done

脚本中先打印当前日期,然后每隔2秒执行whatthis并打印一段字符。由于系统中不存在whatthis命令,因此执行会报错。
假如我们想保存该脚本的打印结果,只需将test.sh的结果重定向到log.txt中即可:

./test.sh > log.txt

执行结果如下:

ubuntu$ ./test.sh >log.txt
./test.sh: 行 7: whatthis: 未找到命令

我们明明将打印内容重定向到log.txt中了,但是这条错误信息却没有重定向到log.txt中。如果你是使用程序调用该脚本,当查看脚本日志的时候,将会完全看不到这条错误信息。而使用下面的方式则会将出错信息也重定向到log.txt中:

./test.sh  > log.txt 2>&1

以这样的方式调用脚本,可以很好的将错误信息保存,帮助我们定位问题

如何理解

每个程序在运行后,都会至少打开三个文件描述符,分别是0:标准输入;1:标准输出;2:标准错误。
例如,对于前面的test.sh脚本,我们通过下面的步骤看到它至少打开了三个文件描述符:

./test.sh    #运行脚本
ps -ef|grep test.sh  #重新打开命令串口,使用ps命令找到test.sh的pid
hyb       5270  4514  0 19:20 pts/7    00:00:00 /bin/bash ./test.sh
hyb       5315  5282  0 19:20 pts/11   00:00:00 grep --color=auto test.sh

可以看到test.sh的pid为5270,进入到相关fd目录:

cd /proc/5270/fd   #进程5270所有打开的文件描述符信息都在此
ls -l              #列出目录下的内容0 -> /dev/pts/71 -> /dev/pts/72 -> /dev/pts/7255 -> /home/hyb/workspaces/shell/test.sh

可以看到,test.sh打开了0,1,2三个文件描述符。同样的,如果有兴趣,也可以查看其他运行进程的文件描述符打开情况,除非关闭了否则都会有这三个文件描述符。

那么现在就容易理解前面的疑问了,2>&1表明将文件描述2(标准错误输出)的内容重定向到文件描述符1(标准输出),为什么1前面需要&?当没有&时,1会被认为是一个普通的文件,有&表示重定向的目标不是一个文件,而是一个文件描述符。在前面我们知道,test.sh >log.txt又将文件描述符1的内容重定向到了文件log.txt,那么最终标准错误也会重定向到log.txt。我们同样通过前面的方法,可以看到test.sh进程的文件描述符情况如下:

 0 -> /dev/pts/71 -> /home/hyb/workspaces/shell/log.txt2 -> /home/hyb/workspaces/shell/log.txt255 -> /home/hyb/workspaces/shell/test.sh

我们可以很明显地看到,文件描述符1和2都指向了log.txt文件,也就得到了我们最终想要的效果:将标准错误输出重定向到文件中
它们还有两种等价写法:

./test.sh  >& log.txt
./test.sh  &> log.txt

总结

我们总结一下前面的内容:

  • 程序运行后会打开三个文件描述符,分别是标准输入,标准输出和标准错误输出。

  • 在调用脚本时,可使用2>&1来将标准错误输出重定向。

  • 只需要查看脚本的错误时,可将标准输出重定向到文件,而标准错误会打印在控制台,便于查看。

  • >>log.txt会将重定向内容追加到log.txt文件末尾。

  • 通过查看/proc/进程id/fd下的内容,可了解进程打开的文件描述符信息。

思考

下面的调用会将标准错误输出重定向到文件中吗?为什么?

./test.sh 2>&1 >log.txt

如何理解Linux shell中的“21”?相关推荐

  1. 如何理解Linux shell中的“2>1”(将文件描述2(标准错误输出)的内容重定向到文件描述符1(标准输出))(尼玛>符号竟然不支持搜索,害我搜搜不到,只能搜)

    文章目录 前言 有何妙用 如何理解 总结 前言 有时候我们常看到类似这样的脚本调用: ./test.sh > log.txt 2>&1 这里的2>&1是什么意思?该如 ...

  2. xshell是什么意思_深入理解Linux shell中21的含义(全网最全,看完就懂)

    A.首先了解下1和2在Linux中代表什么 在Linux系统中0 1 2是一个文件描述符 名称 代码 操作符 Java中表示 Linux 下文件描述符(Debian 为例) 标准输入(stdin) 0 ...

  3. linux重定向到某目录文件,linux shell中12 21 1file_path重定向语法详解

    当初在shell中, 看到">&1"和">&2"始终不明白什么意思.经过在网上的搜索得以解惑.其实这是两种输出. 在 shell 程 ...

  4. linux if else 格式,linux shell中 if else以及大于、小于、等于逻辑表达式

    在linux shell编程中,大多数情况下,可以使用测试命令来对条件进行测试,这里简单的介绍下,方便需要的朋友 比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示 ...

  5. linux shell bin sh,linux shell中#bin/sh的理解

    摘要 腾兴网为您分享:linux shell中#bin/sh的理解,支付旭尊,小熊到家,天天美剧,淘金宝等软件知识,以及维棠flv视频软件,usb抓包工具,红警2无敌,ucbug造梦西游4,壁纸工作室 ...

  6. linux shell中21的含义

    linux shell中"2>&1"的含义 2>&1 的意思就是将标准错误重定向到标准输出.这里标准输出已经重定向到了 /dev/null.那么标准错误 ...

  7. Linux shell中2>1的含义

    转载来源 :Linux shell中2>&1的含义 作者:一个行走的民 https://blog.csdn.net/zhaominpro/article/details/82630528 ...

  8. linux shell中的命令自动补全(compgen complete)与 命令行参数解析

    linux shell中的命令自动补全(compgen complete)与 命令行参数解析 标签: shell脚本 2013-12-31 21:56 6661人阅读 评论(6) 收藏 举报 分类: ...

  9. 会linux基本命令是脚本语言吗,如何理解Linux Shell和基本Shell脚本语言?

    理解Linux Shell: shell:一个命令行解释器,通过执行命令或脚本,帮助用户与操作系统打交道. process:进程,用户执行的任务是进程,但进程不只是任务. file:文件放在硬盘上,包 ...

  10. Linux shell中的一个问题 ${}带正则匹配的表达式

    目前在准备龙芯项目的PMON,在研究其编译过程的时候,看到一些make 语句,百思不得其解.后来在shell编程中看到一点资料,牵扯到Shell中的正则表达式.故记录下来,以备后来查阅. 问题: 在某 ...

最新文章

  1. 如何在Windows中安装Python?
  2. 刚刚!饶毅再次撰文,回应耿美玉,称其未遵守学术规范
  3. 微信公众平台开发(58)自定义菜单
  4. linux下听MP3
  5. 密码篇——对称加密—AES
  6. 《Linux命令行与shell脚本编程大全 第3版》高级Shell脚本编程---32
  7. mysql事务吞吐量_MySQL 5.5和MySQL 5.6的吞吐量测试
  8. 二叉查找树BST----java实现
  9. windows安装mongodb(快速简易版)
  10. Android 系统使用USB OTG功能/打开USB Host API功能
  11. asp.net 根据当前时间计算是否股票、期货、黄金交易日期
  12. 数据结构中的树 --- 红黑树
  13. 基于Pre-trained模型加速模型学习的6点建议
  14. 书单 | 月度畅销好书,助你技能满格,摆脱低效,走向财富人生
  15. JavaScript 逻辑与() 与 逻辑或(||) 运算规则
  16. 严数据结构c语言及答案,严蔚敏《数据结构(c语言版)习题集》全答案
  17. 计算机关于职业与道德的论文怎么写,计算机职业道德论文提纲模板 计算机职业道德论文大纲怎么写...
  18. 在linux下安装TPLINK无线网卡驱动
  19. Android实现查看预览PDF文件功能
  20. think PHP前台模板,thinkphp5(二)前台模板的引入

热门文章

  1. SQL Sever — 查询前10%的数据、查询并参与计算显示出数据、查询前10行数据、多重升序降序查询、去掉重复值、替换列名显示
  2. 安装包 — 夜神模拟器下载地址
  3. Perl语言入门14-17
  4. 【UVA11795】 Mega Man's Mission
  5. [HNOI2008]越狱(luogu P3197)
  6. idea 导入maven项目
  7. $SVN代码版本管理工具的使用
  8. C++全局函数与成员函数的区别
  9. 一个简单的EXCEL 导入SQL 的例子
  10. C++网络编程实例之多个客户端交互(多线程)