该脚本具有执行重新运行主机脚本但执行两次的函数的陷阱。
#!/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
看到调试,函数执行了两次。
^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 函数会执行两次?
您正在对所有这些信号设置陷阱:
这使得
exec_func
打开INT
(ctrl-C)并再次打开EXIT
(脚本结束)。只选择一个(如果你需要的话)喜欢
INT
或者识别与此类似的被捕获的信号,并使用 case 语句来决定要做什么。
输入清理方法后,您应该清除陷阱。
像这样的东西