博主信息
弘德誉曦的博客
博文
137
粉丝
1
评论
0
访问量
115796
积分:1
P豆:431

使用frp实现内网穿透

2021年10月24日 19:25:41阅读数:176博客 / 弘德誉曦的博客/ linux


使用frp实现内网穿透

原文: https://www.jianshu.com/p/e8e26bcc6fe6

原文: https://blog.csdn.net/weixin_43922901/article/details/109261700 

原文地址:http://www.sunnyrx.com/2016/10/21/simple-to-use-frp/

该文章于2019年8月5日将frp版本从0.20.0更新到0.24.1,下文针对frp 0.24.1配置。

NAS没有公网IP是一件很不方便的事情,尤其是在国内的网络环境,学校和小区内的用户通常都没有公网IP。为了解决这个问题,则需要内网穿透,而内网穿透的方法有很多种,例如使用花生壳ngrok等,该文章要介绍的是使用frp让群晖实现内网穿透。

实际上frp有官方的中文文档,上面的内容已经非常详尽,对相关操作比较熟悉的人可以直接阅读官方的中文文档。

什么是frp

frp 是一个高性能的反向代理应用,可以帮助您轻松地进行内网穿透,对外网提供服务,支持 tcp, http, https 等协议类型,并且 web 服务支持根据域名进行路由转发。

准备

在使用frp之前,需要一台有公网IP的服务器(下文称外网主机),一台需要实现内网穿透的机器(下文称内网主机),SSH工具,以及一个域名(如果只是建立SSH反向代理则不需要域名)。

该文章中笔者所使用的服务器是朋友推荐的Vultr服务器,虽然服务器是在国外,但胜在带宽够,有需要的朋友可以注册一个。而需要实现内网穿透的机器则是笔者用上网本搭建的黑群晖。SSH工具使用的是Xshell 5。而域名笔者则是使用自己个人网站的域名。

开始使用

根据机器的操作系统,在Release页面中找到对应的frp程序,然后分别在外网主机和内网主机中下载它。

下面的所示范用的frp程序版本是以笔者的服务器为主的。

外网主机

SSH连接上外网主机后,使用wget指令下载frp。

wget https://github.com/fatedier/frp/releases/download/v0.24.1/frp_0.24.1_linux_amd64.tar.gz

使用tar指令解压tar.gz文件

tar -zxvf frp_0.24.1_linux_amd64.tar.gz

使用cd指令进入解压出来的文件夹

cd frp_0.24.1_linux_amd64/

外网主机作为服务端,可以删掉不必要的客户端文件,使用rm指令删除文件。

rm -f frpc
rm -f frpc.ini

接下来要修改服务器配置文件,即frps.ini文件。使用vi指令对目标文件进行编辑。

vi frps.ini

打开frps.ini后可以看到默认已经有很多详细的配置和示范样例,该文章仅以达到内网穿透为目的,所以这里选择删掉或注释掉里面的所有内容,然后根据群晖的情况,按照官方的中文文档添加以下配置。(这里的操作都使用vi命令,关于vi命令的使用方式这里不作详细介绍,可以自行搜索相关使用方法。)

[common]bind_port = 7000vhost_http_port = 8080

[common]部分是必须有的配置,其中bind_port是自己设定的frp服务端端口,vhost_http_port是自己设定的http访问端口。

保存上面的配置后,使用以下指令启动frp服务端。(如果需要在后台运行,请往下翻阅关于后台运行的部分。)

./frps -c ./frps.ini

服务端的工作就到此结束了。

客户端

客户端前面的操作和服务端是一模一样的,这里不一一解释。

wget https://github.com/fatedier/frp/releases/download/v0.24.1/frp_0.24.1_linux_amd64.tar.gz
tar -zxvf frp_0.24.1_linux_amd64.tar.gz
cd frp_0.24.1_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 = 6000
[nas]
type = http
local_port = 5000
custom_domains = no1.sunnyrx.com
[web]
type = http
local_port = 80
custom_domains = no2.sunnyrx.com

上面的配置和服务端是对应的。

[common]中的server_addr填frp服务端的ip(也就是外网主机的IP),server_port填frp服务端的bind_prot

[ssh]中的local_port填群晖的ssh端口。

[nas]中的type对应服务端配置。local_port填群晖的DSM端口。custom_domains为要映射的域名,记得域名的A记录要解析到外网主机的IP。

[web]同上,local_port填群晖的web端口。这里创建了两个http反向代理是为了分别映射群晖两个重要的端口,500080,前者用于登录群晖管理,后者用于群晖的Web StationDS Photo

保存配置,输入以下指令运行frp客户端。(同样如果需要在后台运行,请往下翻阅关于后台运行的部分。)

./frpc -c ./frpc.ini

此时在服务端会看到"start proxy sucess"字样,即连接成功。

现在可以用SSH通过外网主机IP:6000和群晖建立SSH连接。通过浏览器访问no1.sunnyrx.com:8080打开群晖nas的管理页面,访问no2.sunnyrx.com:8080打开群晖Web Station的网站,DS Photo app可以连接no2.sunnyrx.com:8080进入DS Photo管理。

让frp在后台运行

虽然现在frp运作起来了,内网穿透也实现了,但这还是不够的。此时如果断开与服务端或者客户端的SSH连接(比如关掉了Xshell)也就中止了frp的运行。

保持frp运行是关键是让服务端的frp和客户端的frp在后台运行,这里提两个方法供参考,一个是使用screen指令,另一个是使用nohup指令。nohup相对简单很多,这里就只介绍nohup了。

使用nohup指令

nohup指令的使用方法相对简单,只需要在nohup后面加上frp的运行指令即可。下面示范的指令是运行frp客户端。(同样,如果之前断开了SSH连接,记得用cd指令进入frp的目录先。)

下面分别是服务端和客户端的frp运行指令。

服务端:

nohup ./frps -c ./frps.ini &

客户端:

nohup ./frpc -c ./frpc.ini &

这样就成功让frp在后台运行了。

设置开机自启动

服务器因为一些人为或者其他不可抗力导致的服务器关机重启,这时如果没有开机自启动,可能需要你在服务器旁边开机这个frp的服务,要不然内网穿透不了,远程访问失败。

三个关键文件

  1. frpc  (这里指frpc的启动程序)
  2. frpc.ini    (配置文件)
  3. frpc.service   (包装成一种服务)

部署步骤

  1. frpc启动程序(frpc)配置文件(frpc.ini)复制到相应的目录
#这里需要cd到加压缩frp压缩包的文件位置,解压后会看到文件里有frpc的启动程序
sudo cp frpc /usr/local/bin/frpc
sudo mkdir /etc/frpc
sudo cp frpc.ini /etc/frpc/frpc.ini
  1. 为frpc创建systemd的service文件
sudo vim /usr/lib/systemd/system/frpc.service
  1. 编辑frpc.service
[unit]Description=frpcAfter=multi-user.targe[Service]TimeoutStartSec=30ExecStart=/usr/local/bin/frpc -c /etc/frpc/frpc.iniExecStop=/bin/kill $MAINPID[Install]WantedBy=multi-user.target
  1. 启动frpc服务
sudo systemctl enable frpc
sudo systemctl start frpc
  1. 查看frpc服务是否生效
sudo systemctl list-units |grep frpc

只要显示frpc.service loaded active running 就表示服务开启成功

  1. 查看服务日志
sudo systemctl status frpc

按键q退出

总结

一般出错都是在frpc启动程序的路径和frpc.ini文件路径不对,导致服务开启失败。

版权申明:本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!

全部评论

文明上网理性发言,请遵守新闻评论服务协议

条评论
  • 使css可以将页的大部分甚至是全部的表示信息(样式)从HTML文件中移出,样式和容分离;这样可以降低文件大小、节省络带宽,避免样式代码重复,使得维护更容易,可以使相同的容加以不同的样式来不同的目的
    JavaScript是前端技术中非常重要的容,各种动态效果,提升户体验感;若关闭JavaScript会造成页面上很多功能无法使使站体验差或站部分功能无法使
    JavaScript是前端技术中非常重要的容,各种动态效果,提升户体验感;若关闭JavaScript会造成页面上很多功能无法使使站体验差或站部分功能无法使
    python络爬虫的方法:1、使request库中的get方法,请求url的容;2、【find()】和【find_all()】方法可以遍历这个html文件,提取指定信息。
    css最大的优点是:可以样式信息与容分离。css是于增强控制页样式并允许将样式信息与容分离的一种标记性语言,它扩充了 HTML各标记的属性设定,使容的视觉效果有更多变化。
    PHP经常性地使信息传输,这也是PHP为动态页应运而生的缘由,对于信息量极少的,我们可能会使GET,但是数据容较多时我们会使POST,本文就带大家一起来看一看。
    css样式表可以帮助开发者从如何展示一个文档的琐事中分离出文档的信息容,即把样式从容中分离出来;这样做的好处:1、可以使相同的容加以不同的样式来不同的目的;2、避免重复;3、使得维护更容易;
    CSS指的是层叠样式表,一种来表HTML或XML等文件样式的计算机语言,是可以做到页和容进行分离的样式语言。
    python爬取微博热搜存入Mysql最终的效果使的库目标分析一:得到数据二:链接数据库总代码最终的效果废话不多少,直接上图这里可以清楚的看到,数据库里包含了日期,容,和站link下面我们来分析怎么使的库
    通常在做站的时候,需要在每一篇文章中出与该文章相关的文章列表。对于大多数人来说,使的方法通常是,建立一个关键词列表,判断每篇文章包含有那些关键词,最后根据关键词找出与某篇文章最相关的文章。