Как сбросить comserver через telnet с помощью скрипта python с telnetlib

Я хочу написать скрипт на Python, который автоматически сбрасывает ком-сервер. Для этого скрипт должен передавать команды "2","5","y" Я уже написал эту маленькую программку:

import sched
import time
import sys
from LoggerTelnet import LoggerTelnet

HOST = "xxx.xxx.xx.xxx"
PORT = "yyyy"
UPDATE_TIME = 600

s = sched.scheduler(time.time, time.sleep)

def reset(sc):
    lt = time.localtime()
    print(time.strftime("Datum: %d.%m.%Y, Uhrzeit: %H:%M:%S", lt))
    sys.stdout.flush()
    print("Verbindung zum COM-Server wird aufgebaut")
    sys.stdout.flush()
    tn = LoggerTelnet(HOST, PORT)
    sys.stdout.flush()
    print("Logger wird jetzt resetet")
    sys.stdout.flush()
    tn.kommando("2")
    tn.kommando("5")
    tn.kommando("z")
    tn.close()
    print("Verbindung zum COM-Server wurde geschlossen")
    print("Logger erfolgreich resetet \n\n\n")
    sys.stdout.flush()
    s.enter(UPDATE_TIME, 1, reset, (sc,))

s.enter(UPDATE_TIME, 1, reset, (s,))
s.run()

Эта программа использует мой класс Telnet:

import telnetlib

class LoggerTelnet(object):

    def __init__(self, host, port):
        try:
            self.tel = telnetlib.Telnet(host, port) 
        except:
            raise Error("Could not connect to Host")
        self.lese_daten()

    def close(self): 
        self.tel.close()

    def lese_daten(self):
        msg = self.tel.read_until("\r\n", 20.0)
        print(msg)
        return msg

    def kommando(self, kom):
        try:
            self.tel.write("%s\r\n" % kom)
        except:
            raise Error("Could not send Command")

        return self.lese_daten()

Но вся эта программа не работает. Я думаю, что соединение с сервером устанавливается, но команды не отправляются и не выполняются. Я также не получаю никакой обратной связи от сеанса telnet. Только в начале, что соединение установлено.

Я надеюсь, что у вас есть идея и вы можете мне помочь :-)

Лучший.


person Marcel Gangwisch    schedule 02.01.2014    source источник
comment
Рассмотрим этот ответ, в котором я рекомендовал telnetlib.Telnet.expect() для решения очень похожей проблемы.   -  person Robᵩ    schedule 02.01.2014
comment
Я пытался использовать telnetlib.Telnet.expect(), но это не работает... Я по-прежнему не получаю ответа от Com-сервера. И он тоже не сбрасывался.   -  person Marcel Gangwisch    schedule 03.01.2014