该脚本具有执行重新运行主机脚本的函数的陷阱,但执行两次。
#!/bin/bash
LOCK="/tmp/performanceScript.lock"
exec_func () {
#Creando Script de Vida Eterna.
rm -f $LOCK
cd $( dirname '${BASH_SOURCE[0]}' )
echo "Volvio a la vida" >> /tmp/secuancia_performanceScript.log
$( which bash ) performanceScript2.sh &
exit $?
}
secuencia=0
if (set -o noclobber; echo $$ > "$LOCK") 2> /dev/null;
then
trap 'exec_func' INT TERM EXIT SIGKILL
while true; do
echo "El numero es $secuencia" >> /tmp/secuancia_performanceScript.log
((secuencia++))
sleep 1
done
rm -f $LOCK
trap - INT TERM EXIT
else
echo "ya se está ejecutando: $(cat $LOCK)"
fi
看到debug,该函数被执行了两次。
^C
++ exec_func
++ rm -f /tmp/performanceScript.lock
+++ dirname '${BASH_SOURCE[0]}'
++ cd .
++ echo 'Volvio a la vida'
++ exit 0
+ exec_func
+ rm -f /tmp/performanceScript.lock
+++ which bash
++ dirname '${BASH_SOURCE[0]}'
++ /bin/bash performanceScript2.sh
+ cd .
+ echo 'Volvio a la vida'
+ exit 0
++ which bash
+ /bin/bash performanceScript2.sh
ya se está ejecutando: 13963
为什么exec_func函数执行了两次?
答案1
您正在对所有这些信号设置陷阱:
trap 'exec_func' INT TERM EXIT SIGKILL
这使得exec_func
打开INT
(ctrl-C)并再次打开EXIT
(脚本结束)。
仅选择一个(如果这是您需要的),例如INT
trap 'exec_func' INT
或识别哪个信号被捕获与此类似并使用案例陈述来决定要做什么。
答案2
一旦进入清理方法,您就应该清除陷阱。
像这样的东西
# trap ctrl-c and call ctrl_c()
trap ctrl_c INT TERM ERR EXIT TSTP
function ctrl_c() {
trap '' INT TERM ERR EXIT TSTP
echo "cleanup"
echo "bye"
exit 0
}