SIP協議在嵌入式Linux中的實現
2.2 SIP協議棧的總體結構
根據以上分析,在設計中需對SIP協議棧進行修改和裁剪,使其盡量少地占用資源并能最大限度地實現快速響應。本文設計的嵌入式SIP協議棧模型如圖1所示。本文引用地址:http://www.104case.com/article/151706.htm
協議棧主要分成傳輸層和事務層。傳輸層主要負責收發消息,它管理套接字(socket)和網絡連接,使用TCP或UDP傳送數據。事務層則負責創建并管理事務對象。每個事務對象負責維持狀態,并發消息和使用傳輸層重傳消息。事務層也需要將從傳輸層傳來的消息映射到相應的事務。
SIP協議棧管理層負責系統配置、分配內管理資源、提供登錄協議棧和進行管理的命令以及所有其他層的初始化和關閉。應用程序使用該協議棧前,必須先調用該層的初始化接口以初始化要使用的層,在結束應用程序前,必須調用該層的關閉接口關閉相應的層。
SIP編碼解析是協議棧運行過程中比較耗費時間的一個模塊,為滿足嵌入式環境,該協議棧使用了一種“懶漢”解析策略,當從網絡上收到一個原始的SIP消息時,消息被解析成很多“關鍵字和關鍵字值對”,關鍵字是請求行或SIP頭域名,關鍵字值是沒有解析的請求行和頭域值。到事務層,在應用程序要訪問請求行或某個頭域時,才會對其完全解析,這種策略可有效提高SIP解碼的速度,極大提高那些需要處理繁重網絡流量的應用。
2.3 事務層和傳輸層的實現
圖2為事務層和傳輸層的軟件結構。這2層都使用SIP消息編碼解析層的功能處理SIP消息。其中傳輸層包含3個模塊:1)TcpConn模塊使用TCP實現收發消息功能;2)UdpConn模塊使用UDP現收發消息功能;3)SipMessageSendRcv模塊利用TcpConn和UdpConn向應用程序提供統一的消息收發接口。在TcpConn和UdpConn中,都會創建2個線程,分別負責接收和發送SIP消息。
事務層創建并管理事務對象。TransactionSendRcv提供發送不同SIP消息的接口,并以回調函數的方式在收到消息時通知應用程序。Tr-ansactionSendRcv使用傳輸SipMessageSendRcv提供的收發消息功能收發SIP消息,并根據收發的消息類型產生事件,將事件以及事件體(主要是SIP消息)作為參數傳遞給相應模塊UACTransactFSM和UASTransactlFSM。事務層的核心就是這2個模塊,分別表示UA客戶端和服務器端收到不同消息的處理流程,具體的狀態轉換如圖3所示。
linux相關文章:linux教程
評論