O script termina abruptamente com uma mensagem Terminada

3

Este é o meu script bash. Tudo o que isso faz é verificar se um serviço foi iniciado e se alguns processos estão sendo executados conforme o esperado.

Termina abruptamente com uma mensagem "Terminada". Eu tentei depurá-lo com o sinalizador set -x e ainda não sei o que está errado. O Stack Overflow e o Google não mostram outras pessoas com problemas semelhantes.

O script tem permissões de 755. Alguns comandos são ofuscados, por razões óbvias.

#!/bin/bash

set -x 

DAEMON_BIN=/etc/init.d/init-god
DAEMON_BIN_START="${DAEMON_BIN} start"
DAEMON_BIN_STOP="${DAEMON_BIN} stop"
SOME_VARIABLE="foo"

CHEF_CONFIG_FILE_PATH="/path/to/file"
NODE_INFO_FILE="/mnt/node_info/properties"

function get_key_value (){
    value=$(grep -Po "(?<=^${1}:).*" ${NODE_INFO_FILE})
    echo $value;
}

eval $DAEMON_BIN_STOP

nohup pkill DAEMON &> /dev/null

nohup pkill -f resque &> /dev/null

eval $DAEMON_BIN_START

sleep 15

PROCESS_COUNT='ps aux | awk '/[p]rocess-name/' | wc -l'

NODE_NAME='get_key_value node_name'

if [[ $NODE_NAME -eq $SOME_VARIABLE  && $PROCESS_COUNT -eq 1 ]]; then 
    echo "DAEMON and scheduler are running fine." ;
else
    echo "A problem with DAEMON has occured." ;
fi

EXPECTED_PROCESS_COUNT='get_key_value no_of_workers'
ACTUAL_WORKER_COUNT='ps ax | grep [r]esque-[0-9]'

if [[ $EXPECTED_PROCESS_COUNT -eq $ACTUAL_WORKER_COUNT ]]; then 
    echo "Correct Number of workers initialized." ;
else
    echo "More workers exist than are permitted." ;
fi

for (( i=0; i<${EXPECTED_PROCESS_COUNT}; i++ )); do
    WORKER_NAME='get_key_value worker_${i}'
    COUNT='ps ax | grep ${WORKER_NAME} | grep -v grep | wc -l'
    if [[ $COUNT -eq 1 ]]; then
        #statements
        echo "${WORKER_NAME} is running."
    else
        echo "${WORKER_NAME} may not be running or might have more than 1 copies."
    fi
done

A saída de depuração do script é a seguinte:

+ DAEMON_BIN=/etc/init.d/init-god
+ DAEMON_BIN_START='/etc/init.d/init-god start'
+ DAEMON_BIN_STOP='/etc/init.d/init-god stop'
+ SOME_VARIABLE=foo
+ CHEF_CONFIG_FILE_PATH=/path/to/file
+ NODE_INFO_FILE=/mnt/node_info/properties
+ eval /etc/init.d/init-god stop
++ /etc/init.d/init-god stop
.
Stopped all watches
Stopped god
+ nohup pkill DAEMON
+ nohup pkill -f resque
Terminated

Por que esse script sai com uma mensagem "Terminado"? O que devo fazer para evitar que isso aconteça?

    
por theTuxRacer 09.10.2013 / 07:27

1 resposta

10

Quando você está chamando pkill -f resque , ele também está correspondendo ao seu script, enviando um SIGTERM. Se você não conseguir adicionar restrições adicionais nos comandos pkill , como correspondência mais exata, será necessário eliminar os PIDs um de cada vez para garantir que o script não esteja se matando. Aqui está um exemplo:

pids=( $(pgrep -f resque) )
for pid in "${pids[@]}"; do
  if [[ $pid != $$ ]]; then
    kill "$pid"
  fi
done
    
por 09.10.2013 / 07:38