怎么進(jìn)行LinuxIPsec的分析-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)公司長(zhǎng)期為1000多家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為樂都企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),樂都網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

這里主要講述通過復(fù)盤排查IPSec故障的整體過程,揭示分析故障的方法,以及通過該故障學(xué)習(xí)相關(guān)知識(shí)。

由于業(yè)務(wù)需要,我們?cè)诤M獾哪承┕?jié)點(diǎn)上搭建了VPN,方便海外節(jié)點(diǎn)之間的數(shù)據(jù)交互,某天我們?cè)趦蓚€(gè)新節(jié)點(diǎn)之間搭建了一條新的VPN,上線之后Ping、traceroute測(cè)試無異常,觀察已經(jīng)有流量通過,監(jiān)控指標(biāo)等一切正常。但是過了半個(gè)小時(shí)后,業(yè)務(wù)反饋兩個(gè)新節(jié)點(diǎn)之間網(wǎng)絡(luò)不通,發(fā)現(xiàn)問題后緊急上線回退了配置。然后事后線下回測(cè),發(fā)現(xiàn)通過重啟IPsec 進(jìn)程,能重現(xiàn)時(shí)通時(shí)不通的現(xiàn)象。

接下來重現(xiàn)復(fù)盤一下當(dāng)時(shí)的配置和場(chǎng)景,以及解釋該問題的根因。

環(huán)境簡(jiǎn)述

怎么進(jìn)行Linux IPsec的分析

如上所示,A/B兩個(gè)節(jié)點(diǎn)通過IPsec打通,A側(cè)的網(wǎng)段為10.0.0.0/24,B側(cè)的網(wǎng)段為10.0.1.0/24與10.0.2.0/24。A側(cè)將去往10.0.1.0/24與10.0.2.0/24網(wǎng)段的數(shù)據(jù)包丟向節(jié)點(diǎn)B的IPSec Server,反之亦然。

一側(cè)的配置如下:

conn Tunnel1

    authby=secret

    auto=start

    left=%defaultroute

    leftid=1.1.1.1(本側(cè)公網(wǎng)IP)

    right=2.2.2.2(對(duì)側(cè)公網(wǎng)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

異常表現(xiàn)與原因

異常的表象為節(jié)點(diǎn)A的后端服務(wù)集群無法與節(jié)點(diǎn)B后端的服務(wù)正常通信,但是查看IPSec服務(wù)的狀態(tài)時(shí),IPSec的狀態(tài)是正常的,甚至能抓包看到數(shù)據(jù)在IPSec Tunnel中通信,但是當(dāng)節(jié)點(diǎn)A與B通信異常的時(shí)候,IPSec Server不正常向后端轉(zhuǎn)發(fā)加密的數(shù)據(jù)包。然后查看/proc/net/xfrm_stat文件發(fā)現(xiàn)有一個(gè)XfrmInTmplMismatch錯(cuò)誤計(jì)數(shù)一直處于上升狀態(tài),經(jīng)查這個(gè)報(bào)錯(cuò)的原因?yàn)镹o matching template for states不匹配。簡(jiǎn)述就是IPSec的SA與SP不相匹配,然后在通過ip xfrm monitor 命令發(fā)現(xiàn)節(jié)點(diǎn)A與B之間通信的SPI不一致。

怎么進(jìn)行Linux IPsec的分析

圖1

怎么進(jìn)行Linux IPsec的分析

圖2

首先看圖2,請(qǐng)求發(fā)起時(shí)走的Tunnel的SPI為0x198e7538,屬于reqid 16385號(hào) Tunnel,回包時(shí)走的Tunnel 的SPI為0x9ce44e77,屬于reqid 16389號(hào)Tunnel。由于兩條Tunnel的IKE不同,因此出現(xiàn)了XfrmInTmplMismatch上升的錯(cuò)誤,解決方案很簡(jiǎn)單,將配置文件中的leftsubnets={10.0.1.0/24,10.0.2.0/24}改為leftsubnet=0.0.0.0/0,這樣就能避免來回路徑不一致的問題(PS.因?yàn)橹挥幸粭l路了:))

根因分析

解決方案已經(jīng)有了,但是做人總得深入了解一下,為啥當(dāng)有兩條IPSec Tunnel時(shí),路由會(huì)發(fā)生錯(cuò)誤。由于上述看到是因?yàn)閬砘芈窂讲煌瑢?dǎo)致的問題,因此看源碼找一下SPI的生成規(guī)則:

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

怎么進(jìn)行Linux IPsec的分析

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

中有一個(gè)函數(shù)是get_ipsec_spi ,他的作用為生成唯一的SPI號(hào),然后我們一下它是如何生成SPI號(hào)的:

怎么進(jìn)行Linux IPsec的分析

根據(jù)以上,我們就能發(fā)現(xiàn),生成SPI的時(shí)候并不會(huì)考慮對(duì)端的子網(wǎng)掩碼。

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

看完上述內(nèi)容,你們對(duì)怎么進(jìn)行Linux IPsec的分析有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝大家的支持。

文章標(biāo)題:怎么進(jìn)行LinuxIPsec的分析-創(chuàng)新互聯(lián)
新聞來源:http://muchs.cn/article44/dcodee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、建站公司、網(wǎng)站策劃、移動(dòng)網(wǎng)站建設(shè)、虛擬主機(jī)定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司