我希望执行不同的命令并在之后检查返回代码,然后再转到脚本中的下一步。同时,我还希望使用 tee 命令将执行命令的输出记录到文件中。例子:
#set non-existing folder
local_path="~/njn"
log_path_file="test.log"
cmd="ls -l ${local_path} | tee -a ${log_path_file}";
eval ${cmd}
returncode=$?
echo "execution result: ${returncode}" | tee -a ${log_path_file};
if [ ${returncode} -eq 0 ]; then
echo "success" | tee -a ${log_path_file}
else
echo "not success" | tee -a ${log_path_file}
fi
returncode 是 0 应该是 > 0
我希望 returncode 变量具有已执行命令的实际返回(在本例中为 ls -l 命令。
我已经看到有一个解决方案使用文件将命令的输出写入其中,然后从中读取返回代码(此处),但我正在寻找更优雅的解决方案。
ls -l
在这种特殊情况下,直接执行并对其退出状态采取行动会更容易:在
bash
shell 中,您还可以调查PIPESTATUS
数组中的值:在你的情况下:
您可以使用将命令作为参数并将
tee
输出(stdout 和 stderr)作为日志文件的函数。经过一些额外的测试,我发现这个代码开关被很好地包装并返回了执行的命令返回代码。@Freddy 发布的代码已接近完成。返回码在函数内部导出,但不在函数外部导出。
shopt -s lastpipe 的使用取自此页面:Bash FAQ entry #24:“我在循环中设置变量。为什么它们在循环终止后突然消失?或者,为什么我不能通过管道读取数据? "
这是最终的工作解决方案: