內網服務器無法通過公網地址訪問映射到公網的內網服務

內網服務器無法通過公網地址訪問映射到公網的內網服務

    • 問題現象
    • 問題原因
    • 解決方法
    • 總結

前幾天遇到一個網絡問題,在這里做下記錄,希望能幫助到有相同問題的朋友。

問題現象

網絡拓撲示意
網絡拓撲如上所示,服務器1和服務器2在同一內網,網段均為192.168.101.0/24,出口防火墻上有一個固定公網ip,地址是124.5.5.5。
服務器1上運行了一個業務系統,地址是192.168.101.111:80,然后在出口防火墻上做了映射,將其映射到了124.5.5.5:10080,此時,外部網絡環境中可以正常訪問124.5.5.5:10080,但是在內網環境中,如服務器2上,無法訪問124.5.5.5:10080。也就是說內網服務器上無法通過映射后的公網地址訪問內網服務。

問題原因

分析一下ip報文流轉過程中的源目地址變化,就可以發現問題所在。
源目地址變化
服務器2訪問124.5.5.5:10080時,源地址192.168.101.222目的地址124.5.5.5;
報文到達出口防火墻后,會做一次地址轉換,將目的地址轉換為內網地址192.168.101.111,此時源地址192.168.101.222目的地址192.168.101.111;
報文一步步到達服務器1后,服務器1做出響應,源目地址轉換,此時源地址192.168.101.111目的地址192.168.101.222;
這時候,服務器1發現目的地址為同網段,報文會由服務器1通過接入交換機直接發送給服務器2;
服務器2檢查報文,發現源地址是192.168.101.111,并沒有與之匹配的會話(服務器2發送出去的報文目的地址是124.5.5.5),此時服務器2會丟棄這個報文,這就導致了訪問不通。

解決方法

要解決這個問題,只需要使得服務器1收到的ip報文中,源地址為公網地址124.5.5.5即可,這樣的話,服務器1回復的報文就變為源地址192.168.101.111目的地址124.5.5.5,報文會經過防火墻后再回到服務器2,完成整個通信過程。
要實現以上操作,只需要在防火墻上配置一條源NAT,將源目網段192.168.101.0/24的報文,源地址轉換為124.5.5.5,并將該條SNAT應用到防火墻與核心交換機相連的那個接口上。

總結

做完以上配置后,服務器2(192.168.101.222)通過124.5.5.5:10800訪問服務器1(192.168.101.111:80)時,網絡流量的流轉及地址變化如下:

1.數據包從S2發出
源地址:192.168.101.222:隨機端口(假設為54321)
目的地址:124.5.5.5:10800
路徑:S2 → 接入交換機 → 匯聚交換機→ 核心交換機 → 防火墻(內網接口)

2.防火墻處理(入口方向)
a.目的NAT(DNAT)
規則:將 124.5.5.5:10800映射到192.168.101.111:80
轉換后數據包:
源地址:192.168.101.222:54321
目的地址:192.168.101.111:80
b. 源NAT(SNAT)
規則:源目均為192.168.101.0/24的流量,源地址轉換為124.5.5.5
轉換后數據包:
源地址:124.5.5.5:54321(端口可能保持不變或變化)
目的地址:192.168.101.111:80
路徑:防火墻 → 核心交換機→ 匯聚交換機 → 接入交換機 → S1

3.S1 處理請求并響應
接收的數據包:
源地址:124.5.5.5:54321
目的地址:192.168.101.111:80
響應數據包:
源地址:192.168.101.111:80
目的地址:124.5.5.5:54321
路徑:S1 → 接入交換機 → 匯聚交換機→ 核心交換機 → 防火墻(內網接口)

4.防火墻處理(出口方向)
反向NAT(基于連接跟蹤):
反向DNAT:將目的地址124.5.5.5:54321還原為192.168.101.222:54321
反向SNAT:將源地址192.168.101.111:80還原為124.5.5.5:10800
轉換后響應包:
源地址:124.5.5.5:10800
目的地址:192.168.101.222:54321
路徑:防火墻 → 核心交換機 → 匯聚交換機 → 接入交換機 → S2

5.S2 接收響應
最終數據包:
源地址:124.5.5.5:10800
目的地址:192.168.101.222:54321
S2 視角:認為與124.5.5.5:10800通信成功,整個過程透明

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

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

相關文章

python每日十題(13)

一般把計算機完成一條指令所花費的時間稱為一個指令周期。指令周期越短,指令執行就越快。本題答案為D選項。 順序程序具有順序性、封閉性和可再現性的特點,使得程序設計者能夠控制程序執行的過程(包括執行順序、執行時間),對程序執…

Python 裝飾器(Decorators)

什么是裝飾器? 裝飾器(Decorator)本質上是一個 修改其他函數功能的函數。它的核心思想是:不修改原函數代碼,動態添加新功能。比如: 記錄函數執行時間 檢查用戶權限 緩存計算結果 自動重試失敗操作 理解…

uWebSockets開發入門

一、常用C++ WebSocket開源庫 一些常用的 C++ WebSocket 開源庫,它們支持 WebSocket 協議的實現,適用于客戶端或服務器端開發。 1. Boost.Beast (推薦) 特點:基于 Boost.Asio 的高性能庫,支持 HTTP/WebSocket,屬于 Boost 官方庫的一部分,穩定且跨平臺。 適用場景:需要高…

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺 在于通過分工協作提升整體效率、靈活性和魯棒性。 1. 提升效率與專業性 原理:單一智能體無需處理全流程,通過專業化分工減少冗余計算和決策延遲。 示例: 自動駕駛系統: 感知智能體:專門處理攝像頭、激光雷達等傳…

項目復盤:websocket不受跨域限制的原理

主要還是因為: 1、WebSocket 是獨立于 HTTP 的應用層協議,通過 HTTP 建立連接后,完全脫離 HTTP 語義約束。這意味著 不受 HTTP 同源策略限制 不需要預檢請求 不依賴 CORS 頭機制 2、建立連接時的握手請求仍使用 HTTP 格式,但…

COMPASS:通過殘差強化學習和技能合成實現跨具身移動策略

25年2月來自 Nvidia、UC Berkeley 和 UT Austin 的論文“COMPASS: Cross-embOdiment Mobility Policy via ResiduAl RL and Skill Synthesis”。 隨著機器人越來越多地部署在不同的應用領域,可泛化的跨具身移動策略變得越來越重要。雖然經典的移動棧已被證明在特定…

無人機,雷達定點飛行時,位置發散,位置很飄,原因分析

參考: 無人車傳感器 IMU與GPS數據融合進行定位機制_gps imu 組合定位原始數-CSDN博客 我的無人機使用雷達定位,位置模式很飄 雷達的更新頻率也是10HZ, 而px飛控的頻率是100HZ,沒有對兩者之間的頻率差異做出處理 所以才導致無人…

學習threejs,使用Sprite精靈、SpriteMaterial精靈材質

👨??? 主頁: gis分享者 👨??? 感謝各位大佬 點贊👍 收藏? 留言📝 加關注?! 👨??? 收錄于專欄:threejs gis工程師 文章目錄 一、🍀前言1.1 ??THREE.Sprite1.1.1 ??代碼…

外星人入侵(python設計小游戲)

這個游戲簡而言之就是操作一個飛機對前方的飛船進行射擊,和一款很久之前的游戲很像,這里是超級低配版那個游戲,先來看看效果圖: 由于設計的是全屏的,所以電腦不能截圖。。。。 下面的就是你操控的飛船,上面…

什么是CMS?常用CMS有哪些?

一、內容管理系統(Content Management System)? ?什么是CMS?:位于 Web 前端(服務器)和后端辦公系統之間的軟件系統,用于內容創建、編輯、審批和發布。支持文本、圖片、視頻、數據庫等各類數字內容的管理…

Go 語言規范學習(3)

文章目錄 Properties of types and valuesRepresentation of valuesUnderlying types【底層類型】Core types【核心類型】Type identityAssignabilityRepresentabilityMethod sets BlocksDeclarations and scopeLabel scopesBlank identifierPredeclared identifiersExported i…

在 Ubuntu 上安裝 Docker 的完整指南

1. 卸載舊版本(如有) 在安裝新版本前,建議先卸載舊版本: sudo apt remove docker docker-engine docker.io containerd runc 2. 安裝依賴包 更新軟件包索引并安裝必要的依賴: sudo apt update sudo apt install -y ca-certificates curl gnupg lsb-release 3. 添加 Do…

turtle的九個使用

一 import turtle as t color [red,green,blue,orange,pink] for i in range(len(color)):t.penup()t.goto(-20070*i,0)t.pendown()t.pencolor(color[i])t.circle(50, steps 5) t.done()二 #在____________上補充代碼 #不要修改其他代碼import random as r import turtle a…

23種設計模式-備忘錄(Memento)設計模式

備忘錄設計模式 🚩什么是備忘錄設計模式?🚩備忘錄設計模式的特點🚩備忘錄設計模式的結構🚩備忘錄設計模式的優缺點🚩備忘錄設計模式的Java實現🚩代碼總結🚩總結 🚩什么是…

利用虛擬化技術實現高級Hook

虛擬化技術為系統監控和Hook提供了更強大、更隱蔽的實現方式。以下是幾種基于虛擬化的Hook技術實現方法: 1. 基于VT-x/AMD-V的硬件虛擬化Hook 基本原理 利用CPU的硬件虛擬化擴展(Intel VT-x/AMD-V)在Ring -1層級監控系統行為,實現無法被常規方法檢測的…

某魚、某寶 sign 簽名算法分析記錄

【作者主頁】:小魚神1024 【知識星球】:小魚神的逆向編程圈 【擅長領域】:JS逆向、小程序逆向、AST還原、驗證碼突防、Python開發、瀏覽器插件開發、React前端開發、NestJS后端開發等等 本文章中所有內容僅供學習交流使用,不用于其…

Compose筆記(十三)--事件總線

這一節了解一下Compose中的事件總線,在Jetpack Compose里,官方沒有直接提供事件總線,但可以借助第三方庫或者自定義實現來達成事件總線的功能,進而在不同的 Compose 控件間同步數據。 自定義事件總線 import androidx.compose.r…

Python的inspect模塊

在Python編程中,**inspect**模塊是一個強大的工具包,它提供了一系列函數來獲取對象的信息,主要用于獲取對象的源代碼、參數信息、類繼承關系、方法屬性等。這對于調試、自動化文檔生成、代碼分析等場景都非常有用。本文將詳細介紹inspect模塊…

2025跳槽學習計劃

(1)編程基礎: 目錄學習資料Chttps://www.bilibili.com/video/BV1z64y1U7hs?spm_id_from333.1387.favlist.content.clickLinuxPytorchhttps://www.bilibili.com/video/BV1if4y147hS?spm_id_from333.1387.favlist.content.clickopencv數據結…

WebRTC簡介及應用

WebRTC(Web Real-Time Communication)是一種支持瀏覽器和移動設備進行實時音視頻通信的技術,無需安裝插件或額外的軟件。它是一個開放標準,最初由Google推動,并被W3C(萬維網聯盟)和IETF&#xf…