登录
首页 >  Golang >  Go问答

使用 SSH 和使用 golang 的 pem / 密钥连接到服务器

来源:Golang技术栈

时间:2023-03-23 13:44:47 214浏览 收藏

怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《使用 SSH 和使用 golang 的 pem / 密钥连接到服务器》,涉及到golang,有需要的可以收藏一下

问题内容

我正在尝试使用 Go 编程语言的 [ssh][1] 包通过密钥连接到亚马逊 AWS linux 服务器。但是,包文档有点神秘/令人困惑。有谁知道如何使用密钥或至少在可能的情况下通过 ssh 进行连接?困扰我的是,在 [Dial][3] 示例中它说

// An SSH client is represented with a ClientConn. Currently only
// the "password" authentication method is supported.

我基本上想模仿 ssh -i x.pem root@server.com 行为并在服务器内执行命令(例如whoami

正确答案

您需要使用ssh.PublicKeys将列表ssh.Signers转换为ssh.AuthMethod. 您可以使用从 pem 字节ssh.ParsePrivateKey中获取 a Signer,或者如果您需要使用 rsa、dsa 或 ecdsa 私钥,您可以将它们提供给ssh.NewSignerFromKey.

这是一个使用代理支持的示例(因为使用代理通常是在简单地使用密钥文件之后的下一步)。

sock, err := net.Dial("unix", os.Getenv("SSH_AUTH_SOCK"))
if err != nil {
    log.Fatal(err)
}

agent := agent.NewClient(sock)

signers, err := agent.Signers()
if err != nil {
    log.Fatal(err)
}

// or get the signer from your private key file directly
// signer, err := ssh.ParsePrivateKey(pemBytes)
// if err != nil {
//     log.Fatal(err)
// }

auths := []ssh.AuthMethod{ssh.PublicKeys(signers...)}

cfg := &ssh.ClientConfig{
    User: "username",
    Auth: auths,
}
cfg.SetDefaults()

client, err := ssh.Dial("tcp", "aws-hostname:22", cfg)
if err != nil {
    log.Fatal(err)
}

session, err = client.NewSession()
if err != nil {
    log.Fatal(err)
}

log.Println("we have a session!")

...

到这里,我们也就讲完了《使用 SSH 和使用 golang 的 pem / 密钥连接到服务器》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于golang的知识点!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>