1. 程式人生 > >幾種開放原始碼的TCP/IP協議棧比較

幾種開放原始碼的TCP/IP協議棧比較

1、BSD TCP/IP協議棧

     BSD棧歷史上是其他商業棧的起點,大多數專業TCP/IP棧(VxWorks內嵌的TCP/IP棧)是BSD棧派生的。這是因為BSD棧在BSD許可協議下提供了這些專業棧的雛形,BSD許用證允許BSD棧以修改或未修改的形式結合這些專業棧的程式碼而無須向建立者付版稅。同時,BSD也是許多TCP/IP協議中的創新(如廣域網中餓擁塞控制和避免)的開始點。

2、uC/IP

    uC/IP是由Guy Lancaster編寫的一套基於uC/OS且開放原始碼的TCP/IP協議棧,亦可移植到其它作業系統,是一套完全免費的、可供研究的TCP/IP協議棧,uC/IP大部分原始碼是從公開原始碼BSD釋出站點和KA9Q(一個基於DOS單任務環境執行的TCP/IP協議棧)移植過來。uC/IP具有如下一些特點:帶身份驗證和報頭壓縮支援的PPP協議,優化的單一請求/回覆互動過程,支援IP/TCP/UDP協議,可實現的網路功能較為強大,並可裁減。UCIP協議棧被設計為一個帶最小化使用者介面及可應用序列鏈路網路模組。根據採用CPU、編譯器和系統所需實現協議的多少,協議棧需要的程式碼容量空間在30-60KB之間。

http://ucip.sourceforge.net

3、LwIP

     LwIP是瑞士電腦科學院(Swedish Institute of Computer Science)的Adam Dunkels等開發的一套用於嵌入式系統的開放原始碼TCP/IP協議棧。LwIP的含義是Light Weight(輕型)IP協議,相對於uip。LwIP可以移植到作業系統上,也可以在無作業系統的情況下獨立執行。LwIP TCP/IP實現的重點是在保持TCP協議主要功能的基礎上減少對RAM的佔用,一般它只需要幾十K的RAM和40K左右的ROM就可以執行,這使LwIP協議棧適合在低端嵌入式系統中使用。LwIP的特性如下:支援多網路介面下的IP轉發,支援ICMP協議 ,包括實驗性擴充套件的的UDP(使用者資料報協議),包括阻塞控制,RTT估算和快速恢復和快速轉發的TCP(傳輸控制協議),提供專門的內部回撥介面(Raw API)用於提高應用程式效能,並提供了可選擇的Berkeley介面API。

http://www.sics.se/~adam/lwip/http://savannah.nongnu.org/projects/lwip/

4、uIP

    uIP是專門為8位和16位控制器設計的一個非常小的TCP/IP棧。完全用C編寫,因此可移植到各種不同的結構和作業系統上,一個編譯過的棧可以在幾KB ROM或幾百位元組RAM中執行。uIP中還包括一個HTTP伺服器作為服務內容。許可:BSD許用證
http://www.sics.se/~adam/uip/

5、TinyTcp

    TinyTcp 棧是TCP/IP的一個非常小和簡單的實現,它包括一個FTP客戶。TinyTcp是為了燒入ROM設計的並且現在開始對大端結構似乎是有用的(初始目標是68000晶片)。TinyTcp也包括一個簡單的乙太網驅動器用於3COM多匯流排卡 

http://ftp.ecs.soton.ac.uk/pub/elks/utils/tiny-tcp.txt

選擇一個開源協議棧可以從四個方面來考慮:
       一個是是否提供易用的底層硬體API,即與硬體平臺的無關性;
       一個是與作業系統的核心API。協議棧需要呼叫的系統函式介面是否容易構造,
       另一個對於應用支援程度。
       最關鍵的是佔用的系統資源是否在可接受範圍內,有裁減優化的空間否? 

其中,BSD 棧可完整實現TCP/IP協議,但程式碼龐大,70KB-150KB之間,裁減優化有難度,uIP和TinyTcp程式碼容量小巧,實現功能精簡,限制了在一些較高要求場合下的應用,如可靠性與大容量資料傳輸。

LwIP和uC/IP是同量級別的兩個開源協議棧,兩者程式碼容量和實現功能相似,LwIP沒有作業系統針對性,它將協議棧與平臺相關的程式碼抽象出來,使用者如果要移植到自己的系統,需要完成該部分程式碼的封裝,併為網路應用支援提供了API介面的可選性。uC/IP協議最初是針對uC/OS設計,為方便使用者移植實現,同樣也抽象了協議棧與平臺相關程式碼,但是協議棧所需呼叫的系統函式大多參照uC/OS核心函式原型設計,並提供了協議棧的測試函式,方便使用者參考,其不足在於該協議棧對網路應用支援不足。 

根據以上分析,從應用和開發的角度看,似乎LWIP更得到了網上很多朋友使用的青睞;uC/IP在文件支援與軟體升級管理上有很多不足,但是它最初是針對UC/OS而設計,如果選用UC/OS作為軟體基礎的話,在系統函式構造方面有優勢。當然你選擇其他作業系統的話,可參照OS_NULL資料夾下的檔案修改。 以上的這些開源協議棧也並非免費,拿來就可以用,據我所知,UC/OS的母公司推出UC/OS-TCP/IP花了6人*2年的工作量,國內某公司使用LWIP作為移植的參照,花了4-5人*2年的工作量來測試與優化協議,使用商用TCP/IP棧的高費用就不足為奇了。 作為廣大的愛好者學習而言,如果只是跑跑原型,實驗一下效果,以上的幾種開源協議棧都提供了測試的例子,應該是不錯的選擇。

個人的看法:LWIP可優先考慮,至少網上有很多的人一塊研究,參考的資料較多;UC/IP其次,如果你想深入學習TCP/IP的話,移植UC/IP是一種挑戰性的工作,它尚需完善。