ToB企服应用市场:ToB评测及商务社交产业平台

标题: Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程 [打印本页]

作者: 我可以不吃啊    时间: 2024-7-13 15:22
标题: Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程
Frp 内网穿透服务器基于Docker+Nginx搭建

前言介绍

​ 原先利用的内网穿透服务,natapp、花生壳等三方内网穿透服务,特点方便,但是条数少,有带宽限制,还要实名认证。过于麻烦,本身预备搭建Frp个人穿透服务器。网上教程杂乱不敷具体,特此记载,以便后面需要搭建方便。可以说这是最具体的一篇了。爆肝一天,渴望收藏夹点赞!!!
牢记利用多条http/https映射时,如果是国内服务器,域名需存案。国外的服务器不需要。原本是利用国内的服务器,利用了域名被停止叫存案。TCP协议不收任何影响。
安装环境


安装步骤

注意上面7000、7500要在安全组中放开。访问ip:7500出现面板表示成功,暗码是配置文件中设置的账户暗码。


结合Nginx配置多条http穿透

需要一个域名,和N个子级域名,看环境映射而定。frp 是一个用Go语言开发的,可用于内网穿透的高性能的反向代理应用,支持 tcp, udp 、 http、stcp 和 https。可将一个摆设在本机的web服务映射到外网。
接下来主要讲怎样基于frp + nginx 配置http 内网穿透服务,承载多人同时利用,从而支持微信公众号,微信小程序的当地开发调试
以本人搭建的frp内网穿透服务为例:
第一步: 配置无误的环境下,frp服务端frp客户端先后启动,建立通信隧道,其中:

第二步: 通过配置nginx反向代理,将指向本台公网服务器的dev.msh.com 下的子域名,映射到服务器的8888端口,也就是frp监听的那个端口。 外网用户访问xiao.games下的子域名,例如 :

等同于访问xiao.games:8888,会 触发 frp服务端和客户端的互动,从而http哀求由frp服务端通报到frp客户端。
第三步: frp客户端收到http哀求后,基于自定义配置,则做如下处置惩罚:

第四步: 当地的web服务收到http哀求后,对哀求做处置惩罚,并完成响应
第五步: frp客户端将响应结果回传给frp的服务端。服务端最终将响应回传给外网用户
第六步: 最终的实测结果为:

关于GO语言环境

本文采用Docker安装frp不需要进行Go语言环境安装。
服务端配置

服务端配置我已经在上面配置一部分,需要在上面添加修改即可。
  1. bind_port = 7000
  2. # 启用面板
  3. dashboard_port = 7500
  4. # 面板登录名和密码
  5. dashboard_user = admin
  6. dashboard_pwd = admin(随意填写)
  7. # 使用http代理并使用8888端口进行穿透
  8. vhost_http_port = 8888
  9. # 使用https代理并使用9999端口进行穿透
  10. vhost_https_port = 9999
  11. # 日志路径
  12. log_file = ./frps.log
  13. # 日志级别
  14. log_level = info
  15. # 日志最大保存天数
  16. log_max_days = 2
  17. # 认证超时时间
  18. authentication_timeout = 900
  19. # 认证token,客户端需要和此对应
  20. token=123123123
  21. # 最大连接数
  22. max_pool_count = 50
  23. max_ports_per_client = 0
  24. # 服务端的subdomain_host需要和客户端配置文件中的subdomain、local_port配合使用,
  25. # 可通过{subdomain}.{subdomain_host} 的域名格式来访问自己本地的 web 服务。
  26. # 假如服务端的subdomain_host为dev.msh.com,客户端某个配置组中的
  27. # subdomain为a,local_port为8585,
  28. # 则:
  29. # 访问 a.dev.msh.com ,等同于访问本地的localhost:8585
  30. subdomain_host = dev.xiao.games;
复制代码
修改后需要重新启动Docker内的frp镜像。运行frp-restart.sh脚本。
nginx反向代理配置

Nginx 怎样安装占时不介绍了,可以自行安装,大概我后期补充。

conf目录中配置nginx.conf
  1.     server {
  2.                 listen 80;
  3.                 server_name *.dev.xiao.games;
  4.                 location / {
  5.                         #8888端口即为frp监听的http端口
  6.                         proxy_pass http://127.0.0.1:8888;
  7.                         proxy_set_header Host $host:80;
  8.                         proxy_set_header X-Real-IP $remote_addr;
  9.                         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  10.                         proxy_set_header Upgrade $http_upgrade;
  11.                         proxy_set_header Connection "upgrade";
  12.                         proxy_connect_timeout 7d;
  13.                         proxy_send_timeout 7d;
  14.                         proxy_read_timeout 7d;
  15.                         }
  16.                 # 防止爬虫抓取
  17.                 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")
  18.                         {
  19.                                 return 403;
  20.                         }
  21.         }
  22.         
  23.         server {
  24.         listen 80;
  25.         server_name dev.xiao.games;
  26.         location / {
  27.                proxy_pass http://127.0.0.1:7500;
  28.                proxy_set_header Host $host;
  29.                proxy_set_header X-Real-IP $remote_addr;
  30.                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  31.                proxy_set_header Upgrade $http_upgrade;
  32.                proxy_set_header Connection "upgrade";
  33.                proxy_connect_timeout 7d;
  34.                proxy_send_timeout 7d;
  35.                proxy_read_timeout 7d;
  36.                    }
  37.           }
  38.         server {
  39.             listen 80 default_server;
  40.             server_name  xiao.games;
  41.             location / {
  42.                  return 200 'success';
  43.             }
  44.         }
复制代码
参考文档:
链接:https://juejin.cn/post/6844903766701899784

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4