DPDK PDUMP使用

參考文獻(xiàn):
http://syswift.com/315.html
https://www.cnblogs.com/yhp-smarthome/p/7102557.html
https://blog.csdn.net/bestboyxie/article/details/58713987
如有侵權(quán)哨颂,請(qǐng)聯(lián)系刪除

相關(guān)版本配置信息

CenOS 7.2.1511
2核2線程 (4 lcores)
內(nèi)存4GB
3 NICS
DPDK17.08

DPDK數(shù)據(jù)包捕獲框架由DPDK pdump庫和DPDK pdump工具組成殷蛇,在DPDK v16.07中被初次引入,配置這個(gè)這個(gè)工具可以用于抓取指定接口生棍、隊(duì)列的數(shù)據(jù)。

依賴庫

pdump依賴于libpcap庫及l(fā)ibpcap-dev等相關(guān)庫蚂夕,要預(yù)先安裝。

編譯安裝

Pdump依賴于基于libpcap的PMD驅(qū)動(dòng)禁熏,需要開啟兩個(gè)設(shè)置涎跨,來生成運(yùn)行pdump工具

CONFIG_RTE_LIBRTE_PMD_PCAP=y ($(RTE_SDK)/config/common_base文件)
CONFIG_RTE_LIBRTE_PDUMP=y ($(RTE_SDK)/config/common_base文件)

1.3 編譯dpdk-pdump

cd /root/dpdk-stable-17.08.1/app/pdump  進(jìn)入pdump源碼的存放目錄
make
make install

運(yùn)行原理

pdump使用時(shí),作為secondary進(jìn)程依附于primary進(jìn)程宣虾。primary進(jìn)程中啟動(dòng)server端惯裕,初始化pdump抓包框架任務(wù);dpdk-pdump進(jìn)程是作為client端向primary進(jìn)程發(fā)送開始/停止抓包請(qǐng)求绣硝,然后primary進(jìn)程拷貝一份數(shù)據(jù)包到ring中蜻势,secondary進(jìn)程從ring中讀取出來,并保存為pcap文件鹉胖。因此握玛,可以看出在primary進(jìn)程中需要初始化pdump server够傍。
注:pdump工具只能與數(shù)據(jù)包捕獲框架已初始化的主應(yīng)用程序配合使用,所以必須先啟動(dòng)初始化數(shù)據(jù)包捕獲框架的primary進(jìn)程(例如testpmd, l2fwd, l3fwd)

測(cè)試抓包

以'testpmd' 初始化數(shù)據(jù)包捕獲框架挠铲,作為服務(wù)器冕屯,dpdk-pdump工具作為客戶端。 如果要查看testpmd的Rx或Tx數(shù)據(jù)包拂苹,首先應(yīng)啟動(dòng)應(yīng)用程序安聘,然后再啟動(dòng)dpdk-pdump工具。 testpmd的數(shù)據(jù)包先被發(fā)送到pdump工具瓢棒,然后再從pdump工具發(fā)送到pcap pmd設(shè)備浴韭,最終該設(shè)備根據(jù)命令行選項(xiàng)將數(shù)據(jù)包寫入pcap文件或外部接口。


1. 啟動(dòng)testpmd作為主要應(yīng)用程序

sudo ./build/app/testpmd –l 0,1 –n 4 -- -i --port-topology=chained

2. 啟動(dòng)pdump

sudo ./build/app/dpdk-pdump -- --pdump 'port=0,queue=*,rx-dev=/tmp/capture.pcap'

下面是程序的運(yùn)行參數(shù)
./build/app/dpdk-pdump -- --pdump '(port=<port id> | device_id=<pci id or vdev name>), (queue=<queue_id>), (rx-dev=<iface or pcap file> | tx-dev=<iface or pcap file>), [ring-size=<ring size>], [mbuf-size=<mbuf data size>], [total-num-mbufs=<number of mbufs>]' [--server-socket-path=<server socket dir>] [--client-socket-path=<client socket dir>]

--pdump是必須強(qiáng)制指定的脯宿,其子參數(shù)將在下面部分描述:

()是強(qiáng)制指定的 念颈, []是可選的
多個(gè)--pdump可以用于捕獲不同的接口和隊(duì)列
--server-socket-path這個(gè)選項(xiàng)是可選的。用于指定server socket的目錄嗅绰。如果這個(gè)參數(shù)沒有被指定舍肠,root用戶就默認(rèn)是:/var/run/.dpdk/非root用戶就是 ~/.dpdk/
--client-socket-path 這個(gè)也是可選的搀继。指的是client 的socket目錄窘面。如果這個(gè)參數(shù)沒有被指定,root用戶就默認(rèn)是:/var/run/.dpdk/非root用戶就是 ~/.dpdk

--pdump的子參數(shù)

port :需要被抓包的以太網(wǎng)的portid叽躯;
device_id :需要被抓包的以太網(wǎng)的pci地址或者名字财边;
queue:以太網(wǎng)設(shè)備的queue id;如果queue是*則抓所有的隊(duì)列点骑;(多隊(duì)列的情況)
rx-dev:應(yīng)該是一個(gè)pcap文件名或者linux 的接口
tx-dev:應(yīng)該是一個(gè)pcap的文件名或者是linux的接口
*注意:
因?yàn)橐粋€(gè)bug『眩現(xiàn)在的pdump并不能抓虛擬設(shè)備的報(bào)文;
rx-dev只是入口方向的
tx-dev只是出口方向的
如果兩個(gè)方向都分別要黑滴。tx-dev與rx-dev應(yīng)該被同時(shí)制定兩個(gè)不同的文件或者接口
兩個(gè)方向都同時(shí)要憨募,tx-dev與rx-dev應(yīng)該指定相同的接口或者文件
ring-size:ring的大小。創(chuàng)建內(nèi)部使用的ring袁辈;這個(gè)ring講用于主程序向抓包程序入隊(duì)了用的菜谣。默認(rèn)是16384。
mbuf-sizze:mbuf data的大小晚缩。用于mempool的創(chuàng)建尾膊。用于入隊(duì)列的mbuf用的。主要用于主程序向抓包程序傳數(shù)據(jù)用的荞彼。默認(rèn)是2176冈敛;應(yīng)該與主server的mbuf一樣
total-num-mbufs:這個(gè)指創(chuàng)建mbug的個(gè)數(shù)。默認(rèn)值是65535


3. 通過流量生成器向port0發(fā)送流量

4. 使用tcpdump查看捕獲的pcap文件

$tcpdump -nr /tmp/capture.pcap

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鸣皂,一起剝皮案震驚了整個(gè)濱河市抓谴,隨后出現(xiàn)的幾起案子暮蹂,更是在濱河造成了極大的恐慌,老刑警劉巖癌压,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件椎侠,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡措拇,警方通過查閱死者的電腦和手機(jī)我纪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來丐吓,“玉大人浅悉,你說我怎么就攤上這事∪纾” “怎么了术健?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)粘衬。 經(jīng)常有香客問我荞估,道長(zhǎng),這世上最難降的妖魔是什么稚新? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任勘伺,我火速辦了婚禮,結(jié)果婚禮上褂删,老公的妹妹穿的比我還像新娘飞醉。我一直安慰自己,他們只是感情好屯阀,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布缅帘。 她就那樣靜靜地躺著,像睡著了一般难衰。 火紅的嫁衣襯著肌膚如雪钦无。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天盖袭,我揣著相機(jī)與錄音失暂,去河邊找鬼。 笑死苍凛,一個(gè)胖子當(dāng)著我的面吹牛趣席,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播醇蝴,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼宣肚,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了悠栓?” 一聲冷哼從身側(cè)響起霉涨,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤按价,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后笙瑟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體楼镐,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年往枷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了框产。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡错洁,死狀恐怖秉宿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情屯碴,我是刑警寧澤描睦,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站导而,受9級(jí)特大地震影響忱叭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜今艺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一韵丑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧洼滚,春花似錦埂息、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽享幽。三九已至铲掐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間值桩,已是汗流浹背摆霉。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奔坟,地道東北人携栋。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像咳秉,于是被迫代替她去往敵國(guó)和親婉支。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 1. 簡(jiǎn)介 本文檔包含DPDK軟件安裝和配置的相關(guān)說明澜建。旨在幫助用戶快速啟動(dòng)和運(yùn)行軟件向挖。文檔主要描述了在Linux...
    半天妖閱讀 17,914評(píng)論 0 22
  • 本文主要介紹DPDK框架下進(jìn)行報(bào)文捕獲的方法蝌以,并對(duì)各種方法的優(yōu)劣進(jìn)行簡(jiǎn)單分析。 1.pdump庫的使用 在DPDK...
    cumirror閱讀 12,502評(píng)論 3 12
  • 1.Libpcap 的工作原理 Libpcap的工作原理可以描述為何之,當(dāng)一個(gè)數(shù)據(jù)包到達(dá)網(wǎng)卡時(shí)跟畅,通過網(wǎng)絡(luò)分接口(即旁路...
    shaarawy18閱讀 18,869評(píng)論 1 15
  • 大半的人在20歲或30歲上就死了:一過這個(gè)年齡徊件,他們只變了自己的影子;以后的生命不過是用來模仿自己蒜危,把以前真正有人...
    榆樹閱讀 440評(píng)論 0 0
  • 對(duì)于內(nèi)容創(chuàng)業(yè)者來說舰褪,一個(gè)沒有辦法避免的魔咒就是遭遇瓶頸期皆疹,如何渡過這段 時(shí)間,打通自己的內(nèi)容創(chuàng)業(yè)之路呢占拍? 熱門領(lǐng)域...
    而一心要拍閱讀 817評(píng)論 2 0