【背景】
有三台主机 A、S、B,系统均为Linux。主机 A 和主机 B 在各自不同的内网,主机 S 为一台具有公网 IP 的云主机。主机 A 与主机 B 都可以通过 ssh 连接主机 S。如下图:
【需求】
主机 A 需要通过主机 S 连接主机 B。
【方法】
1、设置主机 S。
1.1、编辑 /etc/ssh/sshd_config 文件,在里面修改或添加:
GatewayPorts yes
1.2、重启 sshd 服务。
sudo service sshd restart
2、设置主机 B。
2.1、方式一:用 ssh
ssh -fNR portS:localhost:22 userS@pubIpS # portS 是主机 S 的某个开放端口 # userS 是主机 S 的一个用户 # pubIpS 是主机 S 的公网IP
2.2、方式二:用 autossh
autossh -M 3456 -NR portS:localhost:22 userS@pubIpS -p22 # -M 参数没大弄明白,大概是通过这个端口监听以便自动重连吧 # 输入密码后可以用 Ctrl-Z 放到后台
3、主机 A 通过 ssh 连接上主机 S 后。这样连接主机 B:
ssh userB@localhost -p portS # userB 为主机 B 的用户 # portS 与上一步的 portS 是同一个端口
相关阅读:SSH反向连接及Autossh
*** walker ***
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。