- A+
没有公网IP的用户如何访问内网,比如你在公司有台电脑,这时你在家里想要访问公司电脑文件。那么这时候有什么办法?有人说我用公司VPN,或者公司自有公网IP端口映射,当然办法有很多种,前提条件都是要有公网IP。
今天给大家介绍一款好用内网穿透工具FRP,FRP全名:Fast Reverse Proxy。FRP是一个使用Go语言开发的高级的反向代理应用,可以帮助您轻松地进行内网穿透,对外网提供服务,FRP支持TCP,UDP,HTTP,HTTPS等协议类型,支持并且Web服务根据域名进行路由转发。
开源FRP项目地址:https : //github.com/fatedier/frp
FRP的作用
- 利用位于内网或防火墙后的机器,对外网环境提供HTTP、HTTPS或者远程服务。
- 对于HTTP,HTTPS服务支持基于域名的虚拟主机,支持自定义域名绑定,使多个域名可以共享一个80端口。
- 利用位于内网或防火墙后的机器,对外网环境提供TCP和UDP服务,例如在家里通过SSH访问位于公司内网环境内的主机。
FRP架构
FRP安装
FRP采用Go语言开发,支持Windows,Linux,MacOS,ARM等多平台部署。FRP安装非常容易,只需下载对应系统平台的软件包,并解压就可用了。
这里以Linux为例:
wget https://github.com/fatedier/frp/releases/download/v0.36.2/frp_0.36.2_linux_amd64.tar.gz tar xzvf frp_0.36.2_linux_amd64.tar.gz
最新版本下载地址:https://github.com/fatedier/frp/releases
FRP配置
服务端配置
以Linux为例,替换为FRP两个服务端配置文件,一个是简版的frps.ini,另一个是完整版本frps_full.ini。
先来看下简版的frps.ini,通过这个配置可以快速的建造起一个FRP服务端。
vi frps.ini [common] bind_port = 7000 token = asdfgh #为了安全这里也可以加上一个token验证
- 默认配置中监听的是7000端口,可根据自己实际情况修改。
- 防火墙要放行该端口
启动FRP服务端
chmod 700 frps frps.ini ./frps -c ./frps.ini
服务端简单配置完成
PC客户端配置
类似,或者FRP也可以称为两个客户端配置文件,一个是简版的frpc.ini,另一个是完整版本frpc_full.ini。
同样以简版的frpc.ini文件为例。
[common] server_addr = 公网IP server_port = 7000 token = asdfgh #token和服务端一样 [ssh] type = tcp local_ip = 192.168.2.21 #内网电脑地址或者填写本机环回地址127.0.0.1 local_port = 3389 #内网远程端口 remote_port = 7000
打开cmd,运行frpc.exe
cd C:frp_0.36.2_windows_amd64 frpc.exe
客户端运行如下图
至此客户端已配置完成,为了方便客户端重启失效,这里加个运行脚本,以便无论何时都可以远程(只要客户端PC是开启状态)
一、使用bat脚本后台运行
1、新建bat批处理文件,内容如下
打开刚新建的bat文件,运行图和cmd一样
2、新建vbs开机自动启动脚本文件,命名frpc.vbs
如图:
将改frpc.vbs文件放进windows启动程序中。或者您按下 "Win + R" 键,打开 "运行" 对话框。输入“shell:startup”并按下回车键,打开用户的启动文件夹。在启动文件夹中,将之前创建的frpc.vbs脚本文件复制进来。现在,每次 Windows 10 开机启动时,该frpc.vbs脚本都会被自动执行。
如图:
到此已全部配置完成。
二、使用nssm服务助手放到后台运行(开机可自动启动或手动禁用)
- nssm 点击下载
详细安装见 https://mefj.com.cn/lur3664.html
管理员运行cmd,nssm install frpc
安装完 nssm start frpc 启动即可,重启pc远程连接,检查服务是否自动启动。
- 启动服务:
nssm start <servicename>
- 停止服务:
nssm stop <servicename>
- 重启服务:
nssm restart <servicename>
- 编辑服务参数:
nssm edit <servicename>
- 删除服务:
nssm remove <servicename>
可选项
给FRP服务端增加一个仪表板
通过Dashboard可以方便的查看FRP的状态以及代理统计信息展示,要使用这个功能首先需要在FRP服务端配置文件中指定Dashboard服务使用的端口:
$ vim frps.ini [common] #指定Dashboard的监听的IP地址 dashboard_addr = 公网IP地址 #指定Dashboard的监听的端口 dashboard_port = 7500 #指定访问Dashboard的用户名 dashboard_user = admin #指定访问Dashboard的端口 dashboard_pwd = admin #打开普罗米修斯 enable_prometheus = true
普罗米修斯
首先启用仪表板,然后enable_prometheus = true在中进行配置frps.ini。
http://{dashboard_addr}/metrics 将提供普罗米修斯监测器数据。
防火墙放行7500
firewall-cmd --zone=public --add-port=7500/tcp --permanent
查看所有已打开的端口
firewall-cmd --zone=public --list-ports
通过公网IP地址:7500访问Dashboard界面,用户名 admin 密码admin。
登录如图
- 微信公众号
- 扫一扫关注微信公众号
- 运维交流群
- 扫一扫二维码加入群聊