我正在使用“ssh”golang 模塊,我想知道我是否實(shí)現(xiàn)了它(或嘗試)。session.Close() 中的“EOF”是否是預(yù)期的錯(cuò)誤?在我在網(wǎng)上看到的示例中,沒(méi)有人檢查 session.Close() 錯(cuò)誤。這是我應(yīng)該忽略或處理的事情嗎?據(jù)我所知,服務(wù)器也不會(huì)出現(xiàn)錯(cuò)誤。我想知道我是否沒(méi)有正確執(zhí)行命令,或者沒(méi)有正確讀取緩沖區(qū)。這是我的代碼:package mainimport ( "bytes" "fmt" "strings" "golang.org/x/crypto/ssh")func main() { sshConfig := &ssh.ClientConfig{ User: “my_username”, Auth: []ssh.AuthMethod{ ssh.Password(“my password”), }, HostKeyCallback: ssh.InsecureIgnoreHostKey(), } connection, err := ssh.Dial("tcp", "localhost:22", sshConfig) if err != nil { fmt.Printf("Failed to dial: %s\n", err) return } defer func() { if err := connection.Close(); err != nil { fmt.Println("Received an error closing the ssh connection: ", err) } else { fmt.Println("No error found closing ssh connection") } }() session, err := connection.NewSession() if err != nil { fmt.Printf("Failed to create session: %s\n", err) return } defer func() { if err := session.Close(); err != nil { fmt.Println("Received an error closing the ssh session: ", err) } else { fmt.Println("No error found closing ssh session") } }() fmt.Println("created session") var stdOut bytes.Buffer var stdErr bytes.Buffer session.Stdout = &stdOut session.Stderr = &stdErr err = session.Run("pwd") fmt.Println("Executed command") fmt.Println("Command stdOut is:", strings.TrimRight(stdOut.String(), "\n"), " --- stdError is:", strings.TrimRight(stdErr.String(), "\n"))}我得到的輸出是:$ go run main.gocreated sessionExecuted commandCommand stdOut is: /Users/my_username --- stdError is: Received an error closing the ssh session: EOFNo error found closing ssh connection$ 有什么建議嗎?
1 回答

慕村9548890
TA貢獻(xiàn)1884條經(jīng)驗(yàn) 獲得超4個(gè)贊
這似乎類(lèi)似于golang/go/issue 31401(然后指的是問(wèn)題 32453:“ x/crypto/ssh
:在發(fā)送 EOF 消息時(shí)調(diào)用 session.Run() 后運(yùn)行 session.Wait() 的語(yǔ)義”)
返回錯(cuò)誤是因?yàn)闀?huì)話(huà)已經(jīng)關(guān)閉(由
Run()
)。
SSH 連接泄漏是因?yàn)樗鼜牟魂P(guān)閉——從返回的客戶(hù)端對(duì)象Dial()
被丟棄,但這是需要關(guān)閉以清理底層 TCP 連接的對(duì)象。順便說(shuō)一句,這似乎是一個(gè)可以正確使用的微妙 API。
會(huì)話(huà)可以在任何時(shí)候被另一方異步關(guān)閉,因此正確編寫(xiě)的代碼總是有可能從中獲取 EOFClose()
所以你可能想測(cè)試那個(gè)特定的錯(cuò)誤,并在你的 defer 函數(shù)中忽略它。
- 1 回答
- 0 關(guān)注
- 373 瀏覽
添加回答
舉報(bào)
0/150
提交
取消