linux 重定向 1>&2 2>&1

本文解释了Shell命令中>&1和>&2的区别,阐述了标准输出(STDOUT)和标准错误输出(STDERR)的关联以及如何通过重定向符号进行文件输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:http://zhumeng8337797.blog.163.com/blog/static/10076891420104215439296/


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


在 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这个文件中, 而不显示在前端. 

补充下, 输出不只1和2, 还有其他的类型, 这两种只是最常用和最基本的.

 

先看例子:

r2007@www r2007 $ (echo -n 123456;sleep 1;echo -n abc >&2;sleep 1;echo -n 789)>puzzle 2>puzzle  
r2007@www r2007 $ cat puzzle  
abc456789  
r2007@www r2007 $ (echo -n 123456;sleep 1;echo -n abc >&2;sleep 1;echo -n 789)>puzzle 2>&1  
r2007@www r2007 $ cat puzzle  
123456abc789  


为了强调每个输出都是step by step,所以加了sleep命令,其实可以省略。(echo ....)等同于一个cmd命令,在这里用一组echo命令是为了能清晰的看到整个操作过程。 
第一种用法实际上同时打开2次puzzle文件。过程如下: 
>puzzle ---- 打开puzzle文件(打开文件的操作会在核心中产生一个数据结构-假设叫做foo结构,其中有很多参数,比如file position-以下简称fp,就是其中之一),然后fd1(标准输出)保存着这个指针(具体结构没做深入分析,姑且简化为保存了一个指针),总而言之,通过fd1可以引用到这个核心中的数据结构。 
2>puzzle --- 基本同上,再次打开这个文件,核心中会产生一个新的数据结构,同时fd2(标准错误输出)保存了这个结构的指针。 
一开始,这两个foo结构中的fp都是0,第一个echo在puzzle文件写入了123456,同时fd1所指向的foo结构中的fp变为6,然后第二个echo要在puzzle文件写入abc,但是它得到的fp是fd2所指向的foo结构中的fp,所以仍然从文件头开始写,所以puzzle中的内容变为abc456,第三个echo就不再罗嗦一遍了,它是从6这个位置开始写操作的。

为什么cmd >file 2>&1这种模式就不会发生混乱呢? 
就是因为2>&1,不是再打开一次文件,而是fd2照抄fd1,这两个fd共用一个foo结构,所以它们使用的fp也是同一个。 

以下例子可以加深理解这个道理: 
(echo -n 123;sleep 1;echo -n abcde >&2;sleep 1;echo -n 789) >puzzle 2>puzzle  
结果:abc789



 

 (echo -n 123;sleep 1;echo -n abcdeghij >&2;sleep 1;echo -n 789) >puzzle 2>puzzle  
结果:abc789hij



对于编程我是个外行,其中如有错误的概念,欢迎指正。

cat x y 1> hold 2>&1

结果就是将标准+错误输出到hold;

cat x y 2>&1 1> hold
则是将错误输出重定向到标准输出,而将标准定向到hold。
所以错误输出不会进入hold,因为被定向到标准输出。

赋值关系 (1) 1 = hold , 2 = 1;
         (2) 2 = 1 , 1 = hold。
明白了?呵呵

为何2>&1要写在后面? 
      command > file 2>&1 
       首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。 
      command 2>&1 >file 
      2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。

用strace可以看到: 
1. command > file 2>&1 
这个命令中实现重定向的关键系统调用序列是: 
open(file) == 3 
dup2(3,1) 
dup2(1,2)

2. command 2>&1 >file 
这个命令中实现重定向的关键系统调用序列是: 
dup2(1,2) 

open(file) == 3 
dup2(3,1)


<think>好的,用户想了解Xshell中重定向命令2>&1的用法及相关问题。首先,我需要回忆一下Linux重定向的基础知识。2>&1的作用是将标准错误(stderr)重定向到标准输出(stdout)。在Xshell中执行命令时,用户可能希望将错误信息一起保存到文件或丢弃,这时候这个命令就派上用场了。 接下来,我需要结合用户提供的引用内容,特别是引用[2],其中解释了2>&1的含义,即文件描述符2(stderr)被重定向到文件描述符1(stdout)的位置。这有助于用户理解合并输出的机制。同时,用户可能遇到需要同时记录正常输出和错误信息的情况,比如脚本执行日志,这时候使用命令如command > log.txt 2>&1就能将所有输出写入同一文件。 然后,用户可能想知道具体的应用场景。例如,后台运行任务时如何忽略所有输出,这时候可以结合引用[2]提到的将输出重定向到/dev/null,并添加&在后台运行。此外,引用[4]中提到的scp命令使用,如果在脚本中使用可能需要处理错误输出,这里也可以应用2>&1来捕获错误。 还需要注意Xshell本身是一个终端模拟器,执行的是Linux命令,所以重定向的语法和Linux系统一致。用户可能混淆Xshell特有的功能,但实际上这里的重定向是Shell的功能,与Xshell无关。不过,用户可能在使用Xshell时遇到重定向问题,比如权限或路径错误,这时候需要检查文件路径和权限是否正确。 最后,整理步骤,从基本语法到常见场景,再到注意事项,确保用户能够逐步理解和应用这个命令。同时,生成相关问题帮助用户进一步学习,比如其他重定向符号或分离输出,这能引导用户深入探索Shell脚本中的高级技巧。</think>### Xshell中重定向命令`2>&1`的用法及场景 #### 一、基础语法解析 1. **标准输入/输出与文件描述符** - `0`:标准输入(键盘) - `1`:标准输出(屏幕) - `2`:标准错误输出(屏幕) 例如:执行`ls non_exist_file`时,错误信息通过文件描述符`2`输出到屏幕。 2. **`2>&1`的作用** - `2>&1`表示将标准错误输出(文件描述符`2`)重定向到标准输出(文件描述符`1`)的当前位置[^2]。 - 若标准输出已重定向到文件,则错误输出也会写入同一文件。例如: ```bash command > output.log 2>&1 # 所有输出(正常+错误)写入output.log ``` #### 二、常见使用场景 1. **日志记录** **需求**:将程序的所有输出(包括错误)保存到日志文件。 **实现**: ```bash ./script.sh > /var/log/script.log 2>&1 ``` **说明**:日志文件中会同时包含正常输出和错误信息。 2. **忽略所有输出** **需求**:后台运行程序且不保留任何输出。 **实现**: ```bash command > /dev/null 2>&1 & # 输出到“黑洞”设备并后台运行[^2] ``` 3. **管道操作中的错误处理** **需求**:将错误信息与正常输出一起传递给后续命令。 **实现**: ```bash command 2>&1 | grep "error" ``` #### 三、Xshell中的具体操作 1. **直接执行命令** 在Xshell终端中直接输入命令,例如: ```bash ping example.com > ping.log 2>&1 ``` 执行后,所有输出(包括网络错误)会保存到`ping.log`。 2. **结合远程操作** 若通过Xshell连接远程服务器(如使用SSH[^4]),重定向语法保持一致: ```bash ssh user@host "sudo apt update > update.log 2>&1" ``` #### 四、注意事项 1. **顺序问题** 重定向顺序影响结果。例如: ```bash command 2>&1 > file.log # 错误输出仍显示在屏幕 ``` 正确写法应为: ```bash command > file.log 2>&1 ``` 2. **权限与路径** - 确保目标文件可写(如使用`sudo`提升权限)。 - 避免路径错误(如写入到不存在的目录)。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值