gpt4 book ai didi

linux - 在下标中使用 exec 重定向标准输出

转载 作者:太空宇宙 更新时间:2023-11-04 10:51:17 27 4
gpt4 key购买 nike

我有一个作为服务启动的主脚本。

我不能修改这个主脚本,因为它经常更新。该主脚本启动一个程序,将任何日志回显到标准输出。

所以我看不到这个程序的任何日志。

但是这个主脚本在开始时调用了一个钩子(Hook)脚本,我可以修改它。

如果我将标准输出重定向到这个钩子(Hook)脚本中的一个文件,它适用于该脚本,但不适用于主脚本。

是否可以更改整个过程的标准输出?

主要(enigma2.sh):

# hook to execute scripts always before enigma2 start
if [ -x enigma2_pre_start.sh ]; then
enigma2_pre_start.sh
fi

...

#this logs to stdout
/usr/bin/enigma2

...

钩子(Hook)(enigma2_pre_start.sh)

exec > /tmp/`date +"%s"`.log
exec 2> /tmp/`date +"%s"`_error.log

编辑:

是否有可能在主进程启动后附加一个 tee(或类似的)?我知道主脚本只运行一次。所以我可以用 ps 获取进程 ID。

最佳答案

您必须获取 enigma_pre_start.sh 而不是执行它,以便 exec 命令在您要更改其文件句柄的同一进程中运行。

if [ -x enigma2_pre_start.sh ]; then
. enigma2_pre_start.sh
fi

否则,您将重定向执行 Hook 脚本的进程的标准输出和错误,该脚本会在脚本完成后立即退出。

关于linux - 在下标中使用 exec 重定向标准输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30909640/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com