最近需要远程访问一台虚拟机内的Linux,因为虚拟机没有公网IP,因此选择使用frp转发ssh流量的方式来实现远程访问。首先访问frp的release页面并根据操作系统和CPU下载相应的版本,之后解压得到frpc
和frps
文件。
frps是服务端版本,它需要部署在一台拥有公网IP的主机上,它的配置frps.ini
如下
[common]bind_port = 10625token = y9XBLEu2ymW1s5N3W7OuDPhUG4IohVmQ
其中bind_port代表了它所监听的端口号,而token则是客户端连接时需要用到的验证信息。
frpc是客户端版本,它的配置frpc.ini
如下
[common]server_addr = 100.26.21.285server_port = 10625authentication_method = token token = y9XBLEu2ymW1s5N3W7OuDPhUG4IohVmQ[ssh]type = tcplocal_ip = 127.0.0.1 local_port = 22remote_port = 10626
common代表通用配置,它包含了4个配置
ssh代表了进行ssh转发的设置,它的含义如下
有了如上的配置之后,我们可以在远程主机上使用该配置启动frps
./frps -c ./frps.ini
需要注意远程主机的10625和10626端口需要关闭防火墙的设置,以保证可以通过外部进行访问。之后启用本地的客户端
./frpc -c ./frpc.ini
本地机器如果没有安装ssh服务,则需要先安装ssh服务。启动了服务端和客户端之后,可以在服务端看到客户端成功连接的日志信息,之后通过
ssh ray@100.26.21.285 -p 10626
命令就可以成功访问虚拟机内Linux的ssh服务了,整个网络流程大致如下