为什么使用 frp ?
通过在具有公网 IP 的节点上部署 frp 服务端,可以轻松地将内网服务穿透到公网,同时提供诸多专业的功能特性,这包括:
- 客户端服务端通信支持 TCP、KCP 以及 Websocket 等多种协议。
- 采用 TCP 连接流式复用,在单个连接间承载更多请求,节省连接建立时间。
- 代理组间的负载均衡。
- 端口复用,多个服务通过同一个服务端端口暴露。
- 多个原生支持的客户端插件(静态文件查看,HTTP、SOCK5 代理等),便于独立使用 frp 客户端完成某些工作。
- 高度扩展性的服务端插件系统,方便结合自身需求进行功能扩展。
- 服务端和客户端 UI 页面。
更多文档,请参考官方文档https://github.com/fatedier/frp
准备条件
- 云服务器(必须)
- 域名(必须)
域名及服务器配置
配置域名解析
建议配置泛域名解析,一劳永逸,我的解析如下
服务器放行端口
需要放行的端口在下文中的 frps.ini 配置文件中有,我目前的放行的有 18888、8888、8843
frp的下载与安装
下载地址 https://github.com/fatedier/frp/releases,注意下载对应自己的操作系统,它的服务端和客户端是在一个包里的,所以,如果你的服务端和客户端是不同的平台,请分别下载(一般都是服务端 linux, 客户端 windows)
服务端
解压到文件夹下就行,实际上只需要 frps 开头的文件
客户端
解压到文件夹下就行,实际上只需要 frpc 开头的文件
frp 的配置
服务器的配置 (frps.ini)
[common]
#通讯端口,用于和客户端内网穿透传输数据的端口,可自定义
bind_port = 18888
#http监听端口,注意可能和服务器上其他服务用的80冲突,比如centos有些默认有Apache,默认80,可自定义
vhost_http_port = 8888
#https监听端口,默认443,可自定义
vhost_https_port = 8843
#通过浏览器查看 frp 的状态以及代理统计信息展示(端口、用户名、密码),可自定义,不建议开启,也没啥用
#dashboard_port = 8880
#dashboard_user = admin
#dashboard_pwd = 123456
#通讯令牌(客户端需和此处一致)
token = lyn4ever#jhacker
# frp日志配置
log_file = /home/frp/frps.log
log_level = info
log_max_days = 3
#全局域名,这个就是上边配置的泛解析域名
subdomain_host = np.jhacker.cn
客户端的配置 (frpc.ini)
[common]
#填写服务器公网IP地址
server_addr = xx.xx.xx.xx
#通讯端口,和服务端保持一致(如果是第三方云服务器需在厂商安全组策略中开放该端口)
server_port = 18888
#通讯令牌,和服务端保持一致
token = lyn4ever#jhacker
# 本地管理的界面的配置
admin_addr = 127.0.0.1
admin_port = 429
admin_user = admin
admin_pwd = 123456
# Admin assets directory. By default, these assets are bundled with frpc.
# assets_dir = ./static
# 以下配置就是你要代理的端口和域名配置,其中subdomain和custom_domains只能配置一个
[web]
type = http
local_port = 8013
subdomain = test
#custom_domains = test.np.jhacker.cn
[mysql]
type = tcp
local_port = 3307
# tcp模式需要指定服务器的端口,注意这个端口需要放行
remote_port = 83307
subdomain = mysql
到此,已经全部配置完毕,在你的客户端机子上的 8013 端口开着一个 http 服务,3306 端口开着 mysql。
分别启动服务器和客户端
- 服务器
./frps -c frps.ini
- 客户端
./frpc -c frpc.ini
- 浏览器打开
http://test.np.jhacker.cn:18888
就能访问你客户端机子上的 8013 的服务了。 - 使用
mysql.np.jhacker.cn:83307
就可以访问你本机上的 mysql 服务了。
在服务器使用 Nginx 进行反向代理访问 frp
这部分主要是为了解决每次使用内网穿透时需要添加端口的问题,比如上边的 18888 端口。nginx 的安装请自行解决,这里只给出反代的配置
server {
listen 80;
server_name *.np.jhacker.cn;
client_max_body_size 10240m;
location / {
# 配置服务器的frp的端口
proxy_pass http://127.0.0.1:18888;
keepalive_timeout 0;
# 剩下的不要动,直接复制
proxy_set_header Host $host;
# proxy_set_header Host $http_host:8007; # 对于 ngrok 需要用这句
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
add_header X-Cache $upstream_cache_status;
add_header Cache-Control no-cache,public; # 设置浏览器协商缓存
expires 12h; # 设置 nginx 缓存 12 小时
}
}
这样配置之后,像上边的 test 服务,可以直接使用域名,而不需要带端口访问了。
更多文章,访问我的博客jhacker
评论区