frp+公网服务器实现内网穿透方案

frp+公网服务器实现内网穿透方案

总体思路是,利用一个具有公网IP的服务器作为跳板,将内网服务器的ip穿透出去

frp中文地址(安装 | frp)

需要先从GitHub地址(Releases · fatedier/frp)下载对应的frp版本

然后区分两个环境

  • 服务端:就是具有公网IP的服务器
  • 客户端:就是需要穿透出去网络的服务器

一、服务端配置

把下载的frp安装包放置到明确的目录下,并进行解压

解压命令tar -xzf frp_0.65.0_linux_amd64.tar.gz

进入到解压缩的目录下,并查看修改frps.toml文件:

bash 复制代码
[root@iZwz96jppbbfoj33cmme5eZ admin]# cd frp_0.65.0_linux_amd64/
[root@iZwz96jppbbfoj33cmme5eZ frp_0.65.0_linux_amd64]# ls
frpc  frpc.toml  frps  frps.toml  LICENSE
[root@iZwz96jppbbfoj33cmme5eZ frp_0.65.0_linux_amd64]# vim frps.toml 

frps.toml内容如下:

复制代码
bindPort = 7000

我没有使用http映射,也就是不需要域名映射,所以不需要设置vhostHTTPPort

也就是frps.toml没有做任何修改

然后使用文本编辑器 (如 vim) 在 /etc/systemd/system 目录下创建一个 frps.service 文件,用于配置 frps 服务。

bash 复制代码
sudo vim /etc/systemd/system/frps.service

内容如下:

bash 复制代码
[Unit]
# 服务名称,可自定义
Description = frp server
After = network.target syslog.target
Wants = network.target

[Service]
Type = simple
# 启动frps的命令,需修改为您的frps的安装路径
ExecStart = /home/admin/frp_0.65.0_linux_amd64/frps -c /home/admin/frp_0.65.0_linux_amd64/frps.toml

[Install]
WantedBy = multi-user.target

然后可以管理frps了

bash 复制代码
# 启动frp
sudo systemctl start frps
# 停止frp
sudo systemctl stop frps
# 重启frp
sudo systemctl restart frps
# 查看frp状态
sudo systemctl status frps

如果frps的状态如下:

复制代码
[root@iZwz96jppbbfoj33cmme5eZ frp_0.65.0_linux_amd64]# systemctl status frps
● frps.service - frp server
   Loaded: loaded (/etc/systemd/system/frps.service; enabled; vendor preset: disabled)
   Active: active (running) since Fri 2025-10-31 11:52:07 CST; 3h 50min ago
 Main PID: 66736 (frps)
    Tasks: 5 (limit: 22547)
   Memory: 33.1M
   CGroup: /system.slice/frps.service
           └─66736 /home/admin/frp_0.65.0_linux_amd64/frps -c /home/admin/frp_0.65.0_linux_amd64/frps.toml

表示frps正常启动玉兴

需要设置frps为开机启动

bash 复制代码
systemctl enable frps

二、客户端配置

同样需要将下载的frp安装包放置到明确的目录下,并进行解压,这里就不再重复操作了

然后开始配置客户端文件frpc.toml,内容如下:

复制代码
serverAddr = "公网IP地址"
serverPort = 7000

[[proxies]]
name = "minio-console"
type = "tcp"
localIP = "内网IP地址"
localPort = 19090
remotePort = 19090

[[proxies]]
name = "minio"
type = "tcp"
localIP = "内网IP地址"
localPort = 19000
remotePort = 19000

[[proxies]]
name = "app-server"
type = "tcp"
localIP = "内网IP地址"
localPort = 8080
remotePort = 8080

[[proxies]]
name = "web-page"
type = "tcp"
localIP = "内网IP地址"
localPort = 80
remotePort = 80

后台运行frpc,命令如下:

bash 复制代码
nohup ./frpc -c frpc.toml > frpc.log 2>&1 &

查看日志文件frpc.log,如果能看到启动成功的命令,就表示客户端配置完成了

三、公网服务器端口开放

前面用到的19000,19090,8080,80这四个端口都需要开放

四、穿透访问

可以使用公网服务器IP+19090端口测试访问minio控制台,如果能正常访问,代表成功实现了内网穿透

五、总结

frp内网穿透的速度确实要比一些商用但是提供免费共呢个的产品,比如cpolar,ZeroNews等,速度要快很多,我都测试过

但是缺点就是需要有一个公网服务器作为跳板

如果能申请到一些免费的云服务器,确实还是很不错的

相关推荐
vortex510 分钟前
Linux进程权限继承研究:从setuid()到exec()与system()的行为差异
linux·服务器·系统安全·suid
信也科技布道师26 分钟前
从Istio 503 NC 错误深入理解 Mesh 路由全链路原理
java·服务器·网络
云计算磊哥@26 分钟前
运维开发宝典030-MySQL06数据库运维阶段总结
运维·数据库·运维开发
鼎讯信通31 分钟前
性能可拓展+功能一体化 走近 TXMN-BLG1 信号模拟设备
运维·能源·信息与通信
小小小花儿34 分钟前
服务器上修改个人账户权限
linux·服务器
Coisinier37 分钟前
RHCE中shell脚本基础(磁盘剩余空间监控,Web 服务状态检查,curl 访问 Web 服务并返回状态)
linux·运维·服务器·前端·nginx·操作系统
lion_zjg1 小时前
Nextcloud + Collabora CODE 离线包部署安装
运维·服务器
随便做点啥1 小时前
Agent 后台 - Token工场-集群设备配置建议
服务器·经验分享
睡不醒男孩0308231 小时前
生产环境故障销账:PostgreSQL 突发连接数暴涨与死锁,如何利用 CLup 秒级定位与解锁?
运维·数据库
志栋智能2 小时前
从固定周期到动态触发:超自动化巡检的智能调度
运维·网络·自动化