Linux下FRP内网穿透配置教程
时间:2026-03-04 12:45:59 279浏览 收藏
本文深入解析了使用FRP实现Linux内网穿透的五大关键实践要点,直击新手高频踩坑场景:从服务端必须监听0.0.0.0而非127.0.0.1以确保外网可达,到客户端正确填写公网IP或域名、严格匹配token;从Web服务映射中vhost_http_port与custom_domains的协同配置,到systemd托管时路径、权限与工作目录的精准设置;最后强调FRP本质是稳定长连接代理,真正决定成败的是网络层的端口可达性、DNS解析和防火墙策略——掌握这些,才能绕过“connection refused”和超时陷阱,高效打通内外网访问链路。

FRP服务端必须监听公网IP或0.0.0.0,不能只绑127.0.0.1
很多用户启动 frps 后发现客户端连不上,日志里反复出现 connection refused 或超时,根本原因是服务端配置里写了 bind_addr = 127.0.0.1。内网穿透的前提是外网能访问到FRP服务端,所以它必须暴露在可路由的地址上。
实操建议:
- 检查
frps.ini中的bind_addr:留空或设为0.0.0.0(默认行为),避免硬写127.0.0.1 - 确认云服务器安全组/防火墙放行了
bind_port(默认7000)和你后续配的自定义端口(如8080、2222等) - 用
netstat -tuln | grep :7000验证监听地址是否为*:7000,而不是127.0.0.1:7000 - 如果服务器有多个网卡(比如同时有公网IP和内网IP),
bind_addr可明确指定公网IP,但不要写错
客户端frpc.ini里server_addr不能填localhost或127.0.0.1
这是最常踩的坑:把服务端部署在阿里云ECS上,却在本地 frpc.ini 里写 server_addr = localhost。这会让客户端尝试连自己本机的7000端口,当然失败。
正确做法:
server_addr必须填FRP服务端的真实公网IP(如123.56.78.90)或已解析到该IP的域名- 如果服务端开了HTTPS或用了CDN,别误以为能走HTTP协议——
frpc和frps通信走的是自研TCP协议,不经过HTTP代理 - 若服务端启用了
token,客户端frpc.ini中的token值必须完全一致,大小写敏感 - 首次调试建议关闭服务端的
vhost_http_port等高级功能,先用最简TCP映射(比如远程桌面3389或SSH 22)验证链路通不通
映射Web服务时vhost_http_port和custom_domains要配套使用
想让外网通过 http://test.yourdomain.com 访问内网Web服务,不能只靠 type = http,还必须启用HTTP虚拟主机模式。
关键配置组合:
- 服务端
frps.ini中需开启vhost_http_port = 8080(或其他非80端口,避开权限限制) - 客户端
frpc.ini对应的proxy段中,必须同时设置type = http、custom_domains = test.yourdomain.com、local_port = 80(对应内网Web服务端口) - 域名
test.yourdomain.com需提前解析到FRP服务端的公网IP;如果服务端在NAT后(如家庭宽带),这条路基本走不通,得换用TCP直连模式 - 注意:
vhost_http_port是服务端接收HTTP请求的入口端口,不是内网服务端口;浏览器访问的是http://test.yourdomain.com:8080(除非你用iptables或反向代理把80转到8080)
systemd托管frpc后无法读取用户级配置文件路径
把 frpc 加进systemd服务后,经常出现“config file not found”或“permission denied”,根源是systemd默认以root用户运行,且工作目录不是你放 frpc.ini 的地方。
解决方法很具体:
- 在service文件(如
/etc/systemd/system/frpc.service)的[Service]段中,显式指定WorkingDirectory=/etc/frp(假设ini放在那里) - 用绝对路径写
ExecStart=/usr/local/bin/frpc -c /etc/frp/frpc.ini,别依赖相对路径 - 如果配置文件里用了
user或group字段,确保对应用户对log_file路径有写权限,否则frpc会静默退出 - 调试时先手动运行一遍命令,确认无报错再reload systemd:运行
sudo systemctl daemon-reload && sudo systemctl start frpc,再用sudo journalctl -u frpc -f看实时日志
FRP本身不处理NAT穿越,也不加密业务流量(TLS需额外配置),它的核心价值是稳定维持长连接+端口复用。真正卡住的往往不是配置语法,而是网络层可见性——服务端端口是否可达、客户端能否建连、DNS是否生效,这些比写对ini文件重要得多。
以上就是《Linux下FRP内网穿透配置教程》的详细内容,更多关于的资料请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
263 收藏
-
109 收藏
-
438 收藏
-
230 收藏
-
351 收藏
-
350 收藏
-
472 收藏
-
467 收藏
-
147 收藏
-
203 收藏
-
380 收藏
-
459 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习