esperar que o script executando a tela pare de funcionar quando executado pelo cron

1

Espero que esta pergunta seja boa para este fórum.

Eu tenho um dispositivo, um modem. Eu falo com este modem com o programa linux "screen" como um programa terminal. Eu chamo-o assim " /usr/bin/screen /dev/tty6 ". Eu preciso enviar cerca de 6 comandos por sessão ou mais. Eu uso um script de espera para poder automatizar o processo. O script expect gera o processo de tela, envia os comandos e sai.

Este sistema funciona bem quando eu o executo a partir de uma sessão de terminal ou quando eu o executo remotamente usando o ssh de outra máquina. Mas quando eu uso o cron para executá-lo, ele falha. Na máquina local, ele falha com um erro como: spawn id exp6 not open while executing exp_send . Isso é feito no terceiro envio do script esperado.

Eu tentei usar o cron para ser executado remotamente usando ssh com as opções -t , -tt , -ttt , mas recebo o erro: " Pseudo-terminal will not be allocated because stdin is not a terminal. "

Meus crontabs têm um conjunto de variáveis de caminho, mas a maioria dos comandos são invocados com um caminho completo, tenho certeza.

Eu tentei gerar tela com uma opção -m , mas ainda parece falhar ao aparecer. A tela de desova e a desanexação não fazem sentido neste cenário. Parte do problema parece ser que a tela de execução como um emulador de terminal para uma porta serial é diferente de executá-lo normalmente. Qualquer ajuda ou insight seria muito apreciada.

O script de expectativa aqui:

--- do-stuff.exp

#!/usr/bin/expect -b

set verbose 0
set verb [lindex $argv 0]
if { $verb eq "-v" } {
  set ::argv [lassign $::argv verbose]
  set verbose 1
}

set phone [lindex $argv 0]
set message [lindex $argv 1]

if { $verbose == 1 } {
  send_user "phone = ($phone)\n"
  send_user "message = ($message)\n"
}

set force_conservative 1  ;# set to 1 to force conservative mode even if
if {$force_conservative} {
    set send_slow {1 .1}
    proc send {ignore arg} {
        sleep .1
        exp_send -s -- $arg
    }
}

# turn off screen echo
if { $verbose == 0 } {
  log_user 0
}

set timeout -1
spawn /usr/bin/screen /dev/tty6 cs8
match_max 100000

# wait 100 milliseconds
after 100
send -- "+++"
after 100
send -- "ATZ\r"
expect -exact "OK\r
" 
send -- "AT+CMGF=1\r"
expect -exact "OK\r
"
send -- "AT+CMGS=\"$phone\"\r"
expect -exact "
> "
send -- "$message\r"
expect -exact "\r
> "
send -- "^Z"
expect -exact "OK\r
"
send -- "^Ak"
after 500
send -- "y"
#expect eof
exit 0

-------- a guia cron

/etc/cron.d/local-test

SHELL=/bin/sh
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
# m h dom mon dow user command
*/3 * * * 1-5  fred        /home/fred/do-stuff.exp -- -v 12345678 "test message cron 2"

O email do cron

phone = (123456789)
message = (test message cron 2)
spawn /usr/bin/screen /dev/tty6 cs8
Please set a terminal type.
+++ATZ
send: spawn id exp6 not open
   while executing
"exp_send -s -- $arg"
   (procedure "send" line 3)
   invoked from within
"send -- "AT+CMGF=1\r""
    
por k-h 22.07.2015 / 13:32

1 resposta

1

Parece que tenho de adicionar:

TERM=vt100

para o meu cronfile. Ai.

Tudo funcionando agora.

    
por 23.07.2015 / 05:03