我写了一个go项目来部署在线代码。我需要远程机器并运行一些start
reload
之类的命令。
我有200多台机器,所以我使用go例程来完成这项工作。
问题是有时 ssh失败抛出ssh: handshake failed: EOF
或ssh: handshake failed: read tcp 10.19.177.216:44721->10.19.139.36:22: read: connection reset by peer
为什么?
我的核心代码:
func RunRemoteCmd(selfDesc string, host string, cmd string, ch chan<- RunResult) {
startTime := time.Now()
sshConfig := &ssh.ClientConfig{
User: "root",
Auth: []ssh.AuthMethod{
publicKey,
},
HostKeyCallback: func(hostname string, remote net.Addr, key ssh.PublicKey) error {
return nil
},
}
addr := fmt.Sprintf("%s:22", host)
connection, err := ssh.Dial("tcp", addr, sshConfig)
if err != nil {
ch <- RunResult{selfDesc, err.Error(), "", time.Since(startTime)}
return
}
session, err := connection.NewSession()
if err != nil {
ch <- RunResult{selfDesc, err.Error(), "", time.Since(startTime)}
return
}
defer session.Close()
var out bytes.Buffer
session.Stdout = &out
session.Run(cmd)
ch <- RunResult{selfDesc, "", out.String(), time.Since(startTime)}
}
答案 0 :(得分:1)
远程服务器可能有多个ssh连接拒绝。
我更改了一台服务器connection
,多个NewSession
解决了这个问题。