frp + nginx 配置多人共用的http 内网穿透服务

栏目: 服务器 · Nginx · 发布时间: 5年前

内容简介:本文主要讲如何基于所需资源:

frp 是一个用 Go 语言开发的,可用于 内网穿透 的高性能的反向代理应用,支持 tcp, udp 、 http 和 https。可将一个部署在本机的web服务映射到外网。

本文主要讲如何基于 frp + nginx 配置http 内网穿透服务,承载 多人 同时使用, 从而支持微信公众号,微信小程序的本地开发调试

所需资源:

msh.com

本文涉及的环境

  • 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.msh.com 下的子域名,映射到服务器的 7071 端口,也就是frp监听的那个端口。 外网用户访问 dev.msh.com 下的子域名,例如 :

a.dev.msh.com
b.dev.msh.com

等同于访问 msh.com:7071 ,会 触发 frp服务端和客户端的互动,从而http请求由frp服务端传递到frp客户端

第三步:frp客户端收到http请求后,基于自定义配置,则做如下处理:

  • 监听到http请求中的域名为 a.dev.msh.com ,则将请求转发到我本地的 8585 web服务端口
  • 监听到http请求中的域名为 b.dev.msh.com ,则将请求转发到我本地的 8686 web服务端口

第四步:本地的web服务收到http请求后,对请求做处理,并完成响应

第五步:frp客户端将响应结果回传给frp的服务端。服务端最终将响应回传给外网用户

第六步:最终的实测效果为:

  • 访问 a.dev.msh.com ,等同于访问我本地的 localhost:8585
  • 访问 b.dev.msh.com ,等同于访问我本地的 localhost:8686

三 、 准备工作

3.1 在域名解析后台配置子域名

本文以 msh.com 为例:

msh.com 下增加两条A记录: dev , *.dev ,记录值为部署frp服务端的公网服务器的ip。

代表 dev.msh.com 下的所有的子域名,会全部指向此台公网服务器。

3.2 服务端配置 go 语言环境

翻墙下载&解压安装

frp 基于 Go 语言进行开发和运行,所以在服务端配置 Go 语言环境

可能是因为 Go 语言是谷歌家开发的,所以连带go的官网 https://golang.org/ 都被墙了(天杀的**),意味着无法通过 wget 命令进行安装。所以只有翻墙后,把下载好的软件包上传到服务器上面

软件包我已经上传到百度云上了,用户可以在百度云上面下载

go1.11.4.linux-amd64.tar.gz 百度云下载地址

# 解压
tar -zxvf go1.11.4.linux-amd64.tar.gz 
# 移动到自定义的软件安装目录
mv go /software/

复制代码

配置环境变量

# 用 vim打开 /etc/profile
vim /etc/profile

# 在里面加入环境变量
export GO_HOME=/software/go
export PATH=$PATH:$GO_HOME/bin

# 使环境变量生效
source /etc/profile

# 查看是否安装成功
go  version
复制代码

四、服务端配置

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 文件, 做如下配置 。配置说明请参见各项对应的注释

[common]
# frp监听的端口,用作服务端和客户端通信
bind_port = 7000

# 服务端通过此端口接监听和接收公网用户的http请求
vhost_http_port = 7071

# frp提供了一个控制台,可以通过这个端口访问到控制台。可查看frp当前有多少代理连接以及对应的状态
dashboard_port = 7500


# 服务端的subdomain_host需要和客户端配置文件中的subdomain、local_port配合使用,
# 可通过{subdomain}.{subdomain_host} 的域名格式来访问自己本地的 web 服务。
# 假如服务端的subdomain_host为dev.msh.com,客户端某个配置组中的
# subdomain为a,local_port为8585,
# 则:
# 访问 a.dev.msh.com ,等同于访问本地的localhost:8585

subdomain_host = dev.msh.com

复制代码

启动frp服务端

./frps -c frps.ini
复制代码

4.2 nginx反向代理配置

修改 nginx.conf 文件

# frp的接收http请求的反向代理
	server {
		listen 80;
		server_name *.dev.msh.com  dev.msh.com;
		
		location / {
			# 7071端口即为frp监听的http端口
			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;
			proxy_send_timeout 7d;
			proxy_read_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")
			{
				return 403;
			}
	}
复制代码

让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

# 开启后重启防火墙,使得刚刚的修改生效
firewall-cmd --reload
复制代码

五、 客户端安装配置

下载客户端

去github上面下载最新版的 windows客户端 github.com/fatedier/fr… ,找到 frp_0.23.1_windows_amd64.zip ,点击下载即可

(Mac用户请下载Mac版本的客户端)

解压后,编辑 frpc.ini 文件

[common]
# 部署frp服务端的公网服务器的ip
server_addr = 132.232.64.79
# 和服务端的bind_port保持一致
server_port = 7000


# 代理服务一 ,[]内的代理服务名称在全局范围内确保唯一,每个人的每个代理服务不能重名,
# 否则会影响正常使用。
 [http-a]
type = http
# local_port代表你想要暴露给外网的本地web服务端口
local_port = 8585
# subdomain 在全局范围内要确保唯一,每个代理服务的subdomain不能重名,否则会影响正常使用。
# 客户端的subdomain需和服务端的subdomain_host配合使用
subdomain = a


# 代理服务二  ,各项配置说明请参考配置组一
[http-b]
type = http
local_port = 8686
subdomain = b
 
           
复制代码

启动 客户端在frp解压目录下右键打开 powershell 或者 cmd

./frpc.exe -c .\frpc.ini
复制代码

如果窗口提示**『start proxy success』**,则代表frp服务端和frp客户端的 通信隧道 建立成功

测试访问

在浏览器里面访问 http://a.dev.msh.com 、测试本地的web服务是否已经暴露给外网

六、问题解疑

疑问: 为什么要搭建自己的内网穿透服务,而不是购买类似花生壳这种收费的内网穿透服务?

解疑:花生壳收费过高,一个旗舰版的一年都需要868元,而且只有4个端口映射,意味着只有4名开发人员同时用都可能不够。一个中型的互联网公司都有四五十人或者上百人,如果用花生壳的话,每年都需要三四万花费,显然不是个小数目。而对于一家互联网公司,都是有自己的服务器资源和域名资源的,既然如此,何不搭建一个自有的内网穿透服务?

疑问:微信小程序只支持https协议,而刚搭建的是http内网穿透,不适用怎么办?**解疑:**可以在微信Web开发者 工具 里面找到项目设置,把『不校验合法域名、业务域名、TLS版本以及HTTPS证书』项勾选即可。这样就可以在生产环境下走 https 协议,本地开发环境下走 http 协议

关于生产环境下怎么部署 https ,请参考本人在掘金上的这篇文章全站HTTPS升级系列

另外关于本地开发环境下怎么部署https,曾经尝试过 mkcert 、jdk的 keystore ,然而最终没有找打一个切实可行的方案

疑问:我搭建的内网穿透服务,怎么限定只有内部成员可用,防止外人随意『搭便车』?

解疑:可以基于token参数来完成身份验证。服务端和客户端的 common 配置中的 token 参数一致则身份验证通过。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

轻快的Java

轻快的Java

(美)塔特、杰兰德/国别:中国大陆 / 张晓坤 / 中国电力出版社 / 2006-7 / 29.00元

Java的开发者正深陷于复杂性的泥沼中而无法自拔。我们的经验和能力正接近极限,程序员为了编写支持所选框架的程序所花的时间比解决真正问题的时间要多得多。我们不禁要问,有必要把Java搞得这么复杂吗?   答案是否定的。本书给你指引了一条出路。无论是维护应用程序,还是从头开始设计,你都能够超越成规,并大幅精简基本框架、开发过程和最终代码。你能重新掌握一度失控的J2EE应用程序。   在本书......一起来看看 《轻快的Java》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器