Go x/crypto/ssh -- 如何通过堡垒节点建立到私有实例的 ssh 连接

我想实现这个场景:在 AWS 上,我有一个 VPC,其中部署了一个公共和私有子网。在公共子网中,我有一个“堡垒”实例,而在私有子网中,有一个节点运行一些服务(也称为“服务实例”)。通过使用 *nux ssh 命令,我可以执行以下操作以从本地笔记本电脑连接到“服务实例”:

ssh -t -o ProxyCommand="ssh -i <key> ubuntu@<bastion-ip> nc %h %p" -i <key> ubuntu@<service-instance-ip>

我有一个 Go 程序,想做以下几件事:

  1. ssh 从“本地笔记本电脑”通过“堡垒”连接到“服务实例”

  2. 使用连接会话运行一些命令(例如“ls -l”)

  3. 将文件从“本地笔记本电脑”上传到“服务实例”

我已经尝试过但无法实现与执行相同的过程

ssh -t -o ProxyCommand="ssh -i <key> ubuntu@<bastion-ip> nc %h %p" -i <key> ubuntu@<service-instance-ip>

谁能帮我举个例子?谢谢!

顺便说一句,我发现了这个: https://github.com/golang/go/issues/6223,这意味着它绝对能够做到这一点,对吧?


鸿蒙传说
浏览 217回答 1
1回答

catspeake

您可以在没有nc命令的情况下使用“x/crypto/ssh”更直接地执行此操作,因为有一种方法可以从远程主机拨打连接并将其显示为net.Conn.一旦有了ssh.Client,您就可以使用该Dial方法net.Conn在您和最终主机之间建立虚拟机。然后你可以把它变成一个新的ssh.Connwith ssh.NewClientConn,并创建一个新的ssh.Clientwithssh.NewClient// connect to the bastion hostbClient, err := ssh.Dial("tcp", bastionAddr, config)if err != nil {&nbsp; &nbsp; log.Fatal(err)}// Dial a connection to the service host, from the bastionconn, err := bClient.Dial("tcp", serviceAddr)if err != nil {&nbsp; &nbsp; log.Fatal(err)}ncc, chans, reqs, err := ssh.NewClientConn(conn, serviceAddr, config)if err != nil {&nbsp; &nbsp; log.Fatal(err)}sClient := ssh.NewClient(ncc, chans, reqs)// sClient is an ssh client connected to the service host, through the bastion host.
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go