Назад | Перейти на главную страницу

Ожидайте, что экран запуска сценария перестает работать при запуске cron

Я надеюсь, что этот вопрос подходит для этого форума.

Имею устройство, модем. Я разговариваю с этим модемом с программой linux "screen" как с терминальной программой. Я вызываю это так "/usr/bin/screen /dev/tty6". Мне нужно отправить около 6 команд за сеанс или около того. Я использую сценарий ожидания, чтобы автоматизировать процесс. Сценарий ожидания порождает экранный процесс, отправляет команды и завершает работу.

Эта система отлично работает, когда я запускаю ее из сеанса терминала или когда я запускаю ее удаленно с помощью ssh с другого компьютера. Но когда я использую cron для его запуска, он не работает. На локальном компьютере происходит сбой с ошибкой, например: spawn id exp6 not open while executing exp_send. Это происходит при третьей отправке сценария ожидания.

Я пытался использовать cron для удаленного запуска, используя ssh с -t, -tt, -ttt варианты, но я получаю сообщение об ошибке: "Pseudo-terminal will not be allocated because stdin is not a terminal."

В моих crontab есть переменная пути, но я уверен, что большинство команд вызываются с полным путем.

Я пробовал создать экран с -m вариант, но он по-прежнему не запускается. В этом сценарии создание и отключение экрана не имеет смысла. Отчасти проблема заключается в том, что рабочий экран в качестве эмулятора терминала для последовательного порта отличается от его обычного запуска. Любая помощь или понимание будут очень благодарны.

Сценарий ожидания здесь:

--- 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

-------- вкладка 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"

Электронная почта 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""

Похоже, мне просто нужно добавить:

TERM=vt100

в мой cronfile. Ой.

Все работает сейчас.