分享
Golang ssh并ping包
zhang_gq · · 1725 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
工作需要写了个Go小程序,需要ssh到host上,并执行ping包,检查host的网络是否通。简单版的如下:
package main
import (
"fmt"
"golang.org/x/crypto/ssh"
"os"
)
func main() {
// get ssh client
addrPort := "10.42.10.11:22"
client, err := ssh.Dial("tcp", addrPort, &ssh.ClientConfig{
User: "root",
Auth: []ssh.AuthMethod{ssh.Password("123456")},
HostKeyCallback: ssh.InsecureIgnoreHostKey(),
})
if err != nil {
fmt.Fprintf(os.Stdout, "Failed to get ssh client %v\n", err)
os.Exit(0)
}
defer client.Close()
// connect host
session, err := client.NewSession()
if err != nil {
fmt.Fprintf(os.Stdout, "Failed to connect session \n")
os.Exit(0)
}
defer session.Close()
pingAccess := "ping -c 2 10.42.10.12 | grep '100% packet loss' | wc -l"
result, err := session.Output(pingAccess)
if err != nil || 49 == result[0] {
fmt.Fprintf(os.Stdout, "Failed to ping result:%d, Err:%v \n", result[0], err)
os.Exit(0)
}
//result is ASCII
fmt.Fprintf(os.Stdout, "finish %d \n", result[0])
}
简单的说明:
1. 下载crypto源码git clone https://github.com/golang/crypto.git,把crypto文件夹拷贝到vendor/golang.org/x/目录下
2. 这里的ssh.InsecureIgnoreHostKey是不检查host key,需要检查的话得参考client源码重写函数。
3. session.run(command)是直接在host执行命令,不关心执行结果。session.Output是将执行命令之后的Stdout返回
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1725 次点击
上一篇:Golang调用Python
下一篇:使用go实现的排序算法
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
工作需要写了个Go小程序,需要ssh到host上,并执行ping包,检查host的网络是否通。简单版的如下:
package main
import (
"fmt"
"golang.org/x/crypto/ssh"
"os"
)
func main() {
// get ssh client
addrPort := "10.42.10.11:22"
client, err := ssh.Dial("tcp", addrPort, &ssh.ClientConfig{
User: "root",
Auth: []ssh.AuthMethod{ssh.Password("123456")},
HostKeyCallback: ssh.InsecureIgnoreHostKey(),
})
if err != nil {
fmt.Fprintf(os.Stdout, "Failed to get ssh client %v\n", err)
os.Exit(0)
}
defer client.Close()
// connect host
session, err := client.NewSession()
if err != nil {
fmt.Fprintf(os.Stdout, "Failed to connect session \n")
os.Exit(0)
}
defer session.Close()
pingAccess := "ping -c 2 10.42.10.12 | grep '100% packet loss' | wc -l"
result, err := session.Output(pingAccess)
if err != nil || 49 == result[0] {
fmt.Fprintf(os.Stdout, "Failed to ping result:%d, Err:%v \n", result[0], err)
os.Exit(0)
}
//result is ASCII
fmt.Fprintf(os.Stdout, "finish %d \n", result[0])
}
简单的说明:
1. 下载crypto源码git clone https://github.com/golang/crypto.git,把crypto文件夹拷贝到vendor/golang.org/x/目录下
2. 这里的ssh.InsecureIgnoreHostKey是不检查host key,需要检查的话得参考client源码重写函数。
3. session.run(command)是直接在host执行命令,不关心执行结果。session.Output是将执行命令之后的Stdout返回