[发明专利]多核多线程的报文转发方法及系统无效

专利信息
申请号: 201210125985.1 申请日: 2012-04-26
公开(公告)号: CN102685002A 公开(公告)日: 2012-09-19
发明(设计)人: 陈海滨 申请(专利权)人: 汉柏科技有限公司
主分类号: H04L12/56 分类号: H04L12/56;H04L29/06
代理公司: 北京路浩知识产权代理有限公司 11002 代理人: 王莹
地址: 300384 天津市华*** 国省代码: 天津;12
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 多核 多线程 报文 转发 方法 系统
【说明书】:

技术领域

本发明涉及网络通信技术领域,特别涉及一种多核多线程的报文转发方法及系统。

背景技术

在一个程序中,这些独立运行的程序片断叫作“线程”(Thread),利用它编程的概念就叫做“多线程处理”。多线程处理一个常见的例子就是用户界面。利用线程,用户可按下一个按钮,然后程序会立即做出响应,而不是让用户等待程序完成了当前任务以后才开始响应。

当前高端网络设备大多采用多核CPU的硬件架构来提高报文的处理和转发性能,对多核CPU分别创建相应的线程与所述多核CPU进行一对一的绑定。申请号为:201010289667.X,发明名称为:一种基于多核构架的报文转发方法及系统的中国专利中,记载了一种将hash队列(即文中的hash表所划分的区域)与线程相绑定的方法,实现了共享资源的免锁设计,但在网络设备出现几条数据流的报文,通过hash计算后均落在了一个hash队列中时,这样就会导致与该hash队列对应的线程很繁忙,与其他hash队列对应的线程均处于闲置状态的情况出现,从而多核CPU的使用效率较低,造成资源的浪费。

发明内容

(一)要解决的技术问题

本发明要解决的技术问题是:如何提高多核CPU在报文转发时的使用效率,避免资源的浪费。

(二)技术方案

为解决上述技术问题,本发明提供了一种多核多线程的报文转发方法,所述方法包括以下步骤:

S1:创建一个预设大小的hash表,并将所述hash表划分为预设个数的区域,设每个区域均为一个hash队列,所述预设个数为大于等于2的整数;

S2:接收物理接口的报文,并根据所述报文的IP五元组进行hash计算,根据计算结果将所述报文放入对应的hash队列中;

S3:当前线程判断当前hash队列是否被其它线程获取权限,若是,则将其它hash队列作为当前hash队列,并重复执行步骤S3,否则执行步骤S4;

S4:获取所述当前hash队列的权限,判断所述当前hash队列中是否具有报文,若是,则对所述当前hash队列中的报文进行报文转发处理,将其它线程作为当前线程,并返回步骤S3,否则舍弃所述当前线程的权限,并将其它hash队列作为当前hash队列,返回步骤S3。

优选地,步骤S1之前还包括以下步骤:

S0:多核CPU分别对应生成与所述多核CPU数量相同的线程。

优选地,所述预设大小为65536。

本发明还公开了一种多核多线程的报文转发系统,所述系统包括:

创建划分模块,用于创建一个预设大小的hash表,并将所述hash表划分为预设个数的区域,设每个区域均为一个hash队列,所述预设个数为大于等于2的整数;

计算模块,用于接收物理接口的报文,并根据所述报文的IP五元组进行hash计算,根据计算结果将所述报文放入对应的hash队列中;

判断模块,用于当前线程判断当前hash队列是否被其它线程获取权限,若是,则将其它hash队列作为当前hash队列,并重复执行判断模块,否则执行权限获取模块;

权限获取模块,用于获取所述当前hash队列的权限,判断所述当前hash队列中是否具有报文,若是,则对所述当前hash队列中的报文进行报文转发处理,将其它线程作为当前线程,并返回判断模块,否则舍弃所述当前线程的权限,并将其它hash队列作为当前hash队列,返回判断模块。

(三)有益效果

本发明通过多核CPU对应的线程浮动获取hash队列的方式,在实现了资源共享的免锁的同时,还可使用与hash队列的数量相同或更少的线程进行报文转发处理,提高了多核CPU在报文转发时的使用效率,避免了资源的浪费。

附图说明

图1是按照本发明一种实施方式的多核多线程的报文转发方法的流程图。

具体实施方式

下面结合附图和实施例,对本发明的具体实施方式作进一步详细描述。以下实施例用于说明本发明,但不用来限制本发明的范围。

图1是按照本发明一种实施方式的多核多线程的报文转发方法的流程图;参照图1,本实施方式的方法包括以下步骤:

S1:创建一个预设大小的hash表,并将所述hash表划分为预设个数的区域,设每个区域均为一个hash队列,所述预设个数为大于等于2的整数,本实施方式中,所述预设大小为65536;

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于汉柏科技有限公司,未经汉柏科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201210125985.1/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top