iptables防火墻,多IP環境下, 指定某個目的IP地址通過某個本地IP訪問,策略路由!

需求

在CentOS 7.9中,若需從特定源IP(10.0.0.3)訪問目標網段 1.1.1.0/24

方法一:策略路由(支持網段)

1. 創建自定義路由表

# 添加名為custom_table的路由表(ID=200)
echo "200 custom_table" >> /etc/iproute2/rt_tables

?2. 向路由表添加默認路由

# 替換10.0.0.254為實際網關(通過ip route show default查看)
ip route add default via 10.0.0.254 dev eth0 table custom_table

3. ?設置策略路由規則

# 匹配目標網段1.1.1.0/24,強制使用custom_table路由表
ip rule add to 1.1.1.0/24 lookup custom_table

4. ?綁定源IP到路由表

# 指定從該路由表發出的流量源IP為10.0.0.3
ip route add default via 10.0.0.254 dev eth0 src 10.0.0.3 table custom_table

5. ?持久化配置

# 創建規則文件(目標網段+路由表)
echo "to 1.1.1.0/24 lookup custom_table" > /etc/sysconfig/network-scripts/rule-eth0# 創建路由表文件(包含源IP配置)
echo "default via 10.0.0.254 dev eth0 src 10.0.0.3" > /etc/sysconfig/network-scripts/route-custom_table

方法二:iptables SNAT(支持網段)

1. 添加SNAT規則

# 匹配目標網段1.1.1.0/24,修改源IP為10.0.0.3
iptables -t nat -A OUTPUT -d 1.1.1.0/24 -j SNAT --to-source 10.0.0.3

2. 保存規則

# 保存規則并重啟服務(需安裝iptables-services)
iptables-save > /etc/sysconfig/iptables
systemctl restart iptables

方法三

1. 使用1.1.1.1的網關:

ip route add 移動IP段1 via 移動網關 src 移動IP
ip route add 移動IP段2 via 移動網關 src 移動IP
ip route add 移動IP段3 via 移動網關 src 移動IP

驗證配置

方法一驗證

# 查看策略規則
ip rule show | grep "1.1.1.0/24"
# 應輸出:32765:	from all to 1.1.1.0/24 lookup custom_table# 測試流量源IP(使用tcpdump抓包)
tcpdump -i eth0 src 10.0.0.3 and dst 1.1.1.0/24

方法二驗證

# 查看NAT規則
iptables -t nat -L -n -v
# 應包含:SNAT       all  --  *      *       0.0.0.0/0            1.1.1.0/24          to:10.0.0.3# 測試連通性
curl --connect-timeout 5 http://1.1.1.1

注意事項

1. ?網關一致性
確保所有命令中的網關(10.0.0.254)與實際網絡一致,可通過以下命令查詢:

ip route show default | awk '/default/ {print $3}'

2. ?策略路由優先級
若系統已有其他路由規則,可通過調整優先級(priority參數)確保新規則生效:

ip rule add to 1.1.1.0/24 lookup custom_table priority 1000

3. 防火墻沖突
如果使用firewalld,需關閉或配置兼容規則:

systemctl stop firewalld && systemctl disable firewalld

4. ?永久生效
策略路由需確保rule-eth0和route-custom_table文件權限為644。
iptables規則需安裝iptables-services并啟用:

yum install iptables-services
systemctl enable iptables

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

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

相關文章

數字孿生技術引領UI前端設計新趨勢:數據可視化與交互設計的深度融合

hello寶子們...我們是艾斯視覺擅長ui設計、前端開發、數字孿生、大數據、三維建模、三維動畫10年經驗!希望我的分享能幫助到您!如需幫助可以評論關注私信我們一起探討!致敬感謝感恩!一、引言:數字孿生驅動 UI 設計的范式革新在大數據與三維可視化技術爆發的今天&…

【機器學習筆記 Ⅱ】6 激活函數

激活函數是神經網絡的核心組件,其作用遠不止“引入非線性”。以下是系統化的解析:1. 核心作用 (1) 引入非線性沒有激活函數:多層神經網絡等價于單層線性變換(矩陣連乘仍是線性)。加入激活函數:每層通過非線…

AI無標記動捕如何結合VR大空間技術打造沉浸式游戲體驗

隨著數字科技的迅猛發展,VR大空間技術正逐步成為各行業探索沉浸式體驗的重要方向。在VR游戲領域,市場對于高度沉浸式體驗的需求日益增長,而傳統VR游戲主要依賴手柄和基礎體感進行交互,而在VR大空間中,用戶可以通過全身…

Qt智能指針

在 Qt 框架中,智能指針用于自動管理對象的生命周期,防止內存泄漏。以下是 Qt 中主要的智能指針及其用法詳解:1. QScopedPointer作用:獨占所有權,超出作用域時自動釋放對象(類似 std::unique_ptr&#xff09…

408第三季part2 - 計算機網絡 - 信道利用率

理解t1是發送幀的傳輸時間t2是確認幀的傳輸時間中間是傳播過程這整個過程就是發送周期任何題目會有以下幾種情況題目這里數據幀和確認幀長度是一樣的t1 t2然后把t1的傳輸數據算出來然后傳播是0.2sd停止等待 k1確認幀忽略t2 0t1算好后,求數據幀的長度下面是速率&…

Android framework 開發者模式下,如何修改動畫過度模式

Android framework 開發者模式下, 如何修改動畫過度模式 開發者模式下,動畫過度 模式1.0→0.5,按如下方式修改。 開發云 - 一站式云服務平臺 .../core/java/com/android/server/wm/WindowManagerService.java | 8 ---- 1 file changed, …

win11安裝paddlelabel并創建目標檢測項目

創建虛擬環境 conda create -n paddlelabel python3.11.11 conda activate paddlelabel通過以下命令安裝 pip install --upgrade paddlelabel輸入命令pdlabel運行paddlelabel,發現報錯: ModuleNotFoundError: Please install connexion using the flask …

關于Novatek B/G-R/G白平衡色溫坐標系再探究

目錄 一、準備知識 二、色溫坐標系的構建 三、Novatek白平衡色溫坐標系的再探究 2.1 直線白點框 2.2雙曲線白點框 四、仿真代碼 之前寫的一篇博文關于聯詠(Novatek )白平衡色溫坐標系探究-CSDN博客感覺邏輯上有些混亂,這個周末我又好好思考了下,以…

基于路徑質量的AI負載均衡異常路徑檢測與恢復策略

AI流量往往具有突發性、大象流(大規模數據流)占比高的特點,極易造成網絡擁塞熱點。一條質量不佳(如高延遲、高丟包、帶寬受限)的路徑,不僅自身無法有效傳輸數據,如果ECMP繼續向其分發流量&#…

ubuntu22.04 安裝cuda cudnn

1.輸入nvidia-smi查看可以支持安裝的cuda最大版本 2.cuda與cudnn版本的選擇 核心原則 向下兼容性:較新的 cuDNN 通常兼容舊版 CUDA,但反之不成立 框架依賴:優先考慮深度學習框架(TensorFlow/PyTorch)的版本要求 硬件…

5、Receiving Messages:Message Listener Containers

提供了兩個MessageListenerContainer實現: KafkaMessageListenerContainer ConcurrentMessageListener容器 KafkaMessageListenerContainer在單個線程上接收來自所有主題或分區的所有消息。ConcurrentMessageListenerContainer委托給一個或多個KafkaMessageListe…

JDBC 注冊驅動的常用方法詳解

JDBC 注冊驅動的常用方法詳解 在 JDBC 中,注冊驅動是建立數據庫連接的第一步。以下是幾種常用的驅動注冊方式: 1. 顯式類加載(傳統方式) // 通過 Class.forName() 加載驅動類 Class.forName("com.mysql.cj.jdbc.Driver&qu…

插入數據優化

目錄 一.插入數據優化 1.insert語句優化 ①批量插入 ②手動提交事務 ③主鍵順序插入 2.大批量插入數據(100萬條) 舉例 第一步:連接數據庫時,加上--local-infile屬性 第二步:查看全局參數local_infile的值&…

區塊鏈在域名系統安全中的應用進展綜述

一、區塊鏈與DNS結合的核心原理1.1 傳統DNS的安全缺陷中心化架構:傳統DNS依賴中心化服務器(如ICANN管理的根服務器),存在單點故障風險,易受DDoS攻擊或配置錯誤影響。協議脆弱性:DNS協議設計之初缺乏加密和認…

GO Web 框架 Gin 完全解析與實踐

目錄 1. 為什么選擇 Gin?解鎖 Go Web 開發的超能力 Gin 的核心優勢 什么時候用 Gin? 第一個 Hello World 2. 路由的藝術:從簡單 GET 到復雜匹配 基礎路由 高級路由技巧 性能優化小貼士 3. 中間件的魔法:讓請求處理更聰明 內置中間件 自定義中間件 中間件的最佳實…

RabbitMQ使用topic Exchange實現微服務分組訂閱

案例場景:用戶下單后需要多個微服務(如營銷、會員)分別訂閱并處理訂單事件,且每個微服務可能有多個集群實例,需要保證同一個微服務的集群中,只有一個實例消費到消息。不同于Kafka和rocketMQ有分組消費的功能…

kotlin 通道trysend方法

trySend 方法是 Kotlin 協程中 Channel 類的一個重要功能。它用于向通道發送元素,但與 send 方法不同的是,trySend 是非阻塞的。這意味著它不會在通道滿時掛起當前協程,而是會立即返回。 trySend 方法的效果 非阻塞行為: 當你調用…

winform CheckedListBox單擊選中解決方案

在WinForms的CheckedListBox控件中,默認需要雙擊才能切換選中狀態(復選框勾選)。要實現單擊即選中,需要通過代碼處理鼠標點擊事件并手動切換選中狀態。以下是實現步驟: 1.CheckOnClick屬性置為true即可。 2.通過事件處…

Docker文件操作、數據卷、掛載

一:容器文件操作 在Docker環境中,管理容器內部的文件是一個常見的需求。 無論是為了配置應用、備份數據還是調試問題,了解如何高效地進行文件操作都是非常重要的。 docker cp命令提供了一種簡單的方法來在宿主主機和容器之間復制文件或目錄…

接口漏洞怎么抓?Fiddler 中文版 + Postman + Wireshark 實戰指南

接口安全是現代應用開發中的高危環節:一旦API存在未授權訪問、參數篡改、權限繞過等漏洞,可能直接導致用戶信息泄露、資金損失甚至整個平臺癱瘓。對于開發和安全人員來說,光依賴后端日志排查遠遠不夠,需要對接口進行主動安全性驗證…