亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在golang ssh會話關閉中將EOF作為錯誤

在golang ssh會話關閉中將EOF作為錯誤

Go
九州編程 2022-05-23 16:39:37
我正在使用“ssh”golang 模塊,我想知道我是否實現了它(或嘗試)。session.Close() 中的“EOF”是否是預期的錯誤?在我在網上看到的示例中,沒有人檢查 session.Close() 錯誤。這是我應該忽略或處理的事情嗎?據我所知,服務器也不會出現錯誤。我想知道我是否沒有正確執行命令,或者沒有正確讀取緩沖區。這是我的代碼: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貢獻1884條經驗 獲得超4個贊

這似乎類似于golang/go/issue 31401(然后指的是問題 32453:“ x/crypto/ssh:在發送 EOF 消息時調用 session.Run() 后運行 session.Wait() 的語義”)

返回錯誤是因為會話已經關閉(由Run())。
SSH 連接泄漏是因為它從不關閉——從返回的客戶端對象Dial()被丟棄,但這是需要關閉以清理底層 TCP 連接的對象。

順便說一句,這似乎是一個可以正確使用的微妙 API。
會話可以在任何時候被另一方異步關閉,因此正確編寫的代碼總是有可能從中獲取 EOFClose()

所以你可能想測試那個特定的錯誤,并在你的 defer 函數中忽略它。


查看完整回答
反對 回復 2022-05-23
  • 1 回答
  • 0 關注
  • 356 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號