使用 frp 实现内网穿透:从零到一的完整指南

使用 frp 实现内网穿透:从零到一的完整指南

🎁 DeepSeek满血版免费领啦!字节跳动火山引擎官方,免费抵扣3625万tokens,畅享R1与V3模型!参与入口:点击进入

为什么需要内网穿透?

在日常开发或家庭网络中,我们常常需要访问位于内网(如公司、家庭局域网)的设备或服务(如远程桌面、NAS、Web服务器)。然而,由于缺乏公网IP或防火墙限制,这些服务无法直接从外网访问。

内网穿透(NAT穿透) 技术应运而生,它能将内网服务暴露到公网。而 frp (Fast Reverse Proxy) 是一款开源、高效的内网穿透工具,支持 TCP/UDP/HTTP/HTTPS 等多种协议,配置简单且社区活跃。

本文将从原理到实践,手把手教你如何使用 frp 实现内网穿透。

一、frp 的核心概念

1.1 工作原理

frp 分为两个角色:

  • 服务端(frps):部署在具有公网 IP 的服务器(如云服务器),负责接收外部请求并转发到内网。

  • 客户端(frpc):运行在内网设备上,注册到服务端并建立隧道,将本地服务暴露出去。

    [内网服务器] <-> [FRP客户端(frpc)] <-> [FRP服务端(frps)] <-> [公网用户]
    

1.2 适用场景

  • 远程访问内网 SSH/RDP 服务
  • 对外发布内网 Web 应用(如个人博客、测试环境)
  • 穿透 NAT 访问 IoT 设备(如树莓派、摄像头)

1.3 主要特性

  • 多协议支持:TCP、UDP、HTTP、HTTPS等
  • 安全性:支持TLS加密传输
  • 高性能:TCP连接复用
  • 负载均衡:支持多个代理的负载均衡
  • 端口复用:多个服务可以复用同一个端口
  • P2P通信:支持点对点直接通信
  • 插件系统:提供丰富的插件扩展功能

二、准备工作

  • 公网服务器:如阿里云、腾讯云(需开放相关端口)。
  • 内网设备:目标服务所在设备(如本地电脑、NAS)。
  • 下载 frp:从 GitHub Release 下载对应系统的版本(服务端与客户端版本需一致)。

三、服务端(frps)配置

基础配置

  1. 解压并编辑配置文件:

    tar -zxvf frp_*.tar.gz
    cd frp_*
    vi frps.ini
    
  2. 配置示例(frps.ini):

    [common]
    bind_port = 7000             # 客户端连接的端口
    token = your_secure_token    # 认证令牌(客户端需一致)
    dashboard_port = 7500        # 服务端仪表盘的端口, 可以用浏览器访问查看
    dashboard_user = admin       # 服务端仪表盘的用户密码
    dashboard_pwd = your_password# 日志保存设定, 保存位置、保存时长
    log_file = ./frps.log
    log_level = info
    log_max_days = 7
    
  3. 启动服务端

    ./frps -c frps.ini
    

进阶配置

  • 限制可代理的端口范围(增强安全性):

    allow_ports = 6000-7000,8000,9000-9100
    
  • 域名访问支持:

    vhost_http_port = 80    # HTTP 服务端口
    vhost_https_port = 443  # HTTPS 服务端口
    

设置开机自启(Linux)

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

    [Unit]
    # 服务名称,可自定义
    Description = frp server
    After = network.target syslog.target
    Wants = network.target[Service]
    Type = simple
    # 启动frps的命令,需修改为您的frps的安装路径
    ExecStart = /path/to/frps -c /path/to/frps.toml[Install]
    WantedBy = multi-user.target
    
  2. 使用 systemd 命令管理 frps 服务

    # 启动frp
    sudo systemctl start frps
    # 停止frp
    sudo systemctl stop frps
    # 重启frp
    sudo systemctl restart frps
    # 查看frp状态
    sudo systemctl status frps
  3. 启动并启用服务:

    systemctl start frps
    systemctl enable frps
    

四、客户端(frpc)配置

基础配置

  1. 解压并编辑配置文件:

    tar -zxvf frp_*.tar.gz
    cd frp_*
    vi frpc.ini
    
  2. 配置(frpc.ini)

    [common]
    # 服务端公网IP
    server_addr = [服务端公网IP]
    # 客户端访问服务端的密码
    token = abcdefg
    # 客户端与服务端通信端口
    server_port = 7000[range:ssh]
    # 指定TCP连接类型
    type = tcp
    # 客户端IP, 这里填本地IP就可以
    local_ip = 127.0.0.1
    # 当前设备开放的远程连接端口, 默认为22
    local_port = 22
    # 表示服务端的代理端口号
    remote_port = 33022
    # 是否加密
    use_encryption = true
    # 是否压缩
    use_compression = false# 示例1:暴露 SSH 服务(通过公网IP:6000访问内网22端口)
    [ssh]
    type = tcp
    local_ip = 127.0.0.1
    local_port = 22
    remote_port = 6000# 示例2:通过域名访问内网 Web 服务
    [web]
    type = http
    local_port = 8080
    custom_domains = www.yourdomain.com# 数据库访问
    [mysql]
    type = tcp
    local_ip = 127.0.0.1
    local_port = 3306
    remote_port = 3306
    
  3. 启动客户端

    ./frpc -c frpc.ini
    

多服务配置

# 远程桌面(RDP)
[rdp]
type = tcp
local_port = 3389
remote_port = 7001# 内网 NAS 的 HTTP 服务
[nas]
type = http
local_port = 5000
subdomain = nas  # 需服务端配置 subdomain_host

五、测试与验证

访问穿透的服务

  • SSH 连接:

    ssh -p 6000 user@your_server_ip
    
  • Web 服务:

    浏览器访问 http://www.yourdomain.com(需域名解析到服务端IP)。
    

监控 frp 状态

访问 http://your_server_ip:7500,输入仪表盘账号密码,查看流量统计和连接状态。

六、安全加固与优化

安全建议

  • 使用强 Token:避免使用默认或简单 token。

  • 限制端口范围:通过 allow_ports 减少攻击面。

  • 启用 TLS 加密(客户端配置):

    [common]
    tls_enable = true
    

性能优化

  • 启用压缩(减少带宽占用):

    use_compression = true
    

七、常见问题解决

  1. 无法连接服务端
    • 检查服务端防火墙是否放行 bind_port(如7000)。
    • 确认客户端配置的 server_addr 和 token 正确。
  2. 域名访问提示 404
    • 确保域名已解析到服务端 IP。
    • 检查客户端配置的 custom_domains 或 subdomain。
  3. 仪表盘无法访问
    • 检查 dashboard_port 是否开放,或尝试关闭服务端防火墙测试。

声明:本文为技术分享,请确保在使用内网穿透时遵守当地法律法规,勿用于非法用途。
frp官网传送门 点击地址 FRP

🎁 DeepSeek满血版免费领啦!字节跳动火山引擎官方,免费抵扣3625万tokens,畅享R1与V3模型!参与入口:点击进入

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/24665.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Akashic Records】《命若琴弦》

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: Akashic Records 文章目录 &#x1f4af;观后感命运的无情与生命的坚持希望的火种与人生的意义虚无与活在当下生死的辩证与享受当下结语 &#x1f4af;观后感 命若琴弦 生命的意义本不在向外的寻取&#xff0c;而在…

C#调用CANoeCLRAdapter.dll文章(一)

一、引言 CANoe 是 Vector 公司开发的一款广泛应用于汽车电子开发、测试和分析的工具。CANoe CLR Adapter 允许开发者使用 C# 等.NET 语言来扩展 CANoe 的功能&#xff0c;实现更灵活、强大的自动化测试和数据处理。本指南将详细介绍如何基于 C# 进行 CANoe CLR Adapter 的开发…

运维和AI的邂逅: 让你的 ssh/terminal 智能化

运维同学很多工作其实就是在命令行里操作服务器&#xff0c;尽管目前有很多可视化的工具&#xff0c;但是命令行(ssh 登录)依然不可或缺&#xff0c;甚至依然还占据着主要工作。这意味着运维同学需要掌握大量和服务器操作系统以及shell相关的知识&#xff0c;记住大量的命令。 …

CMake小结2(PICO为例)

1 前言 之前写过一篇cmake&#xff0c;不过很简单&#xff1a;CMake小结_cmake ${sources}-CSDN博客 构建系统现在真的太多了&#xff0c;完全学不过来的感觉&#xff0c;meson&#xff0c;gardle&#xff0c;buildroot&#xff0c; Maven。。。我是真的有点放弃治疗了。之前…

使用OpenCV实现帧间变化检测:基于轮廓的动态区域标注

在计算机视觉中&#xff0c;帧间差异检测&#xff08;frame differencing&#xff09;是一种常用的技术&#xff0c;用于检测视频流中的动态变化区域。这种方法尤其适用于监控、运动分析、目标追踪等场景。在这篇博客中&#xff0c;我们将通过分析一个基于OpenCV的简单帧间差异…

机器学习01

机器学习的基本过程如下&#xff1a; 1.数据获取 2.数据划分 3.特征提取 4.模型选择与训练 5.模型评估 6.模型调优 一、特征工程&#xff08;重点&#xff09; 0. 特征工程步骤为&#xff1a; 特征提取(如果不是像dataframe那样的数据&#xff0c;要进行特征提取&#…

每日Attention学习24——Strip Convolution Block

模块出处 [TIP 21] [link] CoANet: Connectivity Attention Network for Road Extraction From Satellite Imagery 模块名称 Strip Convolution Block (SCB) 模块作用 多方向条形特征提取 模块结构 模块特点 类PSP设计&#xff0c;采用四个并行分支提取不同维度的信息相比于…

用FileZilla Server 1.9.4给Windows Server 2025搭建FTP服务端

FileZilla Server 是一款免费的开源 FTP 和 FTPS 服务器软件&#xff0c;分为服务器版和客户端版。服务器版原本只支持Windows操作系统&#xff0c;比如笔者曾长期使用过0.9.60版&#xff0c;那时候就只支持Windows操作系统。当时我们生产环境对FTP稳定性要求较高&#xff0c;比…

es-head(es库-谷歌浏览器插件)

1.下载es-head插件压缩包&#xff0c;并解压缩 2.谷歌浏览器添加插件 3.使用

健康检查、k8s探针、Grails+Liquibase框架/health 404 Not Found排查及解决

概述 健康检查对于一个pod而言&#xff0c;其重要性不言而喻。 k8s通过探针来实现健康检查。 探针 k8s提供三种探针&#xff1a; 存活探针&#xff1a;livenessProbe就绪探针&#xff1a;readinessProbe启动探针&#xff1a;startupProbe 存活探针 存活探针决定何时重启…

5个GitHub热点开源项目!!

1.自托管 Moonlight 游戏串流服务&#xff1a;Sunshine 主语言&#xff1a;C&#xff0c;Star&#xff1a;14.4k&#xff0c;周增长&#xff1a;500 这是一个自托管的 Moonlight 游戏串流服务器端项目&#xff0c;支持所有 Moonlight 客户端。用户可以在自己电脑上搭建一个游戏…

【Linux C | 时间】localtime 的介绍、死机、死锁问题以及 localtime_r 函数的时区问题

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

122. 买卖股票的最佳时机 II 反向递推的方法

下面是将你提供的代码整理成一篇Markdown格式的博客内容&#xff1a; 股票买卖的最大利润 问题描述 给定一个整数数组 prices&#xff0c;其中 prices[i] 是股票在第 i 天的价格。你可以选择在某一天买入股票&#xff0c;并在之后的某一天卖出股票。要求计算出你能够获得的最…

详解Tomcat下载安装以及IDEA配置Tomcat(2023最新)

目录 步骤一&#xff1a;首先确认自己是否已经安装JDK步骤二&#xff1a;下载安装Tomcat步骤三&#xff1a;Tomcat配置环境变量步骤四&#xff1a;验证Tomcat配置是否成功步骤五&#xff1a;为IDEA配置Tomcat 步骤一&#xff1a;首先确认自己是否已经安装JDK jdk各版本通用安…

html中的css

css &#xff08;cascading style sheets&#xff0c;串联样式表&#xff0c;也叫层叠样式表&#xff09; css规范一般约定&#xff1a; 1.存放CSS样式文件的目录一般命名为style或css。 2.在项目初期&#xff0c;会把不同类别的样式放于不同的CSS文件&#xff0c;是为了CSS编…

前端项目配置初始化

creat-vue 安装 https://cn.vuejs.org/guide/quick-start.html 官网复制npm安装语句 cmd窗口创建文件夹 npm create vue3.12.2安装webstorm启动vue项目 https://www.jetbrains.com/webstorm/download/other.html 2024.3.2.1 安装依赖 下载包node_modules package 运行服…

Java注解的原理

目录 问题: 作用&#xff1a; 原理&#xff1a; 注解的限制 拓展&#xff1a; 问题: 今天刷面经&#xff0c;发现自己不懂注解的原理&#xff0c;特此记录。 作用&#xff1a; 注解的作用主要是给编译器看的&#xff0c;让它帮忙生成一些代码&#xff0c;或者是帮忙检查…

seacmsv9注入管理员账号密码+orderby+limit

seacmsv9注入管理员账号密码 安装海洋CMS&#xff08;seacms&#xff09; 将upload文件夹里的文件全部上传至网页服务器后&#xff0c;执行以下操作: 请运行http://域名/install/index.php进行程序安装 SQL语句尝试注入 http://127.0.0.1/upload/comment/api/index.php?g…

【构建工具】Gradle Kotlin DSL中的大小写陷阱:BuildConfigField

在Android开发当中&#xff0c;BuildConfig是一个非常有用的功能&#xff0c;它允许我们在构建过程中定义常量&#xff0c;并在运行时使用它们。But&#xff01;&#xff01;当我们从传统的Groovy DSL迁移到Kotlin DSL时或者被Android Studio坑的时候&#xff0c;有一些细微的差…

AI如何改变传统工厂的生产模式?

随着第四次工业革命的浪潮席卷全球&#xff0c;制造业的数字化转型成为企业在竞争中脱颖而出的关键。过去&#xff0c;传统制造业往往依赖于大量的人工操作和低效率的管理流程&#xff0c;而如今&#xff0c;智能化、自动化、数据化已经成为未来制造业的必由之路。从车间到云端…