新闻| 文章| 资讯| 行情| 企业| wap手机版| article文章| 首页|会员中心|保存桌面|手机浏览
普通会员

昌乐市海露科技公司

企业列表
新闻列表
  • 暂无新闻
推荐企业新闻
联系方式
  • 联系人:赵先生
首页 > 新闻中心 > Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程
新闻中心
Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程
发布时间:2024-11-17        浏览次数:0        返回列表

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

Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

  • 服务端环境:centos7(公网服务器) 、docker

  • 客户端环境:win10

    使用场景两台windos机器间前后端进行代码连接调试,使用中间服务器作为中转。

  1. 安装Docker

     

    Docker安装参考

  2. 拉取最新Frp镜像

     
  3. 在某个目录下新建配置文件 frps.ini ,内容如下我的在/frpConfig/下。

     
  4. 在某个目录下新建frp-restart.sh文件,内容如下,我是在根目录下(不要一股脑复制,要注意配置文件的路径

     
  5. 运行frp-restart.sh,检查docker出现如下,运行成功Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

注意上面7000、7500要在安全组中放开。访问ip:7500出现面板表示成功,密码是配置文件中设置的账户密码。Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

  1. 客户端我选用的是frp_0.54.0_windows_amd64,可以参考。该版本下与之前的老版本不一样,配置文件有了些许变动(弃用了之前frpc.ini)。但是还可以直接新建。Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

     

    注意保存后,不要直接点击,frpc.exe ,只是控制台程序,需要用cmd进行运行。

    Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

    Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

    ​ 如图表示成功,我代理一个mysql,现在就可以用公网ip和16000,访问本地Mysql数据库了。这边完成了frp内网穿透的基本搭建,这时候可以拓展很多个TCP连接,但是http和https只能有一条,这也是比较头疼的,之后我可能会解决该问题。

  • 另一种方式直接安装,建议下载0.50.0以下版本。

    Frp 内网穿透服务器基于Docker+Nginx搭建 保姆间级别最细教程

    解压重名为frp,进入frp,编写frps.ini文件。

    配置与上面所说的一样,然后在当前目录启动后,并且设置后台运行,也能达到一样的效果。

     

需要一个域名,和N个子级域名,看情况映射而定。 是一个用语言开发的,可用于的高性能的反向代理应用,支持 tcp, udp 、 http、stcp 和 https。可将一个部署在本机的web服务映射到外网。

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

  1. 所需资源介绍

     

    本次采用的Nginx为nginx-1.19.2 ,其余环境如上。

  2. frp 原理

以本人搭建的内网穿透服务为例

第一步 配置无误的情况下frp服务端frp客户端先后启动,建立,其中

  • frp服务端在公网服务器运行,监听http 端口(此端口可自定义,接收此端口下所有外网用户请求
  • frp客户端在你本地运行,代理本地想要暴露给外网的web服务端口,本文以 , 端口为例

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

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

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

  • 监听到http请求中的域名为 ,则将请求转发到我本地的web服务端口
  • 监听到http请求中的域名为 ,则将请求转发到我本地的web服务端口

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

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

第六步 最终的实测效果为

  • 访问 ,等同于访问我本地的
  • 访问 ,等同于访问我本地的

本文采用Docker安装frp不需要进行Go语言环境安装。

服务端配置我已经在上面配置一部分,需要在上面添加修改即可。

 

修改后需要重新启动Docker内的frp镜像。运行frp-restart.sh脚本。

Nginx 如何安装占时不介绍了,可以自行安装,或者我后期补充。

  • 安装Nginx依赖

     

conf目录中配置nginx.conf