Dificuldades para executar o script na inicialização

1

Estou executando o Ubuntu 16.04 com um adaptador USB conectado ao controle da minha TV. Estou usando uma versão modificada de este script para iniciar um cec-server que aceita e envia comandos.

Então, o script funciona; sempre que eu corro manualmente após a inicialização. Quando eu emito o pidof cec-client , ele me dá um ID e eu posso enviar comandos para o cec-server que funciona imediatamente. Tudo é ótimo assim.

No entanto, parece que não consigo fazê-lo funcionar através do crontab ou através dos aplicativos de inicialização. pidof cec-client não retornará um ID e não posso enviar comandos.

TL; DR: O script funciona quando eu o executo manualmente. Não funciona via crontab. Deseja executá-lo automaticamente após a reinicialização.

EDITAR:

O crontabline que eu uso é @reboot /home/server/Documents/cecserver.sh

O script em si:

#!/bin/bash
#
# Set up a fifo and connect cec-client to it
#
# Original By Will Cooke.  http://www.whizzy.org

CECLOG="/home/server/Documents/logs/cec.log"
CECDEV="/dev/ttyACM0"
CECFIFO="/home/server/Documents/logs/cec.fifo"
CECCLIENT="/usr/bin/cec-client -d 1 -p 1 -o Codex"

timestamp(){
 date +"%Y-%m-%d %T"
}

log(){
    echo "SERVER $(timestamp):  $1" >> $CECLOG
}

echo "SERVER $(timestamp): File loaded ($1)" >> $CECLOG

log "Starting server.  Since only one server can run at a time, stopping first."
log "Begin shutting down..."
declare -a TAILPIDS=('ps aux | grep 'tail -f /dev/null' | egrep -v grep | awk '{print $2}'')
declare -a CATPIDS=('ps aux | grep 'cat $CECFIFO' | egrep -v grep | awk '{print $2}'')
if [ ${#TAILPIDS[@]} -gt 0 ]
  then
    log "Found some tail processes..."
    for i in "${TAILPIDS[@]}"
      do
        log "Killing $i"
        kill $i
      done
fi

if [ ${#CATPIDS[@]} -gt 0 ]
  then
      log "Found some cat processes..."
      for i in "${CATPIDS[@]}"
        do
      log "Killing $i"
      kill $i
    done
fi

log "Asking cec-client to stop if it's running..."
killall -s 2 cec-client >> $CECLOG
log "Trying to remove FIFO..."
rm $CECFIFO >> $CECLOG
log "Done shutting down."
log "Done stopping, now starting..."
log "Setting up FIFOs..."
mkfifo $CECFIFO
log "Open pipe for writing..."
tail -f /dev/null > $CECFIFO &
log "Opening pipe for reading and start cec-client..."
(cat $CECFIFO | $CECCLIENT &) > /dev/null
log "Start up complete."

exit 0
    
por Bob 13.12.2017 / 22:07

0 respostas