frp + nginx 配置多人共用的http 内网穿透服务
一、 前言
frp 是一个用Go 语言开发的,可用于内网穿透 的高性能的反向代理应用,支持 tcp, udp 、 http 和 https。可将一个部署在本机的web服务映射到外网。
本文主要讲如何基于frp + nginx 配置http 内网穿透服务,承载多人同时使用,从而支持微信公众号,微信小程序的本地开发调试
所需资源:
- 一台公网服务器或者VPS(本人用的 腾讯云的主机)
- 一个指向到此台公网服务器的域名(本文以
为例)
本文涉及的环境
- centos7.2
- nginx 1.10.1
- frp 0.22.0
- go 1.11.4
- Windows 10
二 、 frp 原理
(请仔细阅读原理,在不理解原理的情况下上手配置容易出错,且很难定位原因。这都是本人所经历的惨痛教训)
以本人搭建的frp 内网穿透服务为例:
第一步: 配置无误的情况下,frp服务端和frp客户端先后启动,建立通信隧道 ,其中:
- frp服务端监听http
7071 端口(此端口可自定义),接收此端口下所有外网用户请求 - frp客户端代理本地想要暴露给外网的web服务端口,本文以
8585 , 8686 端口为例
第二步: 通过配置nginx 反向代理,将指向本台公网服务器的dev. 下的子域名,映射到服务器的7071 端口,也就是frp监听的那个端口。 外网用户访问dev. 下的子域名,例如 :
等同于访问:7071 ,会 触发 frp服务端和客户端的互动,从而http请求由frp服务端传递到frp客户端
第三步: frp客户端收到http请求后,基于自定义配置,则做如下处理:
- 监听到http请求中的域名为
a.dev. ,则将请求转发到我本地的8585 web服务端口 - 监听到http请求中的域名为
b.dev. ,则将请求转发到我本地的8686 web服务端口
第四步: 本地的web服务收到http请求后,对请求做处理,并完成响应
第五步: frp客户端将响应结果回传给frp的服务端。服务端最终将响应回传给外网用户
第六步: 最终的实测效果为:
- 访问
a.dev. ,等同于访问我本地的localhost:8585 - 访问
b.dev. ,等同于访问我本地的localhost:8686
三 、 准备工作
3.1 在域名解析后台配置子域名
本文以 为例:
登录域名的解析后台,在 下增加两条A记录: dev , *.dev ,记录值为部署frp服务端的公网服务器的ip。
代表dev. 下的所有的子域名,会全部指向此台公网服务器。
3.2 关于 go语言环境
因为本文采用的是绿色安装,所以不需要配置go语言环境。多谢 Tylerrrkd 指正
四、服务端配置
4.1 frp服务端安装配置
下载解压
wget https://github.com/fatedier/frp/releases/download/v0.22.0/frp_0.22.0_linux_amd64.tar.gz tar -zxvf frp_0.22.0_linux_amd64.tar.gz
修改配置文件
解压后进入解压目录,找到frps.ini 文件, 做如下配置 。配置说明请参见各项对应的注释
# 服务端通过此端口接监听和接收公网用户的http请求 # frp提供了一个控制台,可以通过这个端口访问到控制台。可查看frp当前有多少代理连接以及对应的状态 # 服务端的subdomain_host需要和客户端配置文件中的subdomain、local_port配合使用, # 可通过{subdomain}.{subdomain_host} 的域名格式来访问自己本地的 web 服务。 # 假如服务端的subdomain_host为dev.,客户端某个配置组中的 # subdomain为a,local_port为8585, # 访问 a.dev. ,等同于访问本地的localhost:8585
启动frp服务端
4.2 nginx反向代理配置
(关于如何安装nginx 就不过多赘述,详细安装教程请参考 Nginx Linux详细安装部署教程)
修改 nginx.conf 文件
proxy_pass http://127.0.0.1:7071; proxy_set_header Host $host:80; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_connect_timeout 7d; if ($http_user_agent ~* "360Spider|JikeSpider|Spider|spider|bot|Bot|2345Explorer|curl|wget|webZIP|qihoobot|Baiduspider|Googlebot|Googlebot-Mobile|Googlebot-Image|Mediapartners-Google|Adsbot-Google|Feedfetcher-Google|Yahoo! Slurp|Yahoo! Slurp China|YoudaoBot|Sosospider|Sogou spider|Sogou web spider|MSNBot|ia_archiver|Tomato Bot|NSPlayer|bingbot")
让nginx重新加载配置文件
/usr/local/nginx/sbin/nginx -s reload
4.3 开启防火墙端口
# 开启防火墙端口 7000端口和7071端口即为上面配置的bind_port和vhost_http_port端口 firewall-cmd --zone=public --add-port=7000/tcp --permanent firewall-cmd --zone=public --add-port=7071/tcp --permanent
五、 客户端安装配置
下载客户端
去github上面下载最新版的 windows客户端 github.com/fatedier/fr… ,找到 frp_0.23.1_windows_amd64.zip ,点击下载即可
(Mac用户请下载Mac版本的客户端)
解压后,编辑 frpc.ini 文件
server_addr = 132.232.64.79 # 代理服务一 ,[]内的代理服务名称在全局范围内确保唯一,每个人的每个代理服务不能重名, # local_port代表你想要暴露给外网的本地web服务端口 # subdomain 在全局范围内要确保唯一,每个代理服务的subdomain不能重名,否则会影响正常使用。 # 客户端的subdomain需和服务端的subdomain_host配合使用
启动 客户端
在frp解压目录下右键打开 powershell 或者cmd ,执行如下命令
如果窗口提示 『start proxy success』 ,则代表frp服务端和frp客户端的通信隧道 建立成功
测试访问
在浏览器里面访问 http://a.dev. 、测试本地的web服务是否已经暴露给外网
六、问题解疑
疑问: 为什么要搭建自己的内网穿透服务,而不是购买类似花生壳这种收费的内网穿透服务?
解疑: 花生壳收费过高,一个旗舰版的一年都需要868元,而且只有4个端口映射,意味着只有4名开发人员同时用都可能不够。一个中型的互联网公司都有四五十人或者上百人,如果用花生壳的话,每年都需要三四万花费,显然不是个小数目。而对于一家互联网公司,都是有自己的服务器资源和域名资源的,既然如此,何不搭建一个自有的内网穿透服务?
疑问:微信小程序只支持https协议,而刚搭建的是http内网穿透,不适用怎么办?
解疑: 可以在微信Web开发者工具里面找到项目设置,把 『不校验合法域名、业务域名、TLS版本以及HTTPS证书』 项勾选即可。这样就可以在生产环境下走https 协议,本地开发环境下走http 协议
关于生产环境下怎么部署https ,请参考本人在掘金上的这篇文章全站HTTPS升级系列
另外关于本地开发环境下怎么部署https,曾经尝试过mkcert 、jdk的keystore ,然而最终没有找打一个切实可行的方案
疑问:我搭建的内网穿透服务,怎么限定只有内部成员可用,防止外人随意『搭便车』?
解疑: 可以基于token参数来完成身份验证。服务端和客户端的 common 配置中的 token 参数一致则身份验证通过。
|