Kubernetes中的 iptables 規則介紹

#作者:鄧偉

文章目錄

  • 一、Kubernetes 網絡模型概述
  • 二、iptables 基礎知識
  • 三、Kubernetes 中的 iptables 應用
  • 四、查看和調試 iptables 規則
  • 五、總結

在 Kubernetes 集群中,iptables 是一個核心組件, 用于實現服務發現和網絡策略。iptables 通過一系列規則來控制數據包在網絡中的流向,確保集群內部的服務能夠正確地路由到相應的 Pods。本文將深入探討 Kubernetes 中 iptables 的工作原理、配置方式及其重要性。

一、Kubernetes 網絡模型概述

在 Kubernetes 中,每個 Pod 都被分配了一個獨立的 IP 地址,并且這些 Pod 可以直接相互通信,而不需要進行 NAT 轉換。為了支持這一模型,Kubernetes 使用了多種網絡插件(如 Calico、Flannel 等)來管理網絡,同時利用 iptables 來實現服務發現和服務負載均衡。

如 calico架構圖:
在這里插入圖片描述

二、iptables 基礎知識

iptables 是 Linux 內核提供的一個用戶空間工具,用于設置、維護和檢查 IP 包過濾規則表。它主要包括以下幾條鏈:
a.INPUT:處理目標是本機的數據包。
b.OUTPUT:處理從本機發出的數據包。
c.FORWARD:處理需要經過本機轉發的數據包。
d.PREROUTING:在路由之前處理數據包。
e.POSTROUTING:在路由之后處理數據包。

每條鏈都包含若干規則,當數據包到達時會依次匹配這些規則。如果某條規則匹配成功,則執行該規則指定的動作(如 ACCEPT、DROP、REDIRECT 等)。

如圖:
在這里插入圖片描述

三、Kubernetes 中的 iptables 應用

  1. Service 和 ClusterIP
    Kubernetes 中的 Service 提供了一種簡單的方式來訪問一組提供相同服務的 Pods。ClusterIP 類型的 Service 為后端 Pods 分配了一個虛擬 IP 地址(VIP),并使用 iptables 規則將流量導向實際的 Pods。

例如,假設有一個名為 my-service 的 Service,其 VIP 是 10.96.0.1,則會在節點上添加如下類似的 iptables 規則:

-A KUBE-SERVICES -d 10.96.0.1/32 -p tcp -m comment --comment "default/my-service: cluster IP" -m tcp --dport 80 -j KUBE-SVC-NWV5X2332I4OT4T3

這條規則表示所有發往 10.96.0.1:80 的 TCP 流量都會被重定向到 KUBE-SVC-NWV5X2332I4OT4T3 這個自定義鏈中進一步處理。實際場景如圖:
在這里插入圖片描述

  1. Endpoint 和 DNAT
    接下來,在對應的 KUBE-SVC-NWV5X2332I4OT4T3 鏈中,iptables 會根據權重隨機選擇一個 Endpoint(即具體的 Pod IP),并通過 DNAT(Destination Network Address Translation)將其轉換為目標 Pod 的 IP 地址:
-A KUBE-SVC-NWV5X2332I4OT4T3 -m statistic --mode random --probability 0.5000000000 -j KUBE-SEP-WNBA2IHDGP2BOBGZ
-A KUBE-SVC-NWV5X2332I4OT4T3 -j KUBE-SEP-X3P2623AGDHZCBTG

這里,KUBE-SEP-WNBA2IHDGP2BOBGZ 和 KUBE-SEP-X3P2623AGDHZCBTG 分別代表兩個不同的 Endpoint,iptables 會以 50% 的概率選擇其中一個作為目標地址。

  1. NodePort 和 ExternalTrafficPolicy
    對于 NodePort 類型的 Service,除了上述 ClusterIP 的規則外,還會增加額外的規則以便從外部訪問。此外,如果設置了 ExternalTrafficPolicy: Local,iptables 將只允許本地運行的 Pods 接收來自外部的流量,避免跨節點轉發帶來的性能損耗。

四、查看和調試 iptables 規則

你可以使用以下命令查看當前節點上的 iptables 規則:
iptables-save | grep KUBE
或者針對特定鏈進行查看:
iptables -t nat -L KUBE-SERVICES
若遇到問題,可以借助 tcpdump 等工具抓包分析,結合 iptables 日志(需開啟相關選項)定位故障原因。

五、總結

iptables 在 Kubernetes 中扮演著至關重要的角色,它不僅實現了基本的服務發現功能,還支持復雜的網絡策略控制。理解 iptables 的工作機制有助于我們更好地管理和優化 Kubernetes 集群的網絡環境。隨著 Kubernetes 不斷演進,CNI 插件和其他網絡解決方案也在不斷改進,但 iptables 依然是理解和操作 Kubernetes 網絡不可或缺的知識點。

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

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

相關文章

.NET Core全屏截圖,C#全屏截圖

.NET Core全屏截圖,C#全屏截圖 使用框架: WPF.NET 8 using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Imaging; using System.Linq; using System.Text; using System.Threading.Tasks; using System.W…

Java直通車系列15【Spring MVC】(ModelAndView 使用)

目錄 1. ModelAndView 概述 2. ModelAndView 的主要屬性和方法 主要屬性 主要方法 3. 場景示例 示例 1:簡單的 ModelAndView 使用 示例 2:使用 ModelAndView 處理列表數據 示例 3:使用 ModelAndView 處理異常情況 1. ModelAndView 概…

視頻圖像刷新到HTTP的原理

上一篇博客已經說了cgi拿到了共享內存的程序還需要處理的才能夠真正刷新到網頁里面去 HTTP協議介紹 HTTP中文名稱是超文本傳輸協議,它是一個簡單的請求.響應協議,HTTP協議它運行在TCP上面,它是互聯網數據通信的基礎。 幾乎所有的網頁請求和互…

2024四川大學計算機考研復試上機真題

2024四川大學計算機考研復試上機真題 2024四川大學計算機考研復試機試真題 歷年四川大學計算機考研復試機試真題 在線評測:https://app2098.acapp.acwing.com.cn/ 分數求和 題目描述 有一分數序列: 2/1 3/2 5/3 8/5 13/8 21/13… 求出這個數列的前 …

Python評估網絡脆弱性

一、網絡安全 (1)網絡安全的定義 網絡安全是指計算機網絡系統中的硬件、數據、程序等不會因為無意或惡意的原因而遭到破壞、篡改、泄露,防止非授權的使用或訪問,系統能夠保持服務的連續性,以及能夠可靠的運行。網絡安…

Java后端高頻面經——Spring、SpringBoot、MyBatis

Spring定義一個Bean有哪些方法?依賴注入有哪些方法? (1)定義Bean的方法 注解定義Bean,Component 用于標記一個類作為Spring的bean。當一個類被Component注解標記時,Spring會將其實例化為一個bean&#xff0…

Qt 實現繪圖板(支持橡皮擦與 Ctrl+Z 撤銷功能)[特殊字符]

作業&#xff1a; 1&#xff1a;實現繪圖的時候&#xff0c;顏色的隨時調整 2&#xff1a;追加橡皮擦功能 3&#xff1a;配合鍵盤事件&#xff0c;實現功能 當鍵盤按 ctrlz的時候&#xff0c;撤銷最后一次繪圖 頭文件.h #ifndef WIDGET_H #define WIDGET_H#include <QWidge…

計算機網絡(1) 網絡通信基礎,協議介紹,通信框架

網絡結構模式 C/S-----客戶端和服務器 B/S -----瀏覽器服務器 MAC地址 每一個網卡都擁有獨一無二的48位串行號&#xff0c;也即MAC地址&#xff0c;也叫做物理地址、硬件地址或者是局域網地址 MAC地址表示為12個16進制數 如00-16-EA-AE-3C-40 &#xff08;每一個數可以用四個…

HOW - React 如何在在瀏覽器繪制之前同步執行 - useLayoutEffect

目錄 useEffect vs useLayoutEffectuseEffectuseLayoutEffect主要區別總結選擇建議注意事項 useLayoutEffect 使用示例測量 DOM 元素的尺寸和位置示例&#xff1a;自適應彈出框定位 同步更新樣式以避免閃爍示例&#xff1a;根據內容動態調整容器高度 圖像或 Canvas 繪制前的準備…

【無人機三維路徑規劃】基于CPO冠豪豬優化算法的無人機三維路徑規劃Maltab

代碼獲取基于CPO冠豪豬優化算法的無人機三維路徑規劃Maltab 基于CPO冠豪豬優化算法的無人機三維路徑規劃 一、CPO算法的基本原理與核心優勢 冠豪豬優化算法&#xff08;Crested Porcupine Optimizer, CPO&#xff09;是一種新型元啟發式算法&#xff0c;其靈感來源于冠豪豬的…

深度學習驅動的智能化革命:從技術突破到行業實踐

第一章 深度學習的技術演進與核心架構 1.1 從淺層網絡到深度學習的范式轉變 深度學習的核心在于通過多層次非線性變換自動提取數據特征,其發展歷程可劃分為三個階段:符號主義時代的規則驅動(1950s-1980s)、連接主義時代的淺層網絡(1990s-2000s)以及深度學習時代的端到端…

簡潔實用的3個免費wordpress主題

高端大氣動態炫酷的免費企業官網wordpress主題 非常簡潔的免費wordpress主題&#xff0c;安裝簡單、設置簡單&#xff0c;幾分鐘就可以搭建好一個wordpress網站。 經典風格的免費wordpress主題 免費下載 https://www.fuyefa.com/wordpress

RabbitMQ 高級特性解析:RabbitMQ 消息可靠性保障 (上)

RabbitMQ 核心功能 RabbitMQ 高級特性解析&#xff1a;RabbitMQ 消息可靠性保障 &#xff08;上&#xff09;-CSDN博客 RabbitMQ 高級特性&#xff1a;從 TTL 到消息分發的全面解析 &#xff08;下&#xff09;-CSDN博客 前言 最近再看 RabbitMQ&#xff0c;看了看自己之前寫…

用DeepSeek-R1-Distill-data-110k蒸餾中文數據集 微調Qwen2.5-7B-Instruct!

下載模型與數據 模型下載&#xff1a; huggingface&#xff1a; Qwen/Qwen2.5-7B-Instruct HF MirrorWe’re on a journey to advance and democratize artificial intelligence through open source and open science.https://hf-mirror.com/Qwen/Qwen2.5-7B-Instruct 魔搭&a…

在IDEA中進行git回滾操作:Reset current branch to here?或Reset HEAD

問題描述 1&#xff09;在本地修改好的代碼&#xff0c;commit到本地倉庫&#xff0c;突然發覺有問題不想push推到遠程倉庫了&#xff0c;但它一直在push的列表中存在&#xff0c;那該怎么去掉push列表中的內容呢&#xff1f; 2&#xff09;合并別的分支到當前分支&#xff0…

六十天前端強化訓練之第十一天之事件機制超詳解析

歡迎來到編程星辰海的博客講解 目錄 一、事件模型演進史 1.1 原始事件模型&#xff08;DOM Level 0&#xff09; 1.2 DOM Level 2事件模型 1.3 DOM Level 3事件模型 二、事件流深度剖析 2.1 捕獲與冒泡對比實驗 2.2 事件終止方法對比 三、事件委托高級應用 3.1 動態元…

Qwen架構與Llama架構的核心區別

我們在討論Deepseek不同版本之間的區別時了解到,DeepSeek-R1的蒸餾模型分為Qwen和Llama兩個系列,包括Qwen系列的0.5B、1.5B、3B、7B、14B、32B、72B和Llama系列的8B、70B。Qwen系列以阿里通義千問(Qwen)為基礎模型架構(具體是Qwen-2.5),Llama系列以Meta的Llama為基礎模型…

匿名GitHub鏈接使用教程(Anonymous GitHub)2025

Anonymous GitHub 1. 引言2. 準備3. 進入Anonymous GitHub官網4. 用GitHub登錄匿名GitHub并授權5. 進入個人中心&#xff0c;然后點擊? Anonymize Repo實例化6. 輸入你的GitHub鏈接7. 填寫匿名鏈接的基礎信息8. 提交9. 實例化對應匿名GitHub鏈接10. 進入個人中心管理項目11. 查…

工程化與框架系列(25)--低代碼平臺開發

低代碼平臺開發 &#x1f527; 引言 低代碼開發平臺是一種通過可視化配置和少量代碼實現應用開發的技術方案。本文將深入探討低代碼平臺的設計與實現&#xff0c;包括可視化編輯器、組件系統、數據流管理等關鍵主題&#xff0c;幫助開發者構建高效的低代碼開發平臺。 低代碼…

Redis系列之慢查詢分析與調優

Redis 慢查詢分析與優化&#xff1a;提升性能的實戰指南 Redis 作為一款高性能的內存數據庫&#xff0c;因其快速的數據讀寫能力和靈活的數據結構&#xff0c;被廣泛應用于緩存、消息隊列、排行榜等多種業務場景。然而&#xff0c;隨著業務規模的擴大和數據量的增加&#xff0…