我正在嘗試通過(guò) ssh 到路由器并使用 show 命令來(lái)實(shí)現(xiàn)對(duì)各種 Cisco ASR 參數(shù)的監(jiān)控。這是工作流程的一部分(省略了錯(cuò)誤處理):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()在這一點(diǎn)上,我可以寫入sshIn和讀取sshOut. 由于 Cisco 的(和其他供應(yīng)商的)路由器不支持 exec'ing 命令(如果我錯(cuò)了,請(qǐng)糾正我)我所能做的就是將命令傳遞給 shell 并讀取輸入,直到找到命令提示符。好的。這是我用來(lái)在第一個(gè)命令提示符之前跳過(guò)初始路由器問候語(yǔ)的部分:buf := make([]byte, 1000)n, err := sshOut.Read(buf) //this reads the ssh terminal welcome messageloadStr := ""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)產(chǎn)生:Last login: Tue Jan 14 17:29:06 -0500 2014 on pts/1 from 172.16.35.101.Cisco Systems SSI[local]ewag# 要運(yùn)行我寫的命令sshIn:if _, err := sshIn.Write([]byte("show clock\r")); err != nil { panic("Failed to run: " + err.Error())}并以與閱讀初始問候語(yǔ)相同的方式閱讀響應(yīng),從而產(chǎn)生(帶有問候語(yǔ)):Last login: Tue Jan 14 18:06:14 -0500 2014 on pts/2 from 10.7.7.14.Cisco Systems SSI[local]ewag# show clockTuesday January 14 18:09:19 EST 2014[local]ewag# 還是一切正常。但是當(dāng)我嘗試發(fā)送更長(zhǎng)的命令時(shí),fe: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-svcUnknown command - "ipsg-service", unrecognized keyword[local]ewag# 我發(fā)送的命令在某個(gè)時(shí)候被拆分,但命令結(jié)果的輸出正確傳遞而沒有拆分。所以問題是如何修復(fù)這種分裂?現(xiàn)在我沒有想法。謝謝關(guān)注!
2 回答

四季花海
TA貢獻(xiàn)1811條經(jīng)驗(yàn) 獲得超5個(gè)贊
愚蠢的錯(cuò)誤。我是這樣請(qǐng)求 pty 的:
session.RequestPty("vt100", 80, 40, modes)
這給了我40 個(gè)字符的寬度和80 個(gè)字符的高度。在我的情況下,正確的調(diào)用應(yīng)該是:
session.RequestPty("vt100", 0, 200, modes)
這樣一切都按預(yù)期工作。并且無(wú)需顯式更改終端寬度。

BIG陽(yáng)
TA貢獻(xiàn)1859條經(jīng)驗(yàn) 獲得超6個(gè)贊
通過(guò)在 Cisco 上設(shè)置終端寬度解決了問題。因此,在會(huì)話建立后,我發(fā)送命令:
terminal width 200
到路由器。
現(xiàn)在長(zhǎng)命令在回復(fù)中正確顯示。
- 2 回答
- 0 關(guān)注
- 328 瀏覽
添加回答
舉報(bào)
0/150
提交
取消