91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么進行Linux IPsec的分析

發布時間:2021-11-03 16:58:25 來源:億速云 閱讀:165 作者:柒染 欄目:建站服務器

今天就跟大家聊聊有關怎么進行Linux IPsec的分析,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

這里主要講述通過復盤排查IPSec故障的整體過程,揭示分析故障的方法,以及通過該故障學習相關知識。

由于業務需要,我們在海外的某些節點上搭建了VPN,方便海外節點之間的數據交互,某天我們在兩個新節點之間搭建了一條新的VPN,上線之后Ping、traceroute測試無異常,觀察已經有流量通過,監控指標等一切正常。但是過了半個小時后,業務反饋兩個新節點之間網絡不通,發現問題后緊急上線回退了配置。然后事后線下回測,發現通過重啟IPsec 進程,能重現時通時不通的現象。

接下來重現復盤一下當時的配置和場景,以及解釋該問題的根因。

環境簡述


怎么進行Linux IPsec的分析

如上所示,A/B兩個節點通過IPsec打通,A側的網段為10.0.0.0/24,B側的網段為10.0.1.0/24與10.0.2.0/24。A側將去往10.0.1.0/24與10.0.2.0/24網段的數據包丟向節點B的IPSec Server,反之亦然。

一側的配置如下:

conn Tunnel1

    authby=secret

    auto=start

    left=%defaultroute

    leftid=1.1.1.1(本側公網IP)

    right=2.2.2.2(對側公網IP)

    type=tunnel

    ikelifetime=8h

    keylife=1h

    phase2alg=aes128-sha1;modp1024

    ike=aes128-sha1;modp1024

    auth=esp

    keyingtries=%forever

    keyexchange=ike

     leftsubnets={10.0.1.0/24,10.0.2.0/24}

     rightsubnet=10.0.0.0/24

     dpddelay=10

    dpdtimeout=30

    dpdaction=restart_by_peer

異常表現與原因

異常的表象為節點A的后端服務集群無法與節點B后端的服務正常通信,但是查看IPSec服務的狀態時,IPSec的狀態是正常的,甚至能抓包看到數據在IPSec Tunnel中通信,但是當節點A與B通信異常的時候,IPSec Server不正常向后端轉發加密的數據包。然后查看/proc/net/xfrm_stat文件發現有一個XfrmInTmplMismatch錯誤計數一直處于上升狀態,經查這個報錯的原因為No matching template for states不匹配。簡述就是IPSec的SA與SP不相匹配,然后在通過ip xfrm monitor 命令發現節點A與B之間通信的SPI不一致。

怎么進行Linux IPsec的分析

圖1

怎么進行Linux IPsec的分析

圖2

首先看圖2,請求發起時走的Tunnel的SPI為0x198e7538,屬于reqid 16385號 Tunnel,回包時走的Tunnel 的SPI為0x9ce44e77,屬于reqid 16389號Tunnel。由于兩條Tunnel的IKE不同,因此出現了XfrmInTmplMismatch上升的錯誤,解決方案很簡單,將配置文件中的leftsubnets={10.0.1.0/24,10.0.2.0/24}改為leftsubnet=0.0.0.0/0,這樣就能避免來回路徑不一致的問題(PS.因為只有一條路了:))

根因分析

解決方案已經有了,但是做人總得深入了解一下,為啥當有兩條IPSec Tunnel時,路由會發生錯誤。由于上述看到是因為來回路徑不同導致的問題,因此看源碼找一下SPI的生成規則:

https://github.com/xelerance/Openswan/blob/master/programs/pluto/kernel.h

怎么進行Linux IPsec的分析

https://github.com/xelerance/Openswan/blob/master/programs/pluto/kernel.c

中有一個函數是get_ipsec_spi ,他的作用為生成唯一的SPI號,然后我們一下它是如何生成SPI號的:

怎么進行Linux IPsec的分析

根據以上,我們就能發現,生成SPI的時候并不會考慮對端的子網掩碼。

綜上,就是本次排查IPSec故障的所有步驟。

看完上述內容,你們對怎么進行Linux IPsec的分析有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

九龙县| 响水县| 辽源市| 崇信县| 平罗县| 惠东县| 无锡市| 洛隆县| 平南县| 鹤峰县| 吴忠市| 灵武市| 三明市| 张家口市| 桃园市| 馆陶县| 大同县| 通海县| 文水县| 高邮市| 来安县| 泗洪县| 盱眙县| 丰镇市| 武乡县| 搜索| 镇安县| 永靖县| 余干县| 苏尼特左旗| 乌苏市| 广昌县| 麻江县| 巩义市| 刚察县| 昆山市| 崇信县| 宝清县| 招远市| 云安县| 松潘县|