业务场景,有一批网关分布在各个地方,而客户在某个地方有个中央服务器,我们需要在中央服务器上部署一个堡垒机也就是jumpServer,然后所有的硬件以frp的方式穿透到中央服务器,然后我们通过堡垒机也就可以顺利的ssh到所有的网关,这样就方便维护网关程序了。
首先需要给一篇讲解的比较好的帖子
然后frp也有个官网文档,推荐朋友们学习:https://github.com/fatedier/frp/blob/master/README_zh.md
我这边会摘一部分帖子中的内容,然后还会结合我自己的使用给大家讲解。
1.什么是frp
frp是一个高性能的反向代理应用,可以帮助您轻松地进行内网穿透,对外网提供服务,支持 tcp, http, https 等协议类型,并且 web 服务支持根据域名进行路由转发。
2.准备
在使用frp之前,需要一台有公网IP的服务器(下文称外网主机),一台需要实现内网穿透的机器(下文称内网主机),SSH工具,以及一个域名(如果只是建立SSH反向代理则不需要域名)。
3.部署服务端的frp
我们在公网服务器端需要部署一个服务端的frp
wget https://github.com/fatedier/frp/releases/download/v0.20.0/frp_0.20.0_linux_amd64.tar.gz
tar -zxvf frp_0.20.0_linux_amd64.tar.gz
cd frp_0.20.0_linux_amd64/
外网主机作为服务端,可以删掉不必要的客户端文件,使用rm指令删除文件。
rm -f frpc
rm -f frpc.ini
接下来要修改服务器配置文件,即frps.ini文件。使用vi指令对目标文件进行编辑。
vi frps.ini
打开frps.ini后可以看到默认已经有很多详细的配置和示范样例,该文章仅以达到内网穿透为目的,所以这里选择删掉或注释掉里面的所有内容
[common]
bind_port = 7000
[common]部分是必须有的配置,其中bind_port是自己设定的frp服务端端口,vhost_http_port是自己设定的http访问端口。
保存上面的配置后,使用以下指令启动frp服务端,这里我们使用了nohup来后台运行frpc,这样如果会话关闭,程序也不会挂掉。
nohup ./frpc -c ./frpc.ini &
服务端的工作就到此结束了。
4.客户端的frp配置
这里我们到内网的服务器来:
wget https://github.com/fatedier/frp/releases/download/v0.20.0/frp_0.20.0_linux_amd64.tar.gz
tar -zxvf frp_0.20.0_linux_amd64.tar.gz
cd frp_0.20.0_linux_amd64
rm -f frps
rm -f frps.ini
vi frpc.ini
[common]
server_addr = x.x.x.x
server_port = 7000
[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 22000
上面的配置和服务端是对应的。
[common]中的server_addr填frp服务端的ip(也就是外网主机的IP),server_port填frp服务端的bind_prot。
[ssh]中的local_port填ssh端口。
[nas]中的type对应服务端配置。local_port填端口。custom_domains为要映射的域名,记得域名的A记录要解析到外网主机的IP。
[web]同上,local_port填web端口22000
保存配置,输入以下指令运行frp客户端
nohup ./frpc -c ./frpc.ini &
接下来需要讲解下如何在堡垒机页面配置,然后frp需要配置成开机自启动
5.frp开机启动设置
贴一个帖子供大家参考
添加systemd配置文件:
vim /usr/lib/systemd/system/frp.service
文件内容如下:
[Unit]
Description=The nginx HTTP and reverse proxy server
After=network.target remote-fs.target nss-lookup.target
[Service]
Type=simple
ExecStart=/usr/local/frp/frps -c /usr/local/frp/frps.ini
KillSignal=SIGQUIT
TimeoutStopSec=5
KillMode=process
PrivateTmp=true
StandardOutput=syslog
StandardError=inherit
[Install]
WantedBy=multi-user.target
ExecStart的内容请根据自己frp安装目录修改。
设置开机启动
systemctl daemon-reload
systemctl enable frp
启动 frp
systemctl start frp
查看frp是否启动
ps aux | grep frps
centos7 查看启动服务项
使用 systemctl list-unit-files 可以查看启动项
左边是服务名称,右边是状态,enabled是开机启动,disabled是开机不启动
可以使用 systemctl status xxx.service查看服务状态
至此完结。