內網穿透 FRP 配置指南

關鍵詞:內網穿透、FRP配置、frps、frpc、遠程訪問、自建服務器、反向代理、TCP轉發、HTTP轉發

在開發或部署項目時,我們經常遇到內網設備無法被公網訪問的問題,例如你想從外網訪問你家里的 NAS、遠程調試開發板,或是訪問本地測試環境。這時候,一個輕量、易用、高效的開源工具 —— FRP (Fast Reverse Proxy) 就派上用場了。

本文將手把手教你如何使用 FRP 實現內網穿透,支持 **TCP / HTTP ** 協議的穿透。


一、FRP 是什么?

FRP(Fast Reverse Proxy) 是一個高性能的反向代理應用,專為內網穿透而設計。你可以通過它將內網服務映射到公網服務器,實現從外網訪問內網服務的需求。

FRP 包含兩個核心組件:

  • frps:部署在公網服務器上,作為服務端。
  • frpc:部署在內網主機上,作為客戶端。

在這里插入圖片描述

二、FRP 應用場景

  • 從公網訪問位于 NAT/防火墻后的內網服務
  • 家庭網絡中遠程訪問內網電腦或 NAS
  • IoT 設備遠程調試
  • 本地開發環境暴露給互聯網使用
  • 內網網站、API接口暴露給第三方服務

三、準備工作

1. 準備一臺 公網服務器

  • 操作系統:Linux(例如 Ubuntu 20.04)
  • 能開放指定端口(例如 7000、80、443)
  • 安裝 SSH,方便遠程管理

2. 一臺內網主機

  • 比如你家里的電腦、樹莓派、或公司內網中的服務器

3. 下載 FRP 工具

訪問:https://github.com/fatedier/frp/releases

選擇對應系統版本進行下載,例如:

# 以 Linux 64 位為例
wget https://github.com/fatedier/frp/releases/download/v0.63.0/frp_0.63.0_linux_amd64.tar.gz
tar -zxvf frp_0.63.0_linux_amd64.tar.gz

四、服務端配置(公網服務器)

進入 frp_0.63.0_linux_amd64 目錄:

編輯 frps.toml

bindPort = 15700
vhostHTTPPort = 14144

啟動 frps:

# 后臺啟動frp服務端應用
nohpu ./frps -c frps.toml &#利用tail 命令查看啟動日志
tail -f nohup.out

出現如下內容則表示啟動成功:

[1;34m2025-07-23 18:50:38.146 [I] [frps/root.go:105] frps uses config file: frps.toml
[0m[1;34m2025-07-23 18:50:38.307 [I] [server/service.go:237] frps tcp listen on 0.0.0.0:15701
[0m[1;34m2025-07-23 18:50:38.308 [I] [server/service.go:305] http service listen on 0.0.0.0:14144
[0m[1;34m2025-07-23 18:50:38.308 [I] [frps/root.go:114] frps started successfully

? 建議將其配置為 Systemd 服務,實現開機自啟。


五、客戶端配置(內網主機)

在內網主機中進入對應解壓后的 frp 目錄。

編輯 `frpc.toml:

1. 穿透 HTTP 服務(比如本地 8080)
serverAddr = "公網IP"
serverPort = 15700[[proxies]]
name = "web01"
type = "http"
localIP = "127.0.0.1"
localPort = 8080
customDomains = ["指定到公網的域名"]

啟動成功后,可以通過 http://公網IP:14144 內網http服務!

2. 穿透 SSH 服務(遠程 SSH 到內網設備)
serverAddr = "公網地址"
serverPort = 15700[[proxies]]
name = "ssh"
type = "tcp"
localIP = "127.0.0.1"
localPort = 22
remotePort =16000

啟動 frpc:

./frpc -c frpc.toml

啟動成功后,ssh 公網IP -p 16000 來訪問內網ssh服務!


六、設置自啟動(Systemd 配置)

1. 服務器

創建 /etc/systemd/system/frps.service

[Unit]
Description=FRP Server
After=network.target[Service]
ExecStart=/opt/frp/frps -c /opt/frp/frps.toml
Restart=on-failure[Install]
WantedBy=multi-user.target

2.客戶端

創建 /etc/systemd/system/frpc.service

[Unit]
Description=FRP Client
After=network.target[Service]
ExecStart=/opt/frp/frpc -c /opt/frp/frpc.toml
Restart=on-failure[Install]
WantedBy=multi-user.target

執行:

sudo systemctl daemon-reexec
sudo systemctl enable frps
sudo systemctl start frps

客戶端同理。


七、常見問題排查

問題可能原因解決辦法
frpc 連接不上 frps防火墻或端口未開放檢查安全組、防火墻設置
HTTP 映射失敗域名未解析或未配置 vhost_http_port檢查 DNS 和配置
SSH 登錄失敗remote_port 已被占用修改 remote_port
frps/frpc 啟動失敗配置文件格式錯誤仔細檢查 toml 文件格式

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/91913.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/91913.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/91913.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SpringBoot 信用卡檢測、OpenAI gym、OCR結合、DICOM圖形處理、知識圖譜、農業害蟲識別實戰

信用卡欺詐檢測通常使用公開數據集 數據準備與預處理 信用卡欺詐檢測通常使用公開數據集如Kaggle的信用卡交易數據集。數據預處理包括處理缺失值、標準化數值特征、處理類別特征。在Spring Boot中,可以使用pandas或sklearn進行數據預處理。 // 示例:使用Spring Boot讀取CS…

使用 Docker 部署 Golang 程序

Docker 是部署 Golang 應用程序的絕佳方式,它可以確保環境一致性并簡化部署流程。以下是完整的指南: 1. 準備 Golang 應用程序 首先確保你的 Go 應用程序可以正常構建和運行。一個簡單的示例 main.go: package mainimport ("fmt""net/http" )func ha…

從零開始的CAD|CAE開發: LBM源碼實現分享

起因:上期我們寫了流體仿真的經典案例: 通過LBM,模擬計算渦流的形成,當時承諾: 只要驗證通過,就把代碼開源出來;ok.驗證通過了,那么我也就將代碼全都貼出來代碼開源并貼出:public class LidDrivenCavityFlow : IDisposable{public LidDrivenCavityFlow(int width 200, int hei…

倉庫管理系統-17-前端之物品類型管理

文章目錄 1 表設計(goodstype) 2 后端代碼 2.1 Goodstype.java 2.2 GoodstypeMapper.java 2.3 GoodstypeService.java 2.4 GoodstypeServiceImpl.java 2.5 GoodstypeController.java 3 前端代碼 3.1 goodstype/GoodstypeManage.vue 3.2 添加菜單 3.3 頁面顯示 1、goodstype表設…

共識算法深度解析:PoS/DPoS/PBFT對比與Python實現

目錄 共識算法深度解析:PoS/DPoS/PBFT對比與Python實現 1. 引言:區塊鏈共識的核心挑戰 2. 共識算法基礎 2.1 核心設計維度 2.2 關鍵評估指標 3. PoS(權益證明)原理與實現 3.1 核心機制 3.2 Python實現 4. DPoS(委托權益證明)原理與實現 4.1 核心機制 4.2 Python實現 5. P…

3.JVM,JRE和JDK的關系是什么

3.JVM,JRE和JDK的關系是什么 1.JDK(Java Development Kit),是功能齊全的Java SDK,包含JRE和一些開發工具(比如java.exe,運行工具javac.exe編譯工具,生成.class文件,javaw.exe,大多用…

深度學習技術發展思考筆記 || 一項新技術的出現,往往是為了解決先前范式中所暴露出的特定局限

深度學習領域的技術演進,遵循著一個以問題為導向的迭代規律。一項新技術的出現,往往是為了解決先前范式中所暴露出的特定局限。若將這些新技術看作是針對某個問題的“解決方案”,便能勾勒出一條清晰的技術發展脈絡。 例如,傳統的前…

Promise的reject處理: then的第二個回調 與 catch回調 筆記250804

Promise的reject處理: then的第二個回調 與 catch回調 筆記250804 Promise 錯誤處理深度解析:then 的第二個回調 vs catch 在 JavaScript 的 Promise 鏈式調用中,錯誤處理有兩種主要方式:.then() 的第二個回調函數和 .catch() 方法。這兩種方…

Maven模塊化開發與設計筆記

1. 模塊化開發模塊化開發是將大型應用程序拆分成多個小模塊的過程,每個模塊負責不同的功能。這有助于降低系統復雜性,提高代碼的可維護性和可擴展性。2. 聚合模塊聚合模塊(父模塊)用于組織和管理多個子模塊。它定義了項目的全局配…

sqli-labs:Less-21關卡詳細解析

1. 思路🚀 本關的SQL語句為: $sql"SELECT * FROM users WHERE username($cookee) LIMIT 0,1";注入類型:字符串型(單引號、括號包裹)、GET操作提示:參數需以)閉合關鍵參數:cookee p…

大模型+垂直場景:技術縱深、場景適配與合規治理全景圖

大模型垂直場景:技術縱深、場景適配與合規治理全景圖??核心結論?:2025年大模型落地已進入“深水區”,技術價值需通過 ?領域縱深(Domain-Deep)?、數據閉環(Data-Driven)?、部署友好&#x…

Kotlin Daemon 簡介

Kotlin Daemon 是 Kotlin 編譯器的一個后臺進程,旨在提高編譯性能。它通過保持編譯環境的狀態來減少每次編譯所需的啟動時間,從而加快增量編譯的速度。 Kotlin Daemon 的主要功能增量編譯: 只編譯自上次編譯以來發生更改的文件,節…

鴻蒙南向開發 編寫一個簡單子系統

文章目錄 前言給設備,編寫一個簡單子系統總結 一、前言 對于應用層的開發,搞了十幾年,其實已經有點開發膩的感覺了,翻來覆去,就是調用api,頁面實現,最多就再加個性能優化,但對底層…

超詳細:2026年博士申請時間線

博士申請是一場持久戰,需要提前規劃。那么,如何科學安排2026年博士申請時間線?SCI論文發表的最佳時間節點是什么?今天給所有打算申博的同學們,詳細解析下,每個時間節點的重點內容。2025年4月:是…

Python爬蟲實戰:研究tproxy代理工具,構建電商數據采集系統

1. 引言 1.1 研究背景 在大數據與人工智能技術快速發展的背景下,網絡數據已成為企業決策、學術研究、輿情監控的核心資源。據 Statista 統計,2024 年全球互聯網數據總量突破 180ZB,其中 80% 為非結構化數據,需通過爬蟲技術提取與轉化。Python 憑借其簡潔語法與豐富的爬蟲…

HighgoDB查詢慢SQL和阻塞SQL

文章目錄環境文檔用途詳細信息環境 系統平臺:N/A 版本:6.0,5.6.5,5.6.4,5.6.3,5.6.1,4.5.2,4.5,4.3.4.9,4.3.4.8,4.3.4.7,4.3.4.6,4.3.4.5,4.3.4.4,4.3.4.3,4.3.4.2,4.3.4,4.7.8,4.7.7,4.7.6,4.7.5,4.3.2 文檔用途 本文介紹了如何對數據庫日志進行分析…

day15 SPI

1串行外設接口概述1.1基本概念SPI(串行外設接口)是一種高速、全雙工、同步的串行通信協議。串行外設接口一般是需要4根線來進行通信(NSS、MISO、MOSI、SCK),但是如果打算實現單向通信(最少3根線&#xff09…

阿里云微服務引擎 MSE 及 API 網關 2025 年 7 月產品動態

點擊此處,了解微服務引擎 MSE 產品詳情。

RFID技術在汽車倍速鏈中的應用:驅動智能制造的隱形引擎

RFID技術在汽車倍速鏈中的應用:驅動智能制造的隱形引擎某汽車汽車倍速鏈現場存在問題:(1)條形碼需人工掃描,數據采集延遲率高達15%,導致生產調度與實際工況脫節;(2)涂裝車…

ES集群調優策略

Index(寫)調優 副本數置0 如果是集群首次灌入數據,可以將副本數設置為0,寫入完畢再調整回去,這樣副本分片只需要拷貝,節省了索引過 程。 PUT /my_temp_index/_settings { "number_of_replicas": 0 } 自動生成doc ID? 通過Elast…