1>&2 2>&1 的含义

在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是: 

0: Standard Input (STDIN) 

1: Standard Output (STDOUT) 

2: Standard Error Output (STDERR) 

在标准情况下, 这些FD分别跟如下设备关联: 

stdin(0): keyboard  键盘输入,并返回在前端 

stdout(1): monitor  正确返回值 输出到前端 

stderr(2): monitor 错误返回值 输出到前端 

举例说明吧: 

当前目录只有一个文件 a.txt. 

[root@redhat box]# ls 

a.txt 

[root@redhat box]# ls a.txt b.txt          

ls: b.txt: No such file or directory     由于没有b.txt这个文件, 于是返回错误值, 这就是所谓的2输出 

a.txt     而这个就是所谓的1输出 

再接着看: 

[root@redhat box]# ls a.txt b.txt  1>file.out 2>file.err 

执行后,没有任何返回值. 原因是, 返回值都重定向到相应的文件中了,而不再前端显示 

[root@redhat box]# cat file.out 

a.txt 

[root@redhat box]# cat file.err 

ls: b.txt: No such file or directory 

一般来说, "1>" 通常可以省略成 ">". 

即可以把如上命令写成: ls a.txt b.txt  >file.out 2>file.err 

有了这些认识才能理解 " 1>&2 " 和 " 2>&1 ". 

1>&2   正确返回值传递给2输出通道 &2表示2输出通道 

如果此处错写成 1>2, 就表示把1输出重定向到文件2中. 

2>&1  错误返回值传递给1输出通道, 同样&1表示1输出通道. 

举个例子. 

[root@redhat box]# ls a.txt b.txt 1>file.out  2>&1  

[root@redhat box]# cat file.out 

ls: b.txt: No such file or directory 

a.txt 

现在, 正确的输出和错误的输出都定向到了file.out这个文件中, 而不显示在前端.

文章来自:http://chenyubo.iteye.com/blog/321616

<think>好的,用户现在问的是关于shell中的重定向操作符2>&-和2>&1。我之前已经回答过关于install命令的问题,现在需要处理这两个重定向符号的区别和用法。首先,我需要回忆这两个符号的具体含义,确保自己理解正确。 首先,用户可能是在编写脚本或者命令行操作时遇到了输出重定向的问题,特别是关于标准错误(stderr)的处理。这两个符号看起来相似,但功能不同,容易混淆。用户需要明确它们的区别,以便正确使用。 接下来,我需要拆解这两个符号。2>&-是关闭标准错误输出,而2>&1是将标准错误重定向到标准输出的位置。需要分别解释它们的用途和典型场景。 对于2>&-,要说明它如何关闭文件描述符2(stderr),这在需要完全禁止错误输出时使用,比如在后台运行脚本时不想记录任何错误信息。但需要注意关闭后,任何尝试写入stderr的操作都会失败,可能导致程序异常终止,所以使用时需要谨慎。 然后是2>&1,这是将stderr合并到stdout,这样错误信息可以和普通输出一起被重定向到文件或管道。这在需要同时捕获或记录所有输出时非常有用。例如,使用command > output.log 2>&1将stdout和stderr都写入同一个日志文件。 用户可能的混淆点在于这两个符号的相似写法但不同的效果,需要对比说明。同时,需要提醒用户注意顺序问题,比如在重定向时的顺序会影响结果,比如command > file 2>&1和command 2>&1 > file的区别。 此外,用户可能想知道实际应用中的例子,比如在脚本中的使用场景,或者如何调试相关问题。比如,当需要忽略所有错误输出时使用2>&-,或者需要将错误和正常输出一起处理时使用2>&1。 还要考虑用户的使用环境,是否在Linux/Unix环境下,使用哪种shell(比如bash、zsh等),虽然大多数情况下这些重定向操作符的行为是一致的,但最好还是确认一下。 另外,用户可能没有明确说出他们的具体问题,但可能遇到了因为错误使用这些符号导致的脚本错误,比如关闭了stderr后程序崩溃,或者没有正确合并输出导致日志不全。因此,在回答时需要指出潜在的问题和注意事项。 最后,总结这两个操作符的区别,用表格或对比的方式帮助用户快速理解,并给出使用建议,比如何时使用哪一个,以及常见的错误用法。</think>在 Shell 脚本中,`2>&-` 和 `2>&1` 都是与标准错误流(stderr,文件描述符 2)相关的重定向操作符,但它们的用途和效果截然不同。以下是详细对比: --- ### **核心概念** | 表达式 | 文件描述符关系 | 本质行为 | 典型场景 | |-----------|---------------------|-----------------------------|-----------------------------| | `2>&-` | 关闭 stderr 通道 | 完全禁用错误输出 | 静默模式运行,忽略所有错误 | | `2>&1` | 合并到 stdout 通道 | 将错误输出重定向到标准输出 | 统一捕获/记录所有输出信息 | --- ### **逐项解析** #### **1. `2>&-`(关闭标准错误)** - **作用原理** 关闭文件描述符 2(stderr),使程序无法输出错误信息 - **效果示例** ```bash # 尝试列出不存在的文件,并关闭错误输出 ls /non-existent 2>&- # 终端不会有任何错误提示(包括 "No such file...") ``` - **注意事项** - 被关闭的流若尝试写入会触发错误(`Bad file descriptor`) - 可能导致程序异常终止(若依赖错误输出功能) #### **2. `2>&1`(合并错误到标准输出)** - **作用原理** 将 stderr(文件描述符 2)重定向到 stdout(文件描述符 1)的当前位置 - **效果示例** ```bash # 将正常输出和错误输出都写入 log.txt command > log.txt 2>&1 # 实时查看混合输出(例如配合管道) command 2>&1 | grep "error" ``` - **顺序敏感性** ```bash # 错误写法:只会重定向 stdout command 2>&1 > log.txt # stderr 仍输出到终端 # 正确写法:先重定向 stdout,再合并 stderr command > log.txt 2>&1 ``` --- ### **对比实验** ```bash # 实验 1:关闭错误输出 $ ls /non-existent 2>&- # 无任何输出 # 实验 2:合并错误到标准输出 $ ls /non-existent > output.txt 2>&1 $ cat output.txt ls: cannot access '/non-existent': No such file or directory # 实验 3:错误顺序导致的问题 $ ls /non-existent 2>&1 > output.txt ls: cannot access '/non-existent': No such file or directory # 错误仍然显示在终端 ``` --- ### **使用建议** | 场景 | 推荐操作 | 说明 | |-------------------------------|-------------------------|------------------------------------------| | 后台服务静默运行 | `command 2>&- &` | 完全忽略错误输出(需确保程序健壮性) | | 日志记录 | `command > log 2>&1` | 统一记录正常输出和错误信息 | | 实时调试 | `command 2>&1 | less` | 在分页器中同时查看两种输出 | | 临时屏蔽错误 | `command 2>&- || true` | 忽略错误并保证后续命令执行 | --- ### **扩展知识** 1. **文件描述符继承** 子进程会继承父进程打开的文件描述符,使用 `2>&-` 可主动关闭不需要的通道 2. **特殊设备文件** ```bash # 将错误输出发送到"黑洞" command 2>/dev/null # 完全静默模式(推荐替代 2>&- 的方案) command &>/dev/null # Bash 简写 command >/dev/null 2>&1 ``` 3. **诊断技巧** ```bash # 查看文件描述符状态 ls -l /proc/$$/fd # $$ 表示当前 shell 的 PID ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值