我试图使用nohup
调用函数,如下所示:
function1(){
while true
do
echo "function1"
sleep 1
done
}
nohup function1 &
# ...... some other code
但可能是nohup
看不到的功能,我收到此错误:
nohup: failed to run command `function1' : No such file or dictionary
我不想为我的函数创建新的sh文件。我怎样才能解决这个问题?
另一种方案:
function background {
echo TEST
}
export -f background
nohup bash -c background &
nohup
适用于命令而不适用于脚本函数。
例如,包含function1()的脚本(比如func.sh)应该调用函数 - :
function1(){
while true
do
echo "function1"
sleep 1
done
}
function1
现在在后台使用nohup
调用脚本func.sh-:
nohup ./func.sh &
如果您需要从脚本中禁用挂起信号,请使用shell内置的trap
。该示例忽略SIGHUP,但可用于忽略其他(例如SIGINT)。
trap "" HUP # script will ignore HANGUP signal
我找到了一个有效的解决方案 - 在文件中定义函数(例如.functions
)然后用nohup运行函数:
nohup bash -c "source .functions; function1" &
在Ubuntu 13.04上测试过。
由于nohup
必须提供文件名而不是函数作为解决方法,这是可以做到的:
function1(){
while true
do
echo "function1"
sleep 1
done
}
echo "$@" | grep -q -- "--nohup" && function1 || nohup $0 "$@" --nohup &
因此,当使用当前参数调用此脚本时:
`echo "$@" | grep -q -- "--nohup"
将返回错误状态nohup $0 "$@" --nohup &
,它将调用此脚本传递当前参数和新参数--nohup
当使用参数--nohup
调用此脚本时
`echo "$@" | grep -q -- "--nohup"
将返回零状态(成功)function1
是的!它可能是棘手的,严格的bash> v2兼容:
function1(){ local msg=${*:-function1}; echo msg=$msg; }
nohup -- sh -c "$(typeset -f function1); function1 MESSAGE" >nohup.log 2>&1 0</dev/null &
并且不要忘记“排版”是bash弃用赞成“声明”(虽然我不完全同意这一点)。
您可以实现相同的结果,而不是使用为文件定制的nohup:
(trap '' HUP INT
while true
do
echo "function1"
sleep 1
done
) </dev/null 2>&1 1>nohup.out &
由于我倾向于从父脚本启动这些进程,如果父进程被中断,父脚本可能会执行其他工作,我希望子进程忽略INT信号并继续运行。