《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的TCP粘合設計實現
基于FPGA的TCP粘合設計實現
Icbuy
Icbuy
摘要: 行業產品市場行情,產品價格趨勢分析,全國各類展會動態,盡在ICBuy電子網行業資訊頻道。他是您把握市場行情不可多得的得力助手!
Abstract:
Key words :
</a>信息" title="信息">信息" title="信息">信息,決定數據的流向,一旦雙方開始通信,該代理就不再對數據進行分析,而僅起到一個透明網關的作用,從而提高代理的系統性能。

  TCP粘合技術采用軟件處理方式時,由于大量數據包不需要上層解析,因此提高了系統性能,但是受軟件處理速度的限制,該技術仍很難應用于大規模的集群系統。本文提出了一種基于FPGA的TCP粘合技術的高速實現機制,利用硬件的高速處理特性和流水線技術來適應高速網絡傳輸的需要。 

  1 現存的TCP粘合技術

  TCP粘合原理如下:(1)監聽客戶端的連接請求,并在客戶端發出連接請求后(從SYN開始),建立客戶端到均衡器之間的連接(通過TCP的三次握手協議完成)。(2)在隨后的請求報文中分析數據并決定真正被訪問的服務節點。(3)與服務節點建立另一個連接,將兩個連接粘合在一起(Splicing)。其TCP粘合原理示意圖如圖1所示[2]。

TCP粘合原理示意圖

 

  2 TCP粘合技術的硬件實現

  TCP粘合技術的關鍵在于,當客戶端發起連接請求時,系統并不是立即將該請求發給后端服務器,而是偽裝成服務器與客戶端建立連接,取得用戶的GET數據包。通過對URL的匹配來找到信息在后端服務器的位置,然后再在客戶端與服務器之間建立連接通信。

  2.1 系統架構

  TCP粘合系統結構如圖2所示。

 

  該系統中首先由客戶數據接收端對接收到的HTTP報文進行解析,發現數據包為一個發起連接的SYN數據包時,傳給地址管理單元,地址管理就為該連接分配一個地址空間,同時通過映射單元告訴客戶數據發送端與客戶端完成三次握手,建立連接。

  當客戶數據接收端接收到GET數據包時,將該數據包發送給字符串匹配表,該表會將信息在后端服務器的位置返回給地址管理單元,地址管理單元將該信息送給數據包映射單元,映射單元將該信息寫入相應的SSRAM空間中,同時通知服務器發送端與后端服務器建立連接。這樣就完成了一個TCP的粘合過程。

  在客戶端與服務器的通信過程中,數據包映射單元通過雙方SIP、DIP信息從SSRAM中查找出對應的替換信息,完成雙方數據包的映射。

  在雙方通信結束時,由地址管理單元對雙方使用的地址空間進行回收;同時為防止通信過程中的異常中斷,地址管理單元內部還采用了定時器機制對地址空間進行監測,根據定時器返回結果回收過時地址,防止過時信息被查用。

  2.2 設計實現

  在該系統中,為完成TCP粘合并且保證TCP通信的可靠性,必須能夠正確識別接收到的數據包類型;同時由于實際網絡數據傳輸的延時,在一個客戶端通信過程中可能會插入很多其他客戶端發起的新的連接請求,系統內部根據對CAM查找返回的地址來區分不同的數據流,因此要對內部地址空間進行有效的釋放回收,為處理網絡通信異常中斷而導致內部地址無法回收而引入定時器機制;在數據發送部分,客戶端數據發送模塊偽裝成服務器與客戶端完成TCP三次握手協議;服務器數據發送模塊則偽裝成客戶端與服務器完成TCP三次握手協議。雙方在通信過程中轉發對方的數據包。

  2.2.1 數據收發

  對于系統的發送接口來說,所有發送數據包的轉發由數據包映射單元完成,因此發送接口僅完成簡單的數據包轉發功能。而當系統接收到數據包時,要對數據包進行協議解析,從而決定數據包后端處理的方式。在接收部分主要對三種數據包進行區分:(1)雙方發起連接的SYN數據包。這表示一個新連接的發起,因此交給地址管理單元,為它分配一個新的地址空間,同時要求發送端返回一個ACK數據包;(2)客戶端發來的GET數據包中含有客戶端所需信息的URL地址,將該數據包送給字符串匹配表以獲得該信息所在后端服務器的位置;(3)雙方通信的普通數據包。該數據包交給數據包映射單元實現雙發的通信。具體接收的狀態轉換圖如圖3所示。

 

  2.2.2 地址管理單元

  在地址管理的方式上,在此處利用一個地址鏈表進行管理,如圖4所示。

 

  每次地址管理單元接收到新的請求連接就從鏈表的頭部取出該可用地址空間,將新請求的SIP、DIP信息寫入該地址的CAM中,同時在該地址對應的SSRAM的頁面中寫入相關的信息,假設鏈表中取出地址為n,頁面大小為m,則SSRAM中對應的頁面起始地址l為:

  l=n×m

  當地址管理單元接收到字符串匹配表返回的后端服務器位置信息時,首先通過該數據包的SIP、DIP從CAM中查找該數據流對應的地址,通過上述計算公式找出SSRAM中對應的頁面,寫入返回信息。

  對于地址空間的回收,為防止通信異常中斷而無法回收地址,在系統中采用定時器機制,即在一段時間后對SSRAM中的定時器標志位進行檢測,一旦發現該標志位過時則通知地址管理單元回收地址。地址管理單元收到某一地址過時的信息后,將該地址掛在地址管理鏈表尾部,同時清除該地址CAM中的SIP、DIP信息。這樣當同一IP發起新的連接時就不會查找到過時信息。

  2.2.3 數據包映射單元

  為完成數據包的映射,該部分需要實現兩個功能:ACK序列號轉換和雙方轉換信息的存儲。

  在TCP粘合過程中,由于TCP粘合系統送給客戶端的ACK序列號和后端服務器送給客戶端的ACK序列號不相同,因此要進行ACK序列號的轉換,同時要重新計算數據包的TCP/IP校驗和。

  現假設客戶端發送了請求連接的SYN數據包,而客戶端返回給客戶端的SYN序列號為地址管理單元分配給該連接的地址A0,而當系統和服務器建立鏈接時服務器端返回的SYN序列號為A1,則根據這兩個序列號可計算差值A為:A=A0-A1。

  以后通信的過程中,只要將服務器發送給系統的序列號加上A就能夠轉換成為系統送給客戶端的序列號,這樣就完成了服務器端向客戶端發送數據的轉換,反之就可以完成客戶端向服務器發送數據的轉換。

  對于數據包的校驗和轉換而言,由于校驗和本質上是加法運算,所以只需要在原來的校驗和基礎上加上序列號之差(或減去一個差值)即可完成校驗和的轉換。

  在同一個通信過程中,ACK序列號轉換、校驗和的轉換、發起連接的SYN、GET數據包和定時器標志位等信息都需要存儲,由于每個數據流需要存儲的內容較多,單一的地址已經無法滿足存儲要求。此處存儲管理采用頁面式的管理方式。將整個存儲空間分為若干頁面,每個數據流信息存入一個頁面中。SSRAM的存儲格式如圖5所示。

 

  3 性能分析

  該架構已在試驗系統上實現,接收端為兩個GE口。相對于采用TCP粘合的應用代理服務器來說(其中代理服務器CPU Pentium IV 2GHz),具體的性能對比如表1所示。

 

  從上表可以看出在最大連接數方面,在本系統中采用一個18Mbit的CAM,它能夠提供的最大地址空間為288K×144bit,只能支持288K的連接數。對于服務器的最大連接數來說,SYN和GET數據包需要經過軟件協議解析。因此當最大連接數達到582K時CPU的利用率將達到90%以上[3],無法再處理新的連接。從上述分析中可以看出,由于受硬件資源的限制,硬件系統可以支持的最大連接數小于代理服務器。但是在實際的網絡傳輸過程中,一個HTTP連接持續的時間一般為幾百個毫秒,在硬件系統達到每秒21K的連接數時,能夠承受的一個HTTP最大持續時間為13秒,遠遠大于實際HTTP連接的持續時間,因此硬件系統支持的最大連接數是夠用的。當代理服務器采用千兆網卡來接收數據時,由于數據需要經過上層協議解析,因此實際能夠接收的數據量只能夠達到300Mbps。假設每次平均請求512B,則代理服務器能夠支持的最大每秒連接數大約為7K;而當硬件系統工作在133MHz,內部采用32bit總線傳輸時,整個系統的帶寬達到4Gbit,同時系統內部采用流水線方式,能夠線速處理1Gbps數據的接收,假設平均每次請求512B,則硬件系統能夠處理的每秒最大連接數達到21K,因此在單位時間內能夠處理的連接數量會高于代理服務器。

  隨著HTTP訪問量的不斷增大,對于訪問數據包的分流粒度要求越來越細。本文提出的基于硬件實現的TCP粘合系統,在TCP粘合技術的基礎上,利用硬件的高速處理特性,可以達到2個GE口收發(2Gbps)的線速處理性能。同時能夠較好地基于內容來區分數據流,從而避免了后端服務器數據的重新分發。



 

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
午夜在线精品| 欧美精品一区二区三区四区| 亚洲人午夜精品免费| 久久超碰97中文字幕| 亚洲欧美日韩国产成人精品影院| av成人天堂| 亚洲电影免费观看高清| 激情久久五月天| 国模私拍一区二区三区| 国产亚洲精品福利| 国产色婷婷国产综合在线理论片a| 国产精品久久久爽爽爽麻豆色哟哟| 欧美连裤袜在线视频| 欧美激情亚洲自拍| 欧美国产大片| 欧美精品免费视频| 欧美日韩123| 欧美日韩一区二区三区在线看| 欧美美女喷水视频| 欧美日韩一本到| 欧美天天视频| 国产精品麻豆成人av电影艾秋| 欧美午夜不卡在线观看免费| 国产精品地址| 国产欧美综合一区二区三区| 国产欧美日韩精品一区| 国产一区二区精品在线观看| 海角社区69精品视频| 有坂深雪在线一区| 亚洲黄色在线视频| 一道本一区二区| 亚洲欧美日韩一区在线| 久久成人精品电影| 亚洲精品日韩激情在线电影| 日韩视频免费观看| 亚洲午夜在线观看| 欧美中文在线观看国产| 久久久国产一区二区三区| 久久天堂成人| 欧美精品在线播放| 国产精品高清免费在线观看| 国产欧美日本一区二区三区| 国产字幕视频一区二区| 亚洲国产99| 国产精品久久99| 国产日产欧美精品| 激情小说另类小说亚洲欧美| 亚洲高清电影| 正在播放亚洲一区| 欧美一级日韩一级| 亚洲美女视频在线免费观看| 亚洲午夜一二三区视频| 久久精品中文| 欧美啪啪一区| 国产精品萝li| 亚洲电影在线免费观看| 一区二区三区导航| 欧美影院久久久| 99精品国产在热久久下载| 先锋影音国产一区| 免费看亚洲片| 国产精品每日更新在线播放网址| 红桃视频国产精品| 一本高清dvd不卡在线观看| 欧美永久精品| 亚洲一区二区黄色| 久久久久久久一区| 欧美日韩一区二区三区免费| 韩国自拍一区| 一区二区三区四区精品| 亚洲国产视频直播| 午夜精品久久久久久久蜜桃app| 美女精品在线观看| 国产精品日韩欧美一区二区| 亚洲国产日韩一区| 欧美一区二区免费| 亚洲四色影视在线观看| 麻豆精品视频在线| 国产精品日韩欧美大师| 亚洲精品少妇30p| 久久精品国产第一区二区三区最新章节 | 久久国产色av| 欧美视频第二页| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧美激情一区| 一本一本久久a久久精品牛牛影视| 久久精品国产精品| 欧美调教vk| 亚洲日本中文字幕区| 久久国产精品99久久久久久老狼 | 亚洲永久精品大片| 99精品视频免费在线观看| 久久人人97超碰国产公开结果| 国产精品v欧美精品v日本精品动漫| 亚洲国产日韩一区| 亚洲电影免费观看高清| 欧美亚洲在线视频| 欧美小视频在线| 日韩一级在线| 一本一本久久| 欧美精品播放| 亚洲黄色视屏| 亚洲美女福利视频网站| 免费看av成人| 一区二区在线观看视频在线观看| 午夜性色一区二区三区免费视频| 亚洲一区在线免费| 欧美体内she精视频| 999亚洲国产精| 一区二区三区国产| 欧美日本精品一区二区三区| 亚洲国产色一区| 亚洲国产精品欧美一二99| 久久精品网址| 国产午夜精品全部视频在线播放| 亚洲免费在线观看视频| 亚洲综合好骚| 国产精品男人爽免费视频1| 在线亚洲精品福利网址导航| 在线亚洲一区观看| 欧美日韩精品在线播放| 亚洲精品日韩一| 夜夜嗨av色综合久久久综合网| 欧美激情自拍| 日韩视频久久| 亚洲欧美日本国产专区一区| 国产精品久久久久毛片软件| 亚洲综合首页| 久久久久久亚洲精品杨幂换脸| 激情五月综合色婷婷一区二区| 亚洲丰满在线| 欧美激情片在线观看| 亚洲精品国精品久久99热一| 亚洲图片你懂的| 国产精品免费网站在线观看| 亚洲欧美日韩天堂| 久久免费黄色| 亚洲国产精品久久久久婷婷884 | 亚洲最新视频在线播放| 欧美女激情福利| 一二三区精品福利视频| 午夜免费在线观看精品视频| 国产午夜一区二区三区| 久久爱另类一区二区小说| 久久综合狠狠综合久久综青草| 亚洲高清在线视频| 亚洲午夜电影网| 国产日韩欧美在线一区| 久久高清免费观看| 欧美ed2k| 一区二区三区视频在线看 | 久久久久久久网| 亚洲国产天堂久久综合网| 一区二区久久| 国产美女诱惑一区二区| 久久9热精品视频| 亚洲一区二区三区涩| 国产三区二区一区久久| 亚洲国产视频直播| 欧美日韩日本视频| 香蕉视频成人在线观看| 亚洲欧美自拍偷拍| 激情综合网址| 一区二区欧美日韩视频| 国产精品一区久久久| 亚洲国产cao| 欧美日一区二区在线观看 | 久久免费国产精品1| 亚洲黄色天堂| 性色av香蕉一区二区| 影音先锋在线一区| 亚洲欧美激情视频| 一区二区三区自拍| 一区二区三区四区精品| 国产欧美一区二区三区久久| 亚洲黄色影院| 国产精品一区二区三区观看| 亚洲欧洲综合另类在线| 国产精品久久久久久久第一福利 | 亚洲欧美日韩区| 欧美精品1区| 欧美一级理论性理论a| 欧美日韩三级在线| 亚洲第一区色| 国产精品久久久久久久久久尿 | 国产网站欧美日韩免费精品在线观看| 亚洲精品综合在线| 国产日韩欧美日韩| 在线亚洲欧美专区二区| 一区二区三区在线观看欧美| 亚洲欧美日韩人成在线播放| 亚洲电影视频在线| 欧美中文字幕精品| 日韩视频精品| 欧美大片一区二区| 欧美在线播放视频| 国产精品久久久久免费a∨| 日韩视频一区二区三区| 国产原创一区二区| 亚洲一区二区在线观看视频|