Docker搭建frp实现内网穿透

一、服务端搭建

原先用花生壳做穿透,但是个人免费版的花生壳限制太多,带宽也不行,后来又要求上传身份证实名认证,就卸载了,自己搭建frp做穿透,网上教程杂乱,也不够详细,在此记录分享一下。

需要准备一台外网可访问的服务器,作为frp服务端机器,我用的是轻量级云服务器,目的是为了pad在外网直接访问公司的win10机器,所以示例环境相关信息如下:

服务端环境:centos7 、docker
客户端环境:win10

docker搭建frp服务端后,win10机器下载客户端并启动注册到服务端,使用ipad + RD client外网远程内网机器

1.服务端拉镜像

docker pull snowdreamtech/frps

2.在某个目录下新建配置文件 frps.ini ,比如我是在/home/docker/frp目录下,内容如下

[common]
bind_port = 7000
# 启用面板
dashboard_port = 7500
# 面板登录名和密码
dashboard_user = admin
dashboard_pwd = xxxxxx
# 使用http代理并使用8888端口进行穿透
vhost_http_port = 8888
# 使用https代理并使用9999端口进行穿透
vhost_https_port = 9999
# 日志路径
log_file = ./frps.log
# 日志级别
log_level = info
# 日志最大保存天数
log_max_days = 2
# 认证超时时间
authentication_timeout = 900
# 认证token,客户端需要和此对应
token=123123123
# 最大连接数
max_pool_count = 5
max_ports_per_client = 0

3.在某个目录下新建frp-restart.sh文件,内容如下

NAME=frps
IMAGE=snowdreamtech/frps

docker stop $NAME
docker rm $NAME

docker run --restart=on-failure:3 --network host -v /home/docker/frp/frps.ini:/etc/frp/frps.ini -d --name $NAME $IMAGE

4.运行frp-restart.sh,启动服务端容器

5.外网浏览器输入server_host:7500,输入配置文件中的账号密码,登录dashboard,确认是否启动成功

二、客户端搭建

1.下载frp客户端文件,地址:https://github.com/fatedier/frp/releases ,windows客户端找到frp_xxxxxx_windows_amd64.zip,点击下载,解压到本地

2.找到目录中的frpc.ini文件,管理员模式打开编辑,编辑内容如下

[common]
# 服务端ip
server_addr = xxx.xxx.xxx.xxx
# 对应服务端配置 bind_port
server_port = xxxx
# 对应服务端配置中的 token
token = 123123123
[ssh]
type = tcp
# 此处不需要改
local_ip = 127.0.0.1
# windows服务器默认的远程端口,如果考虑安全问题,可以修改远程端口,对应再修改此处
local_port = 3389
# local_port映射的远程端口,也就是映射的服务端的端口
remote_port = 6000

4.客户端机器上新建一个frp_client.bat文件,编辑内容

D:\soft\frp_0.43.0_windows_amd64\frpc.exe -c D:\soft\frp_0.43.0_windows_amd64\frpc.ini

5.双击运行文件,验证连接,如果显示 start proxy success ,说明连接成功,也可以打开frp dashboard,点击菜单Proxies,查看status是否为online

6.如果连接失败,确认服务器frp相关端口是否放行,云服务器的防火墙规则,同时要确保windows机器开启允许远程(家庭版的win系统可能不支持远程,需要确认)

三、测试远程服务

1.windows上用户管理,创建一个新用户

2.ipad下载RD client,打开新建远程连接,地址填写server_host:remote_port,按照示例中的就是server_host:6000,点击,如果能正常连接,会要求输入账号密码,验证成功后即可远程连接

四、客户端开机自启动、后台运行

如果只是偶尔使用一下内网映射,把bat文件放桌面上,使用时双击打开即可,如果需要经常远程或者其它操作,建议搞成后台运行。具体操作如下:

win10用户打开文件夹C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp
1.开机自动启动:将frp_client.bat或其快捷方式放入此文件夹下即可。缺点是启动后会在桌面显示命令窗口,不够友好。
2.开机自动启动并且后台运行:使用VB脚本处理。在上述路径下创建一个vbs后缀的脚本文件,如frp_client_run.vbs(步骤1中的frp_client.bat在此路径下需要移除,否则重复执行),文本编辑器打开,粘贴如下内容

set ws=WScript.CreateObject("WScript.Shell")
ws.Run "D:\soft\frp_0.43.0_windows_amd64\frp_client_run.bat",0

系统重启后,自动无感知开启frp客户端,当然,缺点也是无感知......有时候不确定是不是真的开了

你可能感兴趣的:(Docker搭建frp实现内网穿透)