《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于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亚洲国产精品_日韩亚洲一区二区
亚洲国产美女精品久久久久∴| 亚洲国产老妈| 欧美a级片网站| 欧美一区二区黄| 亚洲天堂黄色| 亚洲精品中文字幕在线| 亚洲成人在线视频播放 | 国产精品―色哟哟| 欧美人与禽性xxxxx杂性| 免费成人高清视频| 久久婷婷综合激情| 久久免费国产精品1| 久久国产精品99久久久久久老狼| 一区二区日本视频| 99国产精品久久久久老师| 亚洲人成啪啪网站| 亚洲人成在线影院| 亚洲精品免费一区二区三区| 亚洲精品美女久久久久| 亚洲精品一区在线观看| 日韩视频在线一区二区| 夜色激情一区二区| 一本大道久久a久久综合婷婷| 99国产精品99久久久久久| 一本色道88久久加勒比精品| 一区二区国产精品| 亚洲一区美女视频在线观看免费| 亚洲午夜羞羞片| 亚洲在线电影| 性做久久久久久久久| 久久aⅴ国产欧美74aaa| 久久爱www.| 久久中文字幕一区| 欧美va亚洲va日韩∨a综合色| 欧美国产日韩一二三区| 欧美日韩视频在线| 国产精品高潮粉嫩av| 国产精品视频精品视频| 国产一区二区三区在线观看视频| 国产综合久久久久久| 在线成人免费观看| 亚洲精品日韩在线| 在线一区二区三区四区五区| 亚洲欧美激情四射在线日| 久久不射2019中文字幕| 亚洲国产mv| 亚洲精品免费一二三区| 亚洲免费视频在线观看| 久久狠狠久久综合桃花| 免费看精品久久片| 欧美日韩一区二区三区在线| 国产精品一区三区| 激情91久久| 日韩午夜激情av| 先锋影音国产精品| 亚洲精品久久视频| 亚洲欧美中文在线视频| 久久亚洲色图| 欧美日韩三级| 国产自产2019最新不卡| 日韩视频在线观看| 欧美在线影院| 亚洲视频导航| 久久久噜噜噜久久狠狠50岁| 欧美激情一区二区三区全黄| 国产精品视频网| 亚洲高清在线精品| 亚洲一本视频| 亚洲欧洲另类国产综合| 先锋亚洲精品| 欧美va亚洲va国产综合| 国产精品综合| 亚洲精品日日夜夜| 亚洲欧洲av一区二区| 日韩视频免费观看高清完整版| 欧美一区二区在线播放| 欧美寡妇偷汉性猛交| 国产精品五月天| 亚洲国产视频直播| 亚洲欧美日韩在线| 99精品视频免费全部在线| 久久精品72免费观看| 欧美日韩免费看| 在线观看日韩精品| 亚洲专区欧美专区| 亚洲美女av在线播放| 久久中文久久字幕| 国产精品美女久久久久av超清| 亚洲高清影视| 亚洲高清色综合| 欧美亚洲午夜视频在线观看| 欧美激情一区二区三区高清视频| 国产永久精品大片wwwapp| 亚洲午夜伦理| 99精品久久| 欧美成人亚洲| 国产一区清纯| 亚洲永久免费| 亚洲香蕉在线观看| 欧美日本免费| 亚洲黄一区二区三区| 亚洲成人在线视频网站| 欧美专区亚洲专区| 国产精品视频免费一区| 在线综合+亚洲+欧美中文字幕| 亚洲免费av网站| 免费成人高清视频| 狠狠色狠色综合曰曰| 性色av一区二区三区红粉影视| 在线亚洲+欧美+日本专区| 欧美sm视频| 在线观看欧美日本| 亚洲成色精品| 久久蜜臀精品av| 国产一级揄自揄精品视频| 亚洲一级在线观看| 午夜视频在线观看一区| 欧美色图首页| 99国产麻豆精品| 中文在线资源观看网站视频免费不卡| 欧美顶级大胆免费视频| 永久555www成人免费| 亚洲电影免费观看高清完整版在线观看 | 一本久道综合久久精品| 亚洲国产成人tv| 久久影视精品| 国产一区在线免费观看| 午夜精品一区二区三区在线| 亚洲影院免费观看| 欧美日韩在线视频首页| 一本色道久久88综合亚洲精品ⅰ| 99香蕉国产精品偷在线观看| 欧美精品偷拍| 99精品欧美| 午夜精品国产更新| 国产精品亚洲成人| 亚洲淫片在线视频| 欧美在线视频一区| 国产日韩欧美另类| 欧美怡红院视频| 媚黑女一区二区| 亚洲人成绝费网站色www| 一本久道久久综合婷婷鲸鱼| 欧美日韩在线一区| 亚洲影院免费观看| 久久久精品2019中文字幕神马| 一区二区在线看| 亚洲伦理自拍| 欧美三区在线观看| 亚洲欧美在线网| 久久久久国产精品人| 尤物九九久久国产精品的分类| 亚洲日本va午夜在线影院| 欧美国产日本高清在线| 夜夜嗨av色一区二区不卡| 欧美一区二区三区免费看| 国产自产精品| 99re6这里只有精品视频在线观看| 欧美午夜激情在线| 亚洲欧美中文日韩在线| 麻豆精品在线观看| 亚洲乱码一区二区| 欧美一区二区免费| 精品999成人| 一区二区三区国产精品| 国产精品自拍一区| 亚洲黄色尤物视频| 欧美视频福利| 久久成人免费电影| 欧美另类99xxxxx| 午夜精品福利视频| 女女同性精品视频| 一区二区三区久久| 久久人人97超碰人人澡爱香蕉| 亚洲国产成人精品久久久国产成人一区| 夜夜精品视频一区二区| 国产欧美一区二区三区沐欲 | 在线观看一区二区视频| 亚洲视频一二| 国产一区二区三区久久 | 欧美日韩高清在线播放| 午夜电影亚洲| 欧美黑人在线播放| 午夜欧美大尺度福利影院在线看| 嫩模写真一区二区三区三州| 亚洲午夜91| 蜜桃精品一区二区三区| 亚洲午夜成aⅴ人片| 免费观看成人www动漫视频| 中国亚洲黄色| 毛片一区二区三区| 亚洲欧美区自拍先锋| 欧美激情一区二区三区全黄 | 久久精品国产69国产精品亚洲| 欧美日韩国产不卡在线看| 欧美在线观看你懂的| 国产精品高清在线观看| 亚洲国产一区二区三区在线播| 国产精品日韩专区| aa成人免费视频|