【问题标题】:Python multiple telnet sessionsPython 多个 telnet 会话
【发布时间】:2013-08-24 23:58:50
【问题描述】:

我需要构建一个脚本来获取尽可能多的主机的 telnet 输出,并将它们保存到每个主机的单独文件中。该脚本应作为守护程序运行。

目前我有一个函数,它封装了使用telnetlib 为单个主机执行此操作的逻辑,但我不知道如何继续。我计划为每个主机打开一个进程(multiprocessing.Process),但我怀疑这将是一种资源浪费,它必须以更好的方式存在:)

def TelnetLogSaver(hostname,ip,filename):   
    # open files and telnet sessions
    f = open(filename,"a")
    tn = telnetlib.Telnet(ip,23,TIMEOUT)

    # login
    e = tn.read_until("Login: ")
    tn.write(USER+"\n")
    # and password
    e = tn.read_until("Password: ")
    tn.write(PASSWORD+"\n")

    # Connected. Start infinite loop to save messages log
    while True:
        e = tn.read_until(PROMPT,TIMEOUT)
        if e is not "":
            f.write(datetime.datetime.now().strftime("%Y-%m-%dT%H:%M:%S"))
            f.write(e)
            f.flush()

        # avoid session timeout
        tn.write("\n")
        e = tn.read_until(PROMPT

【问题讨论】:

  • 你可以试试多线程吗?在主要受网络时间限制的应用程序中,将 GIL 作为瓶颈应该完全可以忽略不计,并且线程要轻得多。
  • 一个想法:使用select()

标签: python telnet telnetlib


【解决方案1】:

我相信以下应该可以满足您的要求,我采用了您的原始代码并将其制成一种线程:

import threading
import telnetlib
import datetime
import sys
# Global Variable Declarations
TIMEOUT = 30
USER = "Noel"
PROMPT = "Noel"


class listener(threading.Thread):
    def __init__(self, filename, ip):
        # Have to make a call to the super classes' __init__ method
        super(listener, self).__init__()
        self.f = open(filename,"a")
        try:
            self.tn = telnetlib.Telnet(ip, 23, TIMEOUT)
        except:
            print "Bad Connection"
            sys.exit(0)

    def run(self):
        # login
        e = self.tn.read_until("Login: ")
        self.tn.write(USER+"\n")
        # and password
        e = self.tn.read_until("Password: ")
        self.tn.write(PASSWORD+"\n")
        while True:
            e = self.tn.read_until(PROMPT, TIMEOUT)
            if e is not "":
                self.f.write(datetime.datetime.now().strftime("%Y-%m-%dT%H:%M:%S"))
                self.f.write(e.strip())
                self.f.flush()

            # avoid session timeout
            self.tn.write("\n")


if __name__ == "__main__":
    # Things to listen to is a dictionary of hosts and files to output
    # to, to add more things to listen to just add an extra entry into
    # the things_to_listen_to in the format: host : outputfile
    things_to_listen_to = {"localhost" :"localhost_output.txt"}
    # Thread holder is going to hold all the threads we are going to start
    thread_holder = []
    for host, file in things_to_listen_to.iteritems():
        thread_holder.append(listener(file, host))
    for thread in thread_holder:
        thread.run()

希望这会有所帮助,如果您有任何问题,请更新您的问题或发表评论。

【讨论】:

    猜你喜欢
    • 2014-05-05
    • 2013-11-19
    • 2014-11-15
    • 2014-01-13
    • 1970-01-01
    • 1970-01-01
    • 2019-02-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多