[发明专利]基于FPGA的高速网络数据流负载均衡调度方法有效
申请号: | 201310056497.4 | 申请日: | 2013-02-22 |
公开(公告)号: | CN103139093A | 公开(公告)日: | 2013-06-05 |
发明(设计)人: | 王勇;刘勇;陶晓玲;何倩 | 申请(专利权)人: | 桂林电子科技大学 |
主分类号: | H04L12/803 | 分类号: | H04L12/803 |
代理公司: | 桂林市持衡专利商标事务所有限公司 45107 | 代理人: | 陈跃琳 |
地址: | 541004 广*** | 国省代码: | 广西;45 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 fpga 高速 网络 数据流 负载 均衡 调度 方法 | ||
1.基于FPGA的高速网络数据流负载均衡调度方法,其特征是包括如下步骤:
S1.数据包首部信息提取,FPGA采用TEMAC核将物理层比特流封装成MAC帧,然后再相应提取源IP地址、目的IP地址、源端口、目的端口、复位RST、同步SYN和终止FIN;
S2.哈希运算,对提取的源IP地址、目的IP地址、源端口和目的端口进行四元组哈希运算,并将哈希结果对4求模取余数;
S3.流映射表管理,包括流映射表的写操作管理、读操作管理和清除操作管理;即
S31.判断TCP新建连接,若SYN=1,则根据在本周期中队列组中最大剩余数据量,判断是否存在队列拥塞,若最大剩余数据量没有超过一定门限值则视为没有拥塞,则不做任何处理;若最大剩余量超过该门限且存在某种梯度时视为轻度、中度与重度拥塞,则分别按某种概率增长方式依概率选中最小流量端口作为当前数据包的输出端口,并标记流映射端口有效,同时将该数据包对应的源IP地址和目的IP地址写入CAM中,并将该CAM地址作为RAM地址,将该输出端口值存入RAM中,以备后续同一条流的数据包访问;若SYN=0,则执行S32;
S32.判断TCP复位,若RST=1,则将数据包对应的源IP地址和目的IP地址匹配CAM,若匹配CAM命中,则将该CAM地址写入指定FIFO,以示该CAM地址单元已被清除,若匹配CAM不命中,则不做任何处理;若RST=0,执行S33;
S33.将数据包相应的源IP地址和目的IP地址匹配CAM,若匹配CAM命中,则将该命中的CAM地址作为地址访问RAM,得到该数据包的输出端口,并标记流映射端口有效,再判断TCP终止,若FIN=1,则再将该CAM地址写入指定FIFO,以示该CAM地址单元已被清除,若FIN=0,则表示该数据包为普通数据包,跳出此步;若匹配CAM不命中,则不做任何处理;
S4.输出端口选择,根据流映射表与哈希值来选择当前数据包的输出端口,即在流映射端口有效时优先选择流映射端口为输出端口,在流映射端口无效时选择哈希值为输出端口;
S5.数据输入输出管理,包含将数据包写入至缓冲池与读取到对应PHY端口;即
S51.从缓冲器接收数据包,并传递该数据包长度信息,另外根据输出端口修改相应指定字段,并将该数据包存储至缓冲池中,同时记录一次数据包传输的首地址;
S52.根据上述记录中的首地址,读取缓冲池中的数据包,根据修改的输出端口字段发送至相应输出队列,使之从该端口发出;
S6.队列分发与存储管理,将数据包相应信息分发存储至PHY端口对应FIFO中,并经过一定周期后反馈当前队列组最大剩余数据量;
S7.流量统计与反馈,在一定周期内统计并反馈当前最小流量端口,并基于速率反馈动态调整下一次统计的周期。
2.根据权利要求1所述的基于FPGA的高速网络数据流负载均衡调度方法,其特征是,
步骤S2与S3并发执行,此外步骤S5、S6与S7也并发执行。
3.根据权利要求1所述的基于FPGA的高速网络数据流负载均衡调度方法,其特征是,
步骤S2中所述哈希运算为移位异或哈希运算。
4.根据权利要求1所述的基于FPGA的高速网络数据流负载均衡调度方法,其特征是,
步骤S5中的数据包的写入与读取以块为单位,其中一个块中有多个数据包。
5.根据权利要求1所述的基于FPGA的高速网络数据流负载均衡调度方法,其特征是,
步骤S7中将前一个周期中端口速率以及当前端口速率按一定关联因子计算出速率,进而依据当前端口流量得出下一个统计周期值。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于桂林电子科技大学,未经桂林电子科技大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201310056497.4/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种电容触摸屏及其制造方法
- 下一篇:电气故障火花实时监测方法及装置