Ubuntu下使用FRP

实验室服务器没有公网IP,但是有时候又需要在外网下远程连接跑代码。师兄之前一直用frp做内网穿透,我也学习一下~~

参考:https://www.iplaysoft.com/frp.html
项目地址:https://github.com/fatedier/frp

0. 准备

首先在内网需要有运行Frp 的客户端,我这里就是实验室的服务器了
其次要有运行Frp 的服务端,它需要有公网IP,我这里用的是阿里云九块九的学生机

1. 什么是Frp

内网穿透工具有很多,其中 Frp (Fast Reverse Proxy) 是比较流行的一款。FRP是一个免费开源的用于内网穿透的反向代理应用,它支持 TCP、UDP 协议, 也为 http 和 https协议提供了额外的支持。你可以粗略理解它是一个中转站,帮你实现公网 ←→ FRP(服务器) ←→ 家庭内网的连接,让内网里的设备也可以被公网访问到。
在这里插入图片描述

2. 安装配置Frp服务端(外网机器)

2.1 下载对应系统平台的软件包解压:

export FRP_VERSION=0.34.0
sudo mkdir -p /etc/frp
cd /etc/frp
sudo wget "https://github.com/fatedier/frp/releases/download/v${FRP_VERSION}/frp_${FRP_VERSION}_linux_amd64.tar.gz"
sudo tar xzvf frp_${FRP_VERSION}_linux_amd64.tar.gz
sudo mv frp_${FRP_VERSION}_linux_amd64/* /etc/frp
  • 其中,第一行等号后面的 0.34.0 是 frp 的版本号 (可以去github项目地址查看)。
  • FRP 默认提供了 2 个服务端配置文件,一个是简化版的 frps.ini,另一个是完整版的 frps_full.ini。初学者只需用简版配置即可,在简版 frps.ini 配置文件里,默认设置了监听端口为 7000,你可以按需修改它。
如果wget下载太慢直接到GitHub上下载压缩包然后上传也可...,我下载好慢啊

2.2 相关配置:

修改frps.ini:

[common]
bind_port = 9000    
token = 123456
vhost_http_port = 9003
  • bind_port 设置了 frp 服务器用户接收客户端连接的端口
  • token 和客户端一致
  • vhost_http_port 设置监听 HTTP 请求端口为 8080

2.3 安全组开放指定的端口:

以阿里云为例,根据上面的配置以及下面客户端的配置,我开放的是9000、9003和6000端口(9000是监听端口,9003是访问我web服务的端口,6000是ssh连接端口,具体在后面内网机器配置中):
在这里插入图片描述

2.4 启动 FRP 服务端:

./frps -c frps.ini
# 或者后台运行(说明:>/dev/null 2>&1 &,表示丢弃)
nohup ./frps -c frps.ini >/dev/null 2>&1 &

启动成功:
在这里插入图片描述

3. 安装配置Frp客户端(内网机器)

3.1 常用配置:

修改frpc.ini:

[common]
server_addr = 公网IP
token = 123456
server_port = 9000 


[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6000

[web]
type = http
local_port = 9003
custom_domains = 公网IP或域名
  • server_port 与服务端的bind_port 相同

3.2 启动 FRP 客户端:

Frp 的客户端程序 frpc (frpc.exe) 与服务器端都在同一个压缩包里, 我们同样下载安装对应系统版本的软件包。
运行:

./frpc -c frpc.ini
# 或者后台运行
nohup ./frpc -c frpc.ini >/dev/null 2>&1 &

4. 设置frp自启动

我们使用 ubuntu Linux下常用的进程管理器supervisor来管理FRP服务。

  1. 首先需要安装supervisor。
sudo apt install supervisor
  1. 然后在/etc/supervisor/conf.d下新建一个配置文件frp.conf,输入以下内容。command应该是你放置frp软件的位置。
[program:frp]
command = /root/frps -c /root/frps.ini
autostart = true
  1. 然后启动supervisor,如果事先已经安装好了supervisor那么就重新启动。之后查看一下supervisor的运行状态,看看frp是否已在运行。
# 启动supervisor
sudo systemctl start supervisor

# 重启supervisor
sudo systemctl restart supervisor

# 查看supervisor运行状态
sudo supervisorctl status
  1. 查看frp是否启动
ps aux | grep frp
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要在Ubuntu使用FRP实现内网穿透,您需要按照以下步骤进行操作: 1. 在服务器和设备上分别安装FRP服务器端和客户端软件。您可以参考FRP的Github页面获取详细的安装说明\[1\]。 2. 在服务器端和客户端的配置文件中进行相应的设置。服务器端的配置文件是frps.ini,客户端的配置文件是frpc.ini。您可以使用文本编辑器打开这两个文件进行修改\[3\]。 3. 在服务器和客户端的系统服务中添加FRP服务。您可以创建一个服务文件,并在其中写入相应的内容。具体的步骤可以参考一篇博客文章\[2\]。 4. 打开服务并开启开机自启动。您可以使用systemctl命令来启动和停止FRP服务,并使用enable命令来设置开机自启动\[2\]。 5. 运行FRP。在服务器端和客户端分别运行相应的命令来启动FRP服务\[2\]。 请注意,上述步骤中的路径和配置信息需要根据您的实际情况进行修改。确保您已经正确设置了服务器端的公网IP地址、端口号以及登录后台的账户和密码\[3\]。 希望以上信息对您有所帮助!如果您还有其他问题,请随时提问。 #### 引用[.reference_title] - *1* *2* *3* [Ubuntu18 使用FRP实现内网穿透](https://blog.csdn.net/surtol/article/details/120354598)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值