现在有个使用场景,本人使用的本地环境是Win10+VSCode,模型训练是在一台Linux服务器上。我想在本地浏览器中直接访问远程服务器上tensorboard的监控界面,而不是通过TeamViewer或者向日葵等远程控制软件先连上服务器再在服务器上查看。
关于如何在pytorch下使用tensorboard可以参照pytorch官网文档(本人使用的版本pytorch1.6.0,再只需安装上tensorboard包即可使用)。
先注明下设备环境:
本地PC机:Windows,编辑器VSCode
远程服务器:Linux,IP地址假设为123.123.123.123,端口号port假设为23456。服务器上的个人账户名假设为xiaoming。
需要说明一点:我这里服务器的端口号是23456而不是ssh端口号22,是因为服务器实际是在另一个局域网内,本地PC机不能直接访问,做了另一个端口转发将123.123.123.123::23456和局域网ip:22映射起来。现在可以理解为这个远程服务器就是由123.123.123.123和23456端口号确定,且可以被本地PC机访问到。
这里我找到了3种方法来实现。
方法1
我自己使用VSCode以及其提供的
首先,登录到远程服务器上:
1 | ssh [email protected] -p 23456 |
之后输入账户xiaoming对应的密码,即可登录成功。(
在VSCode中登录成功后,点击
1 | tensorboard --logdir='path-to-the-log' |
启动成功后会在bash终端中显示:
(默认tensorboard会在6006端口开启,若改到其他端口则加上
到这一步就可以直接在本地浏览器访问
当然也是支持修改本地端口号的,如改成16006。
总结:如果也是用VSCode的话,这个方法很简单,也不需要操作太多。普通SSH登录方式,标准的tensorboard启动方式,PC端直接就可以访问到远程服务器上的tensorboard了。
方法2
借助Xshell等专用远程连接工具来实现。首先设置下Xshell的会话属性页:
连接设置:
用户身份验证:
设置SSH转发规则:
(上图中源主机即本地PC机,目标主机即远程服务器。本地端口设置成了16006,远程服务器端口还是设置默认的tensorboard端口6006)
完成上述步骤后,在Xshell里进行启动tensorboard,再在本地浏览器中访问
方法3
这个方法需要手动输入命令来完成SSH的本地端口转发。
Windows下的命令行工具可以使用cmd或者git bash。在PC机端输入下面命令完成SSH本地端口转发以及登录操作:
1 | ssh -L 16006:127.0.0.1:6006 [email protected] -p 23456 |
该命令作用是登录远程服务器账户,并将服务器端的6006端口和PC机端的16006端口映射起来。这里利用的是SSH本地端口转发功能
执行完该命令也就完成了。之后启动tensorboard,在本地PC机浏览器中访问
以上就是我整理的3种方法。都是可以实现文首所提到的场景需求的。更多关于ssh使用以及端口转发功能,可以参考[1]、[2]。
在这也简单记一下[1]中的内容吧,做个笔记。
SSH端口转发
SSH有三种端口转发模式,本地端口转发(Local Port Forwarding),远程端口转发(Local Port Forwarding)以及动态端口转发(Dynamic Port Forwarding)。
本地端口转发
所谓本地端口转发,就是将发送到本地端口的请求,转发到目标端口。这样,就可以通过访问本地端口,来访问目标端口的服务。使
1 | -L 本地网卡地址:本地端口:目标地址:目标端口 |
本地网卡地址可以省略不写,那它默认值就是localhost(127.0.0.1),即只能本机访问。如果想允许其他地址也能借助本地端口转发,则将本地网卡地址设置为0.0.0.0。
远程端口转发
所谓远程端口转发,就是将发送到远程端口的请求,转发到目标端口。这样,就可以通过访问远程端口,来访问目标端口的服务。使用
1 | -R 远程网卡地址:远程端口:目标地址:目标端口 |
远程端口转发在内网穿透中很有用。
比如有个公网服务器jumpbox作为跳板机,有一台处于内网的机器A和另一个内网的机器B。A和B间不能够直接通讯,这时就借助公网服务器jumpbox作跳板来实现内网穿透。
假设:
jumpbox:ip为123.123.123.123 端口为2000 用户名为root
机器A:ip为192.168.1.1
机器B:ip为192.168.2.2 端口为3000
我们在机器B上执行远程端口转发命令,将机器B上的3000端口暴露给跳板机:
1 | ssh -R 0.0.0.0:2000:localhost:3000 [email protected] |
这样机器A访问跳板机的2000端口即可访问到机器B的3000端口。(首先确保跳板机允许2000端口转发,像阿里云服务器默认是不开启)
博客[3]中有更详细介绍。
参考文献
[1] 玩转SSH端口转发 - Fundebug的文章 - 知乎
[2] SSH 基本用法 - 陈乐群的文章 - 知乎
[3] 利用ssh反向代理以及autossh实现从外网连接内网服务器