python3使用libpcap給ESL命令添加日誌記錄

来源:https://www.cnblogs.com/MikeZhang/archive/2023/11/25/pyESLCapLog20211125.html
-Advertisement-
Play Games

操作系統 :CentOS 7.6_x64 FreeSWITCH版本 :1.10.9 python版本:3.9.12 libpcap版本:1.11.0b7 FreeSWITCH的ESL模塊用起來很方便,可以控制FreeSWITCH實現具體業務需求,但該模塊沒有提供ESL命令執行日誌,不便於排查問題,本 ...


操作系統 :CentOS 7.6_x64 FreeSWITCH版本 :1.10.9 python版本:3.9.12 libpcap版本:1.11.0b7   FreeSWITCH的ESL模塊用起來很方便,可以控制FreeSWITCH實現具體業務需求,但該模塊沒有提供ESL命令執行日誌,不便於排查問題,本文展示一種使用python3基於libpcap實現ESL命令執行日誌的方法,並提供示例代碼及相關資源下載途徑。

一、背景描述

日常開發過程中觀察到:通過ESL發送給FreeSWITCH的命令,在freeswitch.log中找不到記錄。
查看代碼發現,確實沒有相關記錄(mod_event_socket.c文件):
static void *SWITCH_THREAD_FUNC api_exec(switch_thread_t *thread, void *obj)

分析後發現,大概有以下幾個方法:

  • 1、通過修改FreeSWITCH源代碼實現
文件: mod_event_socket.c 入口: api_exec
可通過switch_log_printf函數來實現。
  • 2、使用tcpdump抓取
因EventSocket模塊使用的是基於TCP的文本協議,且未加密,預設埠8021,可以通過tcpdump抓取event socket服務埠獲取命令記錄。

 示例如下:

tcpdump tcp dst port 8021 -w test1.pcap
  • 3、使用python3基於libpcap實現
底層原理和tcpdump一樣,只是基於libpcap使用python3進行實現,會靈活很多,這也是本文終點描述的方法,具體實現在後續展開。

二、具體實現

本文基於python3.9.12實現,CentOS 7環境編譯及使用python3.9.12,可參考這篇文章:
https://www.cnblogs.com/MikeZhang/p/centos7-install-py39-20220704.html

關鍵點如下:
1、實時抓取網卡數據

可基於libpcap實時抓取網卡數據,具體可參考我之前寫的文章:

https://www.cnblogs.com/MikeZhang/p/pythonUseLibpcap20221029.html

2、解析IP頭獲取源地址
需要獲取發送ESL命令機器的源地址以便排查問題,IP數據包裡面包含有源地址,python中解析IP頭的示例如下:

ipInfo = struct.unpack('!BBHHHBBH4s4s',bytes(p[14:34]))
srcIp = socket.inet_ntoa(ipInfo[-2])
dstIp = socket.inet_ntoa(ipInfo[-1])

3、解析TCP頭獲取具體數據
具體的ESL命令在TCP的數據部分保存,可通過解析TCP頭獲取ESL數據的起始下標,進而獲取數據,示例如下:

tcpInfo = struct.unpack('!HHLLBBH',bytes(p[34:50]))
tcpHdrLen = (tcpInfo[4] >> 4) * 4
offset = 34 + tcpHdrLen
data = bytes(p[offset:tlen])

4、使用logging模塊進行記錄
可使用python自帶的日誌模塊記錄ESL命令記錄,併進行存檔,便於後續查看。

示例如下:

logger.info("(%s,%s)" % (srcIp,data))

logger可在main函數中實現,指定具體的存檔文件,如果只是想控制台查看,則可以這樣實現:

logger = logging.getLogger()

...

logging.basicConfig(
    level=logging.DEBUG, # DEBUG,INFO,WARNING,ERROR,CRITICAL
    format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
    datefmt='%a, %d %b %Y %H:%M:%S'
)

基於上述關鍵點,可以實現ESL命令的日誌記錄,示例如下(eslLogTest1.py):

完整代碼可從如下渠道獲取:

關註微信公眾號(聊聊博文,文末可掃碼)後回覆 20231125 獲取。

三、運行效果

可使用ESL發送命令,然後用python腳本進行記錄。發送ESL命令可使用ESL庫,python3.9.12版本的ESL編譯及使用,可參考這篇文章:
https://www.cnblogs.com/MikeZhang/p/py39esl-20230424.html

也可直接使用socket,示例如下(sendcmd1.py):
import socket,time

def doCmd(sock,cmd):
    print(cmd)
    sock.send(cmd + b'\r\n\r\n')

sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  
sock.connect(('192.168.137.32', 8021))  
sock.send(b'auth ClueCon\r\n\r\n')
doCmd(sock,b'bgapi originate user/1000 &echo')
time.sleep(10)
doCmd(sock,b'bgapi hupall')
發送命令後,使用python實時記錄的運行效果如下:

運行效果視頻可從如下渠道獲取:

關註微信公眾號(聊聊博文,文末可掃碼)後回覆 2023112501 獲取。

四、資源獲取

本文涉及資源,可以從如下途徑獲取:

 關註微信公眾號(聊聊博文,文末可掃碼)後回覆 20231125 獲取。

好,就這麼多了,希望對你有幫助。

微信公眾號:

  • E-Mail : [email protected]
  • 轉載請註明出處,謝謝!
    您的分享是我們最大的動力!

    -Advertisement-
    Play Games
    更多相關文章
    • 什麼時候要使用嵌套查詢? 學生信息表: 學生編號姓名班級Id電話性別生日 180325011 任我行 5 13823204456 男 1999-09-09 180325012 張三 4 13823204452 女 1998-08-08 180325013 李四 2 18899251152 男 199 ...
    • ,: 小天才手錶系統指南(僅限Z6及以下舊款小天才主流機型)強烈推薦使用PDF版本閱讀 【 聲明】允許規範轉載並說明來源,不可用於商業用途。 【 重要提示】本教程配套其他up的講解視頻 點擊觀看 【 支持機型】降級和ROOT:Z2 Z3 Z5A/PRO/Q Z6(不含巔峰版、Z6A) → Z7以及更 ...
    • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 JSONP是一種很遠古用來解決跨域問題的技術,當然現在實際工作當中很少用到該技術了,但是很多同學在找工作面試過程中還是經常被問到,本文將帶您深入瞭解JSONP的工作原理、使用場景及安全註意事項,讓您輕鬆掌握JSONP。 JSONP是什麼? ...
    • 事件匯流排是對發佈-訂閱模式的一種實現。 發佈-訂閱模式定義對象間的一種一對多的依賴關係,當一個對象的狀態發生改變時,所有依賴於它的對象都將得到通知。 發佈-訂閱模式實現了松耦合,發佈者不是直接將消息發送給訂閱者,而是經過了一個中間的代理,事件匯流排就是一種中間代理的實現。 ...
    • matplotlib是基於python生態開發的一個可視化繪圖庫,它的出現讓python在數據分析及機器學習方面占了重要的一部分,目前很多數據分析及機器學習相關方面的工程都有使用到這個庫,並且由於其簡單易用,安裝簡單等方面的優勢深得廣大開發者的喜愛。 ...
    • 15.1、常用組件 15.1.1、 DispatcherServlet DispatcherServlet 是前端控制器,由框架提供,不需要工程師開發; 作用:統一處理請求和響應,整個流程式控制制的中心,由它調用其它組件處理用戶的請求。 15.1.2、HandlerMapping HandlerMapp ...
    • 前言: 在Spring Boot中實現快遞鳥、順豐和快遞100的物流查詢功能通常需要與它們提供的API進行交互。當然使用他們的API 我們是需要申請和註冊,從而去拿到 key 來進行調用。所以為註冊的必須先進行註冊,以下是他們的官網地址,可以快捷到達。 快遞鳥官網:快遞鳥 - 快遞查詢介面_免費快遞 ...
    • SQLite,作為一款嵌入式關係型資料庫管理系統,一直以其輕量級、零配置以及跨平臺等特性而備受青睞。不同於傳統的資料庫系統,SQLite是一個庫,直接與應用程式一同編譯和鏈接,無需單獨的資料庫伺服器進程,實現了資料庫的零配置管理。這種設計理念使得SQLite成為許多嵌入式系統、移動應用和小型項目中的... ...
    一周排行
      -Advertisement-
      Play Games
    • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
    • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
    • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
    • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
    • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
    • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
    • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
    • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
    • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
    • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...