当前位置:首页 > CN2资讯 > 正文内容

内网穿透如何前后端联调java http内网穿透

8小时前CN2资讯


frp + nginx 部署http 内网穿透服务

一、 前言

frp 是一个用Go语言开发的,可用于内网穿透的高性能的反向代理应用,支持 tcp, udp 、 http 和
https。可将一个部署在本机的web服务映射到外网。 本文主要讲如何基于frp + nginx 配置http
内网穿透服务,承载多人同时使用,从而支持微信公众号,微信小程序的本地开发调试

所需资源:
一台公网服务器或者VPS(本人用的 腾讯云的主机)
一个指向到此台公网服务器的域名(本文以chunheinanzi.top为例)
本文涉及的环境
centos7.2
nginx 1.10.1
frp 0.22.0
Windows 10

二 、 frp 原理

Frp请求流程

首先,frpc 启动之后,连接 frps,并且发送一个请求 login(),之后保持住这个长连接,如果断开了,就重试
frps 收到请求之后,会建立一个 listener 监听来自公网的请求
当 frps 接受到请求之后,会在本地看是否有可用的连接( frp 可以设置连接池),如果没有,就下发一个 msg.StartWorkConn 并且 等待来自 frpc 的请求
frpc 收到之后,对 frps 发起请求,请求的最开始会指名这个连接是去向哪个 proxy 的
frps 收到来自 frpc 的连接之后,就把新建立的连接与来自公网的连接进行流量互转
如果请求断开了,那么就把另一端的请求也断开

以本人搭建的frp内网穿透服务为例:
第一步: 配置无误的情况下,frp服务端和frp客户端先后启动,建立通信隧道,其中:
frp服务端监听http 7071端口(此端口可自定义),接收此端口下所有外网用户请求
frp客户端代理本地想要暴露给外网的web服务端口,本文以8585 , 8686 端口为例
第二步: 通过配置nginx反向代理,将指向本台公网服务器的dev.chunheinanzi.top 下的子域名,映射到服务器的7071端口,也就是frp监听的那个端口。 外网用户访问dev.chunheinanzi.top下的子域名,例如 :
a.dev.chunheinanzi.top
b.dev.chunheinanzi.top
等同于访问chunheinanzi.top:7071,会 触发 frp服务端和客户端的互动,从而http请求由frp服务端传递到frp客户端
第三步: frp客户端收到http请求后,基于自定义配置,则做如下处理:
监听到http请求中的域名为 a.chunheinanzi.top,则将请求转发到我本地的8585web服务端口
监听到http请求中的域名为 b.chunheinanzi.top,则将请求转发到我本地的8686web服务端口
第四步: 本地的web服务收到http请求后,对请求做处理,并完成响应
第五步: frp客户端将响应结果回传给frp的服务端。服务端最终将响应回传给外网用户
第六步: 最终的实测效果为:
访问 a.chunheinanzi.top,等同于访问我本地的localhost:8585
访问 b.chunheinanzi.top,等同于访问我本地的localhost:8686

三 、 准备工作

3.1 在域名解析后台配置子域名
本文以chunheinanzi.top为例:
登录域名的解析后台,在chunheinanzi.top下增加两条A记录: dev , *.dev,记录值为部署frp服务端的公网服务器的ip。
代表dev.chunheinanzi.top下的所有的子域名,会全部指向此台公网服务器。
3.2 关于 go语言环境
因为本文采用的是绿色安装,所以不需要配置go语言环境。多谢 Tylerrrkd 指正

四、服务端配置

4.1 frp服务端安装配置
下载解压

# 下载 wget https:///fatedier/frp/releases/download/v0.32.1/frp_0.32.1_linux_amd6 4.tar.gz# 解压 tar -zxvf frp_0.32.1_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为,客户端某个配置组中的 # subdomain为a,local_port为8585, # 则: # 访问 www.chunheinanzi.top ,等同于访问本地的localhost:8585 subdomain_host = chunheinanzi.top

启动frp服务端

nohup ./frps -c ./frpc.ini &

4.2 nginx反向代理配置
(关于如何安装nginx就不过多赘述,详细安装教程请参考 Nginx Linux详细安装部署教程)
修改 nginx.conf 文件

# frp的接收http请求的反向代理 server { listen 80; server_name *.dev.chunheinanzi.top dev.chunheinanzi.top; 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客户端 /fatedier/fr… ,找到 frp_0.23.1_windows_amd64.zip,点击下载即可
(Mac用户请下载Mac版本的客户端)
解压后,编辑 frpc.ini 文件

[common] # 部署frp服务端的公网服务器的ip server_addr = **** # 和服务端的bind_port保持一致 server_port = 7000 # 代理服务一 ,[]内的代理服务名称在全局范围内确保唯一,每个人的每个代理服务不能重名, # 否则会影响正常使用。 [http-a] type = http # local_port代表你想要暴露给外网的本地web服务端口 local_port = 8585 # subdomain 在全局范围内要确保唯一,每个代理服务的subdomain不能重名,否则会影响正常使用。 # 客户端的subdomain需和服务端的subdomain_host配合使用 subdomain = www # 代理服务二 ,各项配置说明请参考配置组一 [http-b] type = http local_port = 8686 subdomain = b

启动 客户端
在frp解压目录下右键打开 powershell 或者cmd,执行如下命令

./frpc.exe -c .\frpc.ini

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

测试访问

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

开启自启

linux
在/etc/rc.local里面添加``(文件的具体路径根据实际情况填写),

/root/frp_0.32.1_linux_amd64/frpc -c /root/frp_0.32.1_linux_amd64/frpc.ini > /root/frp_0.32.1_linux_amd64/log.log 2>&1

终端里面输入下面的命令,或者把文件下载回本地修改后重新上传覆盖源文件。然后执行

chmod +x /etc/rc.d/rc.local,重启验证是否开机自启

测试地址

http://www.chunheinanzi.top/me/testget?sign=pater1&data=1234

Dashboard
可以查看请求响应数据,监控服务。

http://www.chunheinanzi.top:7500/


    你可能想看:

    扫描二维码推送至手机访问。

    版权声明:本文由皇冠云发布,如需转载请注明出处。

    本文链接:https://www.idchg.com/info/31596.html

    分享给朋友:

    “内网穿透如何前后端联调java http内网穿透” 的相关文章

    选择DigitalVirt的KVM VPS服务,体验高性价比与稳定性

    DigitalVirt的成立是在2022年,这让我对他们的新起步感到兴奋。这家国人商家致力于提供高质量的KVM VPS服务,逐渐在市场上赢得了一席之地。就我个人的体验来看,DigitalVirt的使命似乎就是帮助用户实现在线业务的稳定与高效。特别是在快节奏的数字时代,能够找到一个可靠的服务提供商至关...

    IDC托管便宜还是公有云便宜?全面解析成本优势与选择指导

    在选择IT基础设施时,我发现IDC托管和公有云服务是两个普遍关注的选项。很多企业在进行服务器部署时都在思考“IDC托管便宜还是公有云便宜?”为了帮助大家更好地理解,我决定从几个关键方面进行深入分析。 IDC托管的价格构成 在开始探讨具体价格前,我们有必要理清IDC托管的价格构成。基本上,IDC托管费...

    VPS是干嘛用的:解析虚拟专用服务器的优势与应用

    在当今互联网的快速发展下,VPS(Virtual Private Server,虚拟专用服务器)逐渐成为了个人和企业首选的主机类型。简单来说,VPS就是一种将物理服务器分割成多个虚拟服务器的技术。每个虚拟服务器都能独立运行操作系统,用户可以自由管理自己的环境,就像拥有一台独立的服务器一样。VPS通过...

    波测评分析及其在医疗与教育领域的重要性

    波测评的定义与重要性 波测评是一种重要的技术手段,专注于评估波动的特性和行为。我发现,这种测评方法在多个行业中都扮演了至关重要的角色,比如医疗、工业和电力等领域。以脑波测评为例,它不仅可以帮助医生了解病人的大脑状态,还能在教育领域评估学习能力。这些应用展示了波测评技术在科学与技术进步中的不可或缺性。...

    银联卡购买:便捷与安全的消费体验

    在这个快速发展的支付时代,银联卡作为一种便捷的支付工具,已经逐渐渗透到我们的日常生活中。我常常发现自己在购物、旅行时,银联卡都能为我省去不少麻烦。通过这张小小的卡片,我可以轻松实现线上和线下消费,四处都能找到它的身影。 银联卡的发展背景十分丰富。自1994年银联成立以来,它不断扩大和完善自己的支付网...

    SpartanHost:高性能托管服务的最佳选择与用户体验深入分析

    说到SpartanHost,我最初的印象是它所承载的使命与愿景。这是一家相对年轻的托管服务提供商,成立的初衷是为了满足越来越多用户日益增长的需求。从我了解的信息来看,SpartanHost用创新和技术驱动为客户提供高质量的主机服务。从简单的个人网站到复杂的在线应用,它都能找到合适的解决方案。 在服务...