frp+nginx实现网络穿透及windows远程桌面连接
前言
之前写过一篇ngrok+nginx实现windows远程桌面连接实现了在公司远程连接家里的电脑,最近发现另一个开源网络穿透frp似乎更优秀,其在git的star达到了61.4k,本篇就是用frp搭建网络穿透。
frp 是什么?
官方的解释为
frp is a fast reverse proxy to help you expose a local server behind a NAT or firewall to the Internet. As of now, it supports TCP and UDP, as well as HTTP and HTTPS protocols, where requests can be forwarded to internal services by domain name.
frp also has a P2P connect mode.
frp 是一种快速反向代理,可帮助您将 NAT 或防火墙后面的本地服务器暴露给 Internet。 目前,它支持 TCP 和 UDP,以及 HTTP 和 HTTPS 协议,可以通过域名将请求转发到内部服务。
frp 还有一个 P2P 连接模式。
简单来说,你个人本地web服务,通过与frp的服务建立隧道连接,然后别人就可以通过访问frp服务来访问你的本地服务了。
frp的git地址: https://github.com/fatedier/frp
frp官方文档: https://gofrp.org/docs/overview/
官方文档罗列了相关概念和操作,要是有能力尽量阅读官方文档。
frp 的下载
frp可以在release页面进行下载,当前的最新版本为0.045,客户端和服务端为同一个,只不过配置和启动命令不同,大家可以根据自己的操作系统进行下载,要是linux不知道下载那个那个文件,可以查看linux cpu 指令集架构 RISC / CISC | arm | amd | X86/i386 | aarch64这篇文章了解cpu对应的指令集架构下载对应的软件包。
frp 服务端
frp 服务端配置
frp的服务端配置文件为frp文件夹下的frps.ini文件,具体完整的配置可以参考frps_full.ini文件.
本人的一个配置为
1 | # 模块名 |
frp 服务端启动
标准的启动命令为
1 | /frp_path/frps -c /frp_path/frps.ini |
frp 的部署
只使用命令,当我们推出linux shell后,服务就暂停了,这不是我们想要的结果,部署有两种方式,使用systemd及后天运行脚本。
systemd
systemd为官方推荐的部署方式,参考官方文档 使用 systemd
后台运行
我们也可以使用linux后台运行命令自己部署
1 | nohup /frp_path/frps -c /frp_path/frps.ini & |
frp 客户端
frp 客户端配置
frp的客户端配置文件为frp文件夹下的frpc.ini文件,具体完整的配置可以参考frpc_full.ini文件.
本人的一个配置为
1 | # frpc.ini |
frp 客户端启动
标准的启动命令为
1 | ./frpc -c ./frpc.ini |
frp 的部署
linux 下推荐使用 systemd
windows下推荐自己编写.bat文件,然后配置为开机启动项,windows的开机启动配置可以参考win10 开机启动,无需登录
域名配置
登录你的域名管理,配置frp.xxx.com
及*.frp.xxx.com
指向你的frp server地址
nginx 配置
一个简单的nginx配置如下
1 | server { |
本质上就是当后续使用服务的时候,如访问者访问http://web1.frp.xxx.com 时,将请求转交给frp server处理。
frp 的使用情况
登录 http://server ip:7091 进行访问,端口为之前服务端的dashboard_port配置。
服务的使用
远程桌面连接
通过以下地址 frp.xxx.com:3389 进行连接
http接口或页面
如果是页面,直接访问 web1.frp.xxx.com ,输入用户名密码后即可进行访问
如果是程序调用,需要加上 Authorization 的header,具体可以参考文章 JAVA Http Basic auth
自问自答
frp的客户端和服务端通信安全如何保障?
参考身份认证 ,目前 frpc 和 frps 之间支持两种身份验证方式,token 和 oidc,默认为 token。
我暴露的服务如何保障安全
http相关的可以通过设置 BasicAuth 鉴权实现简单的认证。
复杂可以通过安全地暴露内网服务,这样服务只能被部署了visitor frp client的机器访问,缺点是需要部署frp cli。
完结
至此,使用frp搭建的http穿透及远程桌面连接已顺利实现。