Telnetlib 不会因大量输出而退出

Posted

技术标签:

【中文标题】Telnetlib 不会因大量输出而退出【英文标题】:Telnetlib doesn't exit on huge output 【发布时间】:2021-10-08 00:43:56 【问题描述】:

我正在尝试仅使用 telnetlib 从多个设备收集 show tech-support。它适用于一个小问题。它收集show tech-support 命令的完整输出并将其导出到一个文本文件(export_text_support() 是一个简单的with open() 语句)。

我实验室中两个开关的全部输出是show tech-support 命令的32,76816,325 行。我得到了整个输出,BUT 一个小问题是会话在完成后没有退出调用tn.write(b"exit\n")。当exec-timeout 按下开关(会话变为空闲时) 时,它会退出,这两个开关都是 10 分钟,而不是当没有其他内容可从 tn 读取时。 p>

我尝试了以下相同的代码来获得较短的输出,例如 show running-config,我在导出的文件中看到了 #exit(末尾有一个空行)。

短输出

...
365 !
366 end
367
368 Switch#
369 Switch#exit
370 

巨大的输出

....
16321 423 entries printed
16322 
16323 
16324 
16325 Switch#

(你可以注意到exit在巨大的输出样本中没有看到,最后也没有空行)

这是我的sn-p

from telnetlib import Telnet


host = ""
username = ""
password = ""

def get_tech_support(host: str) -> None:

    with Telnet(host=host, port=23) as tn:
        # Check for credentials
        if username:
            tn.read_until(b"Username: ")
            tn.write(username.encode("ascii") + b"\n")
        if password:
            tn.read_until(b"Password: ")
            tn.write(password.encode("ascii") + b"\n")
        
        # Some commands
        commands = ["\n", "terminal width 115", "terminal length 0"]
        [tn.write(command.encode("ascii") + b"\n") for command in commands]
        
        # The main command
        cmd = "show tech-support"

        # Send the main command
        tn.write(cmd.encode("ascii") + b"\n")

        hostname = tn.read_until(b"#")

        tn.write(b"\nexit\n")
        command_output = tn.read_all().decode("ascii")

    result = dict(
        ip=host, hostname=hostname, command=cmd, command_output=command_output
    )

    export_tech_support(command_output=result)  # Export the show command output

如何让会话在完成详细输出后自动退出并避免等待exec-timeout 被点击(在我的情况下为 10 分钟)

【问题讨论】:

【参考方案1】:

当我们提取大量输出和配置时,telnetlib 和 paramiko 存在问题。

这是由于在运行脚本时控制台连接关闭,因此您必须寻找解决方案来维护控制台连接。我建议使用 netmiko,因为 netmiko 版本 >= 1.0 现在也支持 Telnet。

例如,你可以检查这个脚本:

from pprint import pprint
import yaml
from netmiko import (
    ConnectHandler,
    NetmikoTimeoutException,
    NetmikoAuthenticationException,
)


def send_show_command(device, commands):
    result = 
    try:
        with ConnectHandler(**device) as ssh:
            ssh.enable()
            for command in commands:
                output = ssh.send_command(command)
                result[command] = output
        return result
    except (NetmikoTimeoutException, NetmikoAuthenticationException) as error:
        print(error)


if __name__ == "__main__":
    device = 
        "device_type": "cisco_ios_telnet", #Refer netmiko device type
        "host": "192.168.100.1",
        "username": "cisco",
        "password": "cisco123",
        "secret": "cisco",  #if not required remove this
    
    result = send_show_command(device, ["sh clock", "sh ip int br"])
    pprint(result, width=120)

【讨论】:

以上是关于Telnetlib 不会因大量输出而退出的主要内容,如果未能解决你的问题,请参考以下文章

MS Access 因错误而退出

如果程序因错误而提前退出,那么释放动态分配的内存的正确方法是啥?

命令 PhaseScriptExecution 因 R.swift 的非零退出代码而失败

如何解决 J2ME 中的“应用程序因内存不足而意外退出”错误

VBA:代码因DoEvents而暂停时间长度变化

datastax 会话因大量并行查询而挂起