O script Python é bem-sucedido manualmente, mas falha no crontab

2

Então, atualmente, estou tentando fazer um script funcionar, mas ele está se comportando de maneira diferente quando eu o executo manualmente do que quando o executo a partir do crontab. Basicamente, eu tenho um túnel ssh reverso configurado de um servidor para outro, e para verificar se o meu túnel está ativo eu:

  • SSH do servidor A para o servidor B
  • Envia um URL de teste do servidor A do servidor B
  • se o Wget for bem-sucedido, desconecto e não faço nada
  • se o Wget falhar, eu desconecto e reinicio o túnel

Eu sei que existem maneiras mais elegantes de verificar túneis ssh (como autossh e ServerKeepAlive), mas para questões de política e redundância, tenho que fazer as coisas dessa maneira. De qualquer forma, aqui está o script:

from __future__ import print_function
from __future__ import absolute_import

import os, sys, subprocess, logging, pexpect

COMMAND_PROMPT = '[#$] '
TERMINAL_PROMPT = '(?1)terminal type\?'
TERMINAL_TYPE = 'vt100'
SSH_NEWKEY = '(?i)are you sure you want to continue connecting'
SERVERS = [{address':'192.168.100.10', 'connString':'ssh [email protected]', 'testGet':'wget http://192.168.100.11/test.html -t 1 -T 10', 'tunnel':'start_tunnel'}, {address':'192.168.100.12', 'connString':'ssh [email protected]', 'testGet':'wget http://192.168.100.13/test.html -t 1 -T 10', 'tunnel':'start_tunnel2'}]

def main():

    global COMMAND_PROMPT, TERMINAL_PROMPT, TERMINAL_TYPE, SSH_NEWKEY, SERVERS

    #set up logging
    log = logging.getLogger(__name__)
    log.setLevel(logging.DEBUG)
    handler = logging.FileHandler('/home/user/tunnelTest.log')
    formatter = logging.Formatter('%(asctime)s - %(module)s.%(funcName)s: %(message)s')
    handler.setFormatter(formatter)
    log.addHandler(handler)


    for x in SERVERS:

        #connect to server
        child = pexpect.spawn(x['connString'])
        i = child.expect([pexpect.TIMEOUT, SSH_NEWKEY, COMMAND_PROMPT, '(?i)password'])
        if i == 0:   #Timeout
             log.debug('ERROR! Could not log in to ' + x['address'] + ' ...')
             sys.exit(1)
        if i = 1:    #No key cached
             child.sendline('yes')
             child.expect(COMMAND_PROMPT)
             log.debug('Connected to ' + x['address'] + '...')
        if i = 2:    #Good to go
             log.debug('Connected to ' + x['address'] + '...')
             pass

        #Housecleaning
        child.sendline('cd /tmp')
        child.expect(COMMAND_LINE)
        child.sendline('rm -r test.html')
        child.expect(COMMAND_LINE)

        log.debug('Testing service using ' + x['testGet'] + ' ...')
        child.sendline(x['testGet'])
        child.expect(COMMAND_PROMPT)
        if 'saved' in child.before.lower():
            log.debug('Tunnel working, nothing to do here!')
            log.debug('Disconnecting from remote host ' + x['address'] + '...')
            child.sendline('exit')
        else:
            log.error('Tunnel down!')
            log.debug('Disconnecting from remote host ' + x['address'] + ' and restarting tunnel')
            child.sendline('exit')
            subprocess.call(['start',x['tunnel']])
            log.debug('Autossh tunnel restarted')

if __name__ == "__main__":
    main()

A entrada do meu crontab é a seguinte:

0,30 * * * * python /home/user/tunnelTest.py

Então, sim - este script roda bem quando eu o faço manualmente (sudo python tunnelTest.py) e também roda bem no crontab, a menos que um túnel esteja inativo. Quando um túnel está em baixo, eu pego o "túnel para baixo!" e "Desconectando do host remoto 192.168.100.10 e reiniciando o túnel" mensagens no meu log, mas o script parece morrer lá. O túnel não é reiniciado e não recebo mensagens no meu log até o início da próxima execução agendada.

O script start_tunnel está em / etc / init, o script testTunnel.py está em / home / user, o arquivo testTunnel.log está em / home / user / logs e executei crontab -e como root.

Qualquer visão sobre este assunto seria muito apreciada.

Obrigado!

    
por tparrott 31.07.2014 / 14:27

1 resposta

4

Você precisa usar o caminho completo para python, por exemplo

/usr/bin/python

você pode descobrir o caminho com which python

Assim, a entrada do seu crontab seria parecida com

0,30 * * * * /usr/bin/python /home/user/tunnelTest.py

    
por 31.07.2014 / 14:32

Tags