使用go ssh库与Cisco设备交谈

使用go ssh库与Cisco设备交谈,ssh,go,cisco,Ssh,Go,Cisco,我试图通过ssh到路由器并使用show命令来实现对各种Cisco ASR参数的监控。以下是工作流的一部分(省略错误处理): 此时,我可以写入sshIn并读取sshOut。 由于Cisco(和其他供应商)的路由器不支持执行命令(如果我错了,请纠正我),所以我所能做的就是将命令传递给shell并读取输入,直到找到命令提示符 嗯。下面是我用来在第一个命令提示符前跳过初始路由器问候语的部分: buf := make([]byte, 1000) n, err := sshOut.Read(buf) //

我试图通过ssh到路由器并使用show命令来实现对各种Cisco ASR参数的监控。以下是工作流的一部分(省略错误处理):

此时,我可以写入
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())
}
阅读回复的方式与我阅读初始问候语的方式相同,这会产生(带问候语):

还是一切都好。但当我尝试发送更长的命令时,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# 
我发送的命令在某个点被拆分,但是命令结果的输出在没有拆分的情况下被正确传递

所以问题是如何修复这种分裂?现在我没有主意了。
谢谢大家的关注

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

terminal width 200
到路由器


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

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

session.RequestPty("vt100", 80, 40, modes)
这给了我40个字符的宽度和80个字符的高度。 在我的情况下,正确的呼叫应该是:

session.RequestPty("vt100", 0, 200, modes)
这样,一切都按预期进行。并且不需要显式更改端子宽度

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