先确认端口映射有没有配对。
因为我这边作为客户端(被链接的ssh服务器)是放在docker中的ubuntu系统,所以这穿透时的端口就复杂一些,涉及到了三个OS(端口):docker中的ssh服务端口22,映射到本地机器上的端口23,映射到公网服务器上的端口24
那么,此时客户端的配置文件:frpc.ini中的端口要如何配置?
答:应分情况讨论:
如果你的frpc客户端放在docker中,则配置为:
[common]
server_addr = xxxx
server_port = 7000[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 24
也即从docker容器内的客户端看来,frp连接的是“本地系统”的22端口和远程服务的24端口。而22-23的映射由docker run 的-p参数负责处理,对容器内frp的客户端来说不可见。
如果放在docker之外(但目标还是连docker内的ssh),则配置应为
[common]
server_addr = xxxx
server_port = 7000[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 23
remote_port = 24
同理,对此时的frp客户端来说,其所连接转发的是远程服务的24端口和本机系统的23端口,而23端口与docker容器内的转发一样由docker run的p参数负责。
小结一下就是,local_port应为当前容器(OS)中,ssh服务所监听的端口。