色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python如何實(shí)時(shí)獲取tcpdump輸出

瀏覽:51日期:2022-07-11 09:57:15

一、背景

今天有個(gè)小需求,要確認(rèn)客戶端有沒(méi)有往服務(wù)端發(fā)送udp包,但為了減輕工作量,不想每次到機(jī)器上手動(dòng)執(zhí)行tcpdump抓包命令。于是就寫(xiě)了個(gè)腳本來(lái)釋放人力。

二、代碼實(shí)現(xiàn)

整個(gè)腳本我還加了一些其他功能:時(shí)間戳、發(fā)送端IP提取,數(shù)據(jù)包分析,數(shù)據(jù)持久化等。這里都先去掉,僅記錄下簡(jiǎn)單的實(shí)時(shí)獲取tcpdump輸出功能。代碼如下:

# -*- coding: utf-8 -*-# !/usr/bin/env python# sudo tcpdump -tt -l -nn -c 5 -i enp4s0 udp port 514 or 51414import subprocesscmd = [’sudo’, ’tcpdump’, ’-tt’, ’-l’, ’-nn’, ’-c’, ’5’, ’-i’, ’enp4s0’, ’udp’, ’port’, ’514’, ’or’, ’51414’]proc = subprocess.Popen(cmd, stdout=subprocess.PIPE)while True: line = proc.stdout.readline() line = line.strip() if not line: print(’tcpdump finished...’) break print(line)

輸出如下(實(shí)時(shí)):

wenyuanblog@localhost:/home/test/script# python tcpdump_udp.py tcpdump: verbose output suppressed, use -v or -vv for full protocol decodelistening on enp4s0, link-type EN10MB (Ethernet), capture size 262144 bytes1499774951.124178 IP 192.168.10.210.41974 > 192.168.10.251.514: UDP, length 1391499774953.125664 IP 192.168.10.210.54995 > 192.168.10.251.51414: UDP, length 1391499774956.128498 IP 192.168.10.210.56748 > 192.168.10.251.514: UDP, length 1391499774958.129918 IP 192.168.10.210.53883 > 192.168.10.251.51414: UDP, length 1391499774961.132921 IP 192.168.10.210.58803 > 192.168.10.251.514: UDP, length 1395 packets captured6 packets received by filter0 packets dropped by kerneltcpdump finished...

以上代碼相當(dāng)于手動(dòng)執(zhí)行了 sudo tcpdump -tt -l -nn -c 5 -i enp4s0 udp port 514 or 51414 這條命令。注意參數(shù)-l很重要(行顯)。

三、代碼實(shí)現(xiàn)(更新)

上面的代碼能實(shí)現(xiàn)tcpdump的功能,但是有一個(gè)問(wèn)題:沒(méi)有做超時(shí)保護(hù)。即當(dāng)程序執(zhí)行時(shí)間過(guò)長(zhǎng)時(shí)kill該進(jìn)程(這里使用ctrl+c的方式)。要實(shí)現(xiàn)這個(gè)功能有很多種方案,例如定時(shí)器+多線程等,這里僅演示一種方案,代碼如下:

# -*- coding: utf-8 -*-# !/usr/bin/env python# sudo tcpdump -tt -l -nn -c 50 -i enp4s0 udp port 514 or 51414import subprocessimport signalimport timeimport osimport reimport jsonclass CmdServer: def __init__(self, cmd, timeout=120): ’’’ :param cmd: 執(zhí)行命令(列表形式) :param timeout: 任務(wù)超時(shí)時(shí)間(seconds,進(jìn)程運(yùn)行超過(guò)該時(shí)間,kill該進(jìn)程) :param taskname: 任務(wù)名稱(根據(jù)該任務(wù)名稱記錄命令輸出信息) ’’’ self.cmd = cmd self.timeout = timeout self.base_path = reduce(lambda x, y: os.path.dirname(x), range(1), os.path.abspath(__file__)) self.output_path = os.path.join(self.base_path, ’data.json’) self.udp_flow_list = [] self.begin_time = int(time.time()) # 執(zhí)行tcpdump任務(wù) def run(self): if os.path.exists(self.output_path): with open(self.output_path, ’r’) as f:self.udp_flow_list = json.load(f) proc = subprocess.Popen(self.cmd, stdout=subprocess.PIPE) stdout = ’’ while proc.poll() == None: current_time = int(time.time()) if current_time - self.begin_time >= self.timeout:print(’tcpdump timeout...’)proc.send_signal(signal.SIGINT)stdout = proc.stdout.read() if proc.poll() is not None and not stdout: print(’tcpdump finished...’) stdout = proc.stdout.read() stdout_list = stdout.split(’n’) if stdout_list: self._merge_data(stdout_list) self._save_data() # 數(shù)據(jù)合并(新增/更新) def _merge_data(self, stdout_list): for line in stdout_list: line = line.strip() if not line:continue timestamp = int(float(line.split(’IP’)[0].strip())) * 1000 # 源 src_ip_port_list = re.findall(r’IP(.+?)>’, line) if not src_ip_port_list:continue src_ip_port_str = src_ip_port_list[0].strip() src_ip = ’.’.join(src_ip_port_str.split(’.’)[0:4]) # 目的 dst_ip_port_list = re.findall(r’>(.+?):’, line) if not dst_ip_port_list:continue dst_ip_port_str = dst_ip_port_list[0].strip() dst_port = dst_ip_port_str.split(’.’)[-1] # 新增/更新latest_timestamp src_item = filter(lambda x: src_ip == x[’src_ip’], self.udp_flow_list) if src_item:src_item[0][’dst_port’] = dst_portsrc_item[0][’latest_timestamp’] = timestamp else:self.udp_flow_list.append(dict( src_ip=src_ip, dst_port=dst_port, latest_timestamp=timestamp)) # 保存數(shù)據(jù) def _save_data(self): # 寫(xiě)入文件 with open(self.output_path, ’w’) as f: json.dump(self.udp_flow_list, f, encoding='utf-8', ensure_ascii=False)if __name__ == ’__main__’: cmd = [’sudo’, ’tcpdump’, ’-tt’, ’-l’, ’-nn’, ’-c’, ’5’, ’-i’, ’enp4s0’, ’udp’, ’port’, ’514’, ’or’, ’51414’] cmd_server = CmdServer(cmd, 10) cmd_server.run()

四、總結(jié)

比較簡(jiǎn)單,僅僅是記錄下。

以上就是python如何實(shí)時(shí)獲取tcpdump輸出的詳細(xì)內(nèi)容,更多關(guān)于python獲取tcpdump輸出的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 乱人伦中文视频在线 | 韩国一级永久免费观看网址 | 久久色精品 | 亚洲成人国产 | 欧美成人久久一级c片免费 欧美成人看片黄a免费 | 国产一级一级片 | 国产精品日韩欧美 | 成人观看视频又黄又免费 | 久色网址 | 三级三级三级全黄 | 加勒比日本道 | 亚洲精品一区二区三区四区 | 亚洲第一页视频 | av国产精品 | 亚洲91在线| 狠狠色婷婷丁香综合久久韩国 | 国产美女作爱全过程免费视频 | 国产一区中文字幕在线观看 | 亚洲天堂网视频 | 亚洲日本久久一区二区va | 在线免费视频 | 国产美女主播一级成人毛片 | 欧美一级毛片100部 欧美一级毛片aaaaa | 在线成人a毛片免费播放 | 国产精品正在播放 | 国产女人在线观看 | 毛片毛片毛是个毛毛片 | 亚洲图片偷拍自拍 | 6一10周岁毛片免费 6一12呦女精品 | 国产黄三级三·级三级 | 日日摸人人看97人人澡 | 成人丝袜激情一区二区 | 久久国产精品成人免费 | 日本色综合网 | 欧美日韩专区国产精品 | 国产黄色在线网站 | 成年人www| 国产成人午夜极速观看 | 国产午夜久久影院 | 国产永久免费高清动作片www | 在线观看免费视频国产 |