O script possui traps que executam uma função que executa novamente o script do host, mas o executa duas vezes.
#!/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
vendo o debug, a função é executada duas vezes.
^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
Por que a função exec_func é executada duas vezes?
Você está armando uma armadilha em todos esses sinais:
o que faz com que seja
exec_func
ligadoINT
(ctrl-C) e novamente ligadoEXIT
(fim do script).Escolha apenas um (se é isso que você precisa) como
INT
Ou identifique qual sinal está sendo capturado semelhante a este e use uma instrução case para decidir o que fazer.
Você deve limpar a armadilha assim que inserir seu método de limpeza.
algo assim