欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

shell里面用tee写log时return code问题

程序员文章站 2022-05-19 18:19:52
...

shell里面,常出现程序执行结果既要往终端输出,又要往log文件输出的情况,这时候一般都使用tee。

例如:

#!/bin/sh

command | tee -a out.txt

ST=$?

 

但是现在变量ST里设置的返回值是tee命令的返回值,而不是command的返回值, 所以出现即使command执行结果出错,可变量ST的值仍是正常0的情况。

 

解决办法是使用环境变量PIPESTATUS, 这个数组型变量里面存放用"|" 隔开的各个命令的执行结果。

上例是想取缔一个命令的执行结果,所以代码应该如下

#!/bin/sh

command | tee -a out.txt

ST=${PIPESTATUS[0]}

 

相关标签: linux shell