Parece que tenho de adicionar:
TERM=vt100
para o meu cronfile. Ai.
Tudo funcionando agora.
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
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"
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""
Parece que tenho de adicionar:
TERM=vt100
para o meu cronfile. Ai.
Tudo funcionando agora.
Tags cron gnu-screen expect serial