我有一个主脚本是作为服务启动的。
我不能修改这个主脚本,因为它经常被更新。
这个主脚本启动一个程序,将任何日志回送到stdout。
所以我看不到这个程序的任何日志。
但是这个主脚本在一开始调用一个钩子脚本,我可以修改它。
如果我将stdout重定向到这个钩子脚本中的一个文件,它对那个脚本有效,但对主脚本无效。
是否可以更改整个过程的标准输出?
主要(谜2.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
...
钩子(enigma2_pre_start.sh)
exec > /tmp/`date +"%s"`.log
exec 2> /tmp/`date +"%s"`_error.log
编辑:
启动主流程后,是否可以将三通(或类似)连接到主流程?
我知道主脚本只运行一次。这样我就可以用ps获取进程id。
最佳答案
您必须源代码enigma_pre_start.sh
而不是执行它,以便exec
命令在要更改其文件句柄的同一进程中运行。
if [ -x enigma2_pre_start.sh ]; then
. enigma2_pre_start.sh
fi
否则,您将重定向执行钩子脚本的进程的标准输出和错误,一旦脚本完成,钩子脚本就会退出。