【问题标题】:Talking to Cisco equipment using go ssh library使用 go ssh 库与 Cisco 设备通信
【发布时间】:2014-01-15 19:05:58
【问题描述】:

我正在尝试监控各种 Cisco ASR 参数,对路由器执行 ssh 并使用 show 命令获取结果。这是工作流程的一部分(省略了错误处理):

client, err := ssh.Dial("tcp", "172.16.32.95:22", config)
session, err := client.NewSession()
sshOut, err := session.StdoutPipe()
sshIn, err := session.StdinPipe()
err := session.RequestPty("xterm", 80, 40, modes)
err := session.Shell()

此时我可以写信到sshIn 并从sshOut 读取。 由于 Cisco(和其他供应商)的路由器不支持执行命令(如果我错了,请纠正我),我所能做的就是将命令传递给 shell 并读取输入,直到找到命令提示符。

好的。这是我用来在第一个命令提示符之前跳过初始路由器问候的部分:

buf := make([]byte, 1000)
n, err := sshOut.Read(buf) //this reads the ssh terminal welcome message
loadStr := ""
if err == nil {
    loadStr = string(buf[:n])
}
for (err == nil) && (!strings.Contains(loadStr, "[local]")) {
    n, err = sshOut.Read(buf)
    loadStr += string(buf[:n])
}
fmt.Println(loadStr)

产生:

Last login: Tue Jan 14 17:29:06 -0500 2014 on pts/1 from 172.16.35.101.
Cisco Systems SSI
[local]ewag# 

要运行命令,我写信给sshIn

if _, err := sshIn.Write([]byte("show clock\r")); err != nil {
    panic("Failed to run: " + err.Error())
}

并以与我阅读初始问候语相同的方式阅读响应,从而产生(带问候语):

Last login: Tue Jan 14 18:06:14 -0500 2014 on pts/2 from 10.7.7.14.
Cisco Systems SSI
[local]ewag# 
show clock
Tuesday January 14 18:09:19 EST 2014
[local]ewag# 

一切正常。但是当我尝试发送更长的命令时,f.e.:

if _, err := sshIn.Write([]byte("show session progress ipsg-service ipsg-gprs-svc\r")); err != nil {
    panic("Failed to run: " + err.Error())
}

输出中断:

Last login: Tue Jan 14 18:09:19 -0500 2014 on pts/2 from 10.7.7.14.
Cisco Systems SSI
[local]ewag# 
show session progress ipsg
-service ipsg-gprs-svc
Unknown command - "ipsg-service", unrecognized keyword
[local]ewag# 

我发送的命令在某些时候被拆分,但命令结果的输出正确传递而没有拆分。

那么问题是如何解决这种分裂?现在我没有想法。 感谢关注!

【问题讨论】:

    标签: ssh go cisco


    【解决方案1】:

    愚蠢的错误。我是这样请求 pty 的:

    session.RequestPty("vt100", 80, 40, modes)
    

    这给了我 width 40 个字符和 height 80 个字符。 在我的情况下,正确的调用应该是:

    session.RequestPty("vt100", 0, 200, modes)
    

    这样一切都按预期工作。并且无需显式更改终端宽度。

    【讨论】:

      【解决方案2】:

      问题已通过在 Cisco 上设置终端宽度解决。 所以,会话建立后,我发送命令:

      terminal width 200
      

      到路由器。

      现在回复中可以正确显示长命令。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2015-04-02
        • 1970-01-01
        • 1970-01-01
        • 2011-10-31
        • 2012-12-19
        • 2023-04-07
        相关资源
        最近更新 更多