CN109451045A - 一种可配置自定义以太头的高速报文采集网卡控制方法 - Google Patents

一种可配置自定义以太头的高速报文采集网卡控制方法 Download PDF

Info

Publication number
CN109451045A
CN109451045A CN201811516677.5A CN201811516677A CN109451045A CN 109451045 A CN109451045 A CN 109451045A CN 201811516677 A CN201811516677 A CN 201811516677A CN 109451045 A CN109451045 A CN 109451045A
Authority
CN
China
Prior art keywords
ethernet header
customized
control method
configure
field
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201811516677.5A
Other languages
English (en)
Inventor
杨洋
原小卫
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Chengdu Jiuzhou Electronic Information System Co Ltd
Original Assignee
Chengdu Jiuzhou Electronic Information System Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Chengdu Jiuzhou Electronic Information System Co Ltd filed Critical Chengdu Jiuzhou Electronic Information System Co Ltd
Priority to CN201811516677.5A priority Critical patent/CN109451045A/zh
Publication of CN109451045A publication Critical patent/CN109451045A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/2866Architectures; Arrangements
    • H04L67/30Profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • H04L41/0803Configuration setting

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明公开了一种可配置自定义以太头的高速报文采集网卡控制方法,该方法包括设定配置文件,获取自定义以太头格式,根据自定义以太头格式进行报文解析,根据配置的HASH函数计算HASH值,根据RETA索引分配CPU。本发明通过对网卡中的配置文件进行设定,使得网卡根据配置文件获取自定义以太头格式后,能够按照自定义以太头对接收的数据报文进行解析,从而能够适应不同的自定义需求,保证数据报文同源同宿的分配到一个CPU。

Description

一种可配置自定义以太头的高速报文采集网卡控制方法
技术领域
本发明属于信息安全技术领域,具体涉及一种可配置自定义以太头的高速报文采集网卡控制方法。
背景技术
通常网卡接收报文的时候可以通过RSS(Receive Side Scaling)使接收报文在多个CPU之间高效分发。
但是一旦用户自定义以太头,这样就导致网卡无法正确的识别出以太头部长度,无法正确计算出报文五元组信息,从而无法保证报文同源同宿的分配到一个CPU,最终导致应用程序无法通过多通道高效的处理报文。
发明内容
本发明的发明目的是:为了解决现有技术中存在的以上问题,本发明提出了一种可配置自定义以太头的高速报文采集网卡控制方法。
本发明的技术方案是:一种可配置自定义以太头的高速报文采集网卡控制方法,包括以下步骤:
A、设定配置文件内容,并在网卡中生成配置文件;
B、利用网卡读取步骤A中生成的配置文件,获取自定义以太头格式信息;
C、利用网卡根据步骤B中自定义以太头格式信息对接收的数据报文进行解析,获取IP地址、协议和端口五元组信息;
D、利用网卡根据配置的HASH函数计算HASH值;
E、选取步骤D中HASH值中的低几位作为RETA的索引,并根据RETA中存储的值分发到对应的CPU。
进一步地,所述步骤A中配置文件采用xml格式生成。
进一步地,所述步骤A中配置文件具体包括user_tag字段、fixed_bytes字段、dynamic_bytes字段、bytes字段和index字段。
进一步地,所述user_tag字段用于判断是否进行自定义以太头解析;若是,则利用网卡根据自定义以太头格式信息对接收的数据报文进行解析;若否,则利用网卡按照标准IP包对接收的数据报文进行解析。
进一步地,所述fixed_bytes字段用于自定义以太头固定长度。
进一步地,所述dynamic_bytes字段用于自定义以太头变长部分。
进一步地,所述dynamic_bytes字段采用bytes字段和index字段进行表示。
进一步地,所述bytes字段用于自定义变长值所占字节数。
进一步地,所述index字段用于自定义变长值起始字节。
本发明的有益效果是:本发明通过对网卡中的配置文件进行设定,使得网卡根据配置文件获取自定义以太头格式后,能够按照自定义以太头对接收的数据报文进行解析,从而能够适应不同的自定义需求,保证数据报文同源同宿的分配到一个CPU。
附图说明
图1为本发明的可配置自定义以太头的高速报文采集网卡控制方法的流程示意图;
图2为本发明的可配置自定义以太头的高速报文采集网卡的硬件逻辑图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
如图1所示,为本发明的可配置自定义以太头的高速报文采集网卡控制方法的流程示意图。一种可配置自定义以太头的高速报文采集网卡控制方法,包括以下步骤:
A、设定配置文件内容,并在网卡中生成配置文件;
B、利用网卡读取步骤A中生成的配置文件,获取自定义以太头格式信息;
C、利用网卡根据步骤B中自定义以太头格式信息对接收的数据报文进行解析,获取IP地址、协议和端口五元组信息;
D、利用网卡根据配置的HASH函数计算HASH值;
E、选取步骤D中HASH值中的低几位作为RETA的索引,并根据RETA中存储的值分发到对应的CPU。
在本发明的一个可选实施例中,上述步骤A首先在网卡中生成预先设定的配置文件,以配置文件形式与用户约定以太头具体格式,同时支持用户配置不同的HASH算法。
因为网卡不需要获取以太层数据每个字段含义,它只需能够正确跳过以太头,解析出五元组信息即可,因此本发明通过设定配置文件使得网卡能够跳过以太头指向IP头。
本发明中配置文件采用xml格式生成,配置文件具体包括user_tag字段、fixed_bytes字段、dynamic_bytes字段、bytes字段和index字段。
上述user_tag字段即自定义标签字段,用于判断是否进行自定义以太头解析;若是,则利用网卡根据自定义以太头格式信息对接收的数据报文进行解析;若否,则利用网卡按照标准IP包对接收的数据报文进行解析。例如,将userTag字段设定为1,即表示按照自定义以太头解析,因此利用网卡根据自定义以太头格式信息对接收的数据报文进行解析;将userTag字段设定为0,即表示按标准IP包解析,因此利用网卡按照标准IP包对接收的数据报文进行解析。
上述fixed_bytes字段即固定字节字段,用于自定义以太头固定长度。
上述dynamic_bytes字段即变长字节字段,用于自定义以太头变长部分,其采用子节点bytes字段和index字段进行表示。
上述bytes字段即变长字节数,用于自定义变长值所占字节数。例如将bytes字段设定为2,表示描述变长字段总共占2个字节。
上述index字段即变长字节索引字段,用于自定义变长值起始字节。例如将index字段设定为17,表示描述变长字段从第17字节开始,连续2个字节所表示的值为变长长度。
本发明设定的配置文件的具体字段可以表示为
<?xmlversion="1.0"encoding="utf-8"?>
<root>
<user_tag>1</user_tag>
<fixed_bytes>17</fixed_bytes>
<dynamic_bytes>
<bytes>2</bytes>
<index>17</index>
<dnamic_bytes>
</root>
配置文件在每次网卡驱动模块的重新安装之后生效。如图2所示,为本发明的可配置自定义以太头的高速报文采集网卡的硬件逻辑图。
在本发明的一个可选实施例中,上述步骤B利用网卡读取步骤A中生成的配置文件,获取自定义以太头格式信息;自定义以太头格式信息包括双层MAC头,具体为非标准以太头以外的用户自定义的以太头格式。
在本发明的一个可选实施例中,上述步骤C利用网卡根据步骤B中自定义以太头格式信息对接收的数据报文进行解析,获取IP地址、协议和端口五元组信息。
在本发明的一个可选实施例中,上述步骤D利用网卡根据配置的HASH函数计算HASH值。
在本发明的一个可选实施例中,上述步骤E选取步骤D中HASH值中的低几位作为RETA(redirection table,索引间接寻址表)的索引,并根据RETA中存储的值分发到对应的CPU。
本领域的普通技术人员将会意识到,这里所述的实施例是为了帮助读者理解本发明的原理,应被理解为本发明的保护范围并不局限于这样的特别陈述和实施例。本领域的普通技术人员可以根据本发明公开的这些技术启示做出各种不脱离本发明实质的其它各种具体变形和组合,这些变形和组合仍然在本发明的保护范围内。

Claims (9)

1.一种可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,包括以下步骤:
A、设定配置文件内容,并在网卡中生成配置文件;
B、利用网卡读取步骤A中生成的配置文件,获取自定义以太头格式信息;
C、利用网卡根据步骤B中自定义以太头格式信息对接收的数据报文进行解析,获取IP地址、协议和端口五元组信息;
D、利用网卡根据配置的HASH函数计算HASH值;
E、选取步骤D中HASH值中的低几位作为RETA的索引,并根据RETA中存储的值分发到对应的CPU。
2.如权利要求1所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述步骤A中配置文件采用xml格式生成。
3.如权利要求2所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述步骤A中配置文件具体包括user_tag字段、fixed_bytes字段、dynamic_bytes字段、bytes字段和index字段。
4.如权利要求3所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述userTag字段用于判断是否进行自定义以太头解析;若是,则利用网卡根据自定义以太头格式信息对接收的数据报文进行解析;若否,则利用网卡按照标准IP包对接收的数据报文进行解析。
5.如权利要求4所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述fixed_bytes字段用于自定义以太头固定长度。
6.如权利要求5所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述dynamic_bytes字段用于自定义以太头变长部分。
7.如权利要求6所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述dynamic_bytes字段采用bytes字段和index字段进行表示。
8.如权利要求7所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述bytes字段用于自定义变长值所占字节数。
9.如权利要求8所述的可配置自定义以太头的高速报文采集网卡控制方法,其特征在于,所述index字段用于自定义变长值起始字节。
CN201811516677.5A 2018-12-12 2018-12-12 一种可配置自定义以太头的高速报文采集网卡控制方法 Pending CN109451045A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811516677.5A CN109451045A (zh) 2018-12-12 2018-12-12 一种可配置自定义以太头的高速报文采集网卡控制方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811516677.5A CN109451045A (zh) 2018-12-12 2018-12-12 一种可配置自定义以太头的高速报文采集网卡控制方法

Publications (1)

Publication Number Publication Date
CN109451045A true CN109451045A (zh) 2019-03-08

Family

ID=65557946

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811516677.5A Pending CN109451045A (zh) 2018-12-12 2018-12-12 一种可配置自定义以太头的高速报文采集网卡控制方法

Country Status (1)

Country Link
CN (1) CN109451045A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111835709A (zh) * 2020-05-29 2020-10-27 深圳市风云实业有限公司 一种基于可控数据流向的网络安全监控系统及方法

Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102546442A (zh) * 2012-03-09 2012-07-04 北京神州数码思特奇信息技术股份有限公司 通信协议转换技术
CN104639578A (zh) * 2013-11-08 2015-05-20 华为技术有限公司 多协议栈负载均衡方法及装置
CN105634958A (zh) * 2015-12-24 2016-06-01 东软集团股份有限公司 基于多核系统的报文转发方法和装置
CN105871725A (zh) * 2015-01-23 2016-08-17 阿里巴巴集团控股有限公司 一种报文分流方法及装置
CN106598581A (zh) * 2016-12-06 2017-04-26 成都能通科技有限公司 基于xml的asterix报文解析代码生成方法
CN106796514A (zh) * 2014-05-21 2017-05-31 社会创新Ipco有限公司 用于完全可配置的实时处理的系统和方法
US9712460B1 (en) * 2013-08-26 2017-07-18 F5 Networks, Inc. Matching port pick for RSS disaggregation hashing
CN107181738A (zh) * 2017-04-25 2017-09-19 中国科学院信息工程研究所 一种软件化入侵检测系统及方法
CN107832149A (zh) * 2017-11-01 2018-03-23 西安微电子技术研究所 一种针对多核处理器动态分组管理的Receive‑side Scaling电路
CN107911349A (zh) * 2017-11-01 2018-04-13 西安微电子技术研究所 一种面向UDP传输的对称性Receive‑side Scaling电路
CN108566297A (zh) * 2018-04-12 2018-09-21 福建升腾资讯有限公司 VOI虚拟化下的Windows网卡驱动加载方法
CN108881172A (zh) * 2018-05-22 2018-11-23 阿里巴巴集团控股有限公司 报文的解析方法及装置
CN108965261A (zh) * 2018-06-25 2018-12-07 网易(杭州)网络有限公司 信息处理方法及装置、存储介质、电子装置

Patent Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102546442A (zh) * 2012-03-09 2012-07-04 北京神州数码思特奇信息技术股份有限公司 通信协议转换技术
US9712460B1 (en) * 2013-08-26 2017-07-18 F5 Networks, Inc. Matching port pick for RSS disaggregation hashing
CN104639578A (zh) * 2013-11-08 2015-05-20 华为技术有限公司 多协议栈负载均衡方法及装置
CN106796514A (zh) * 2014-05-21 2017-05-31 社会创新Ipco有限公司 用于完全可配置的实时处理的系统和方法
CN105871725A (zh) * 2015-01-23 2016-08-17 阿里巴巴集团控股有限公司 一种报文分流方法及装置
CN105634958A (zh) * 2015-12-24 2016-06-01 东软集团股份有限公司 基于多核系统的报文转发方法和装置
CN106598581A (zh) * 2016-12-06 2017-04-26 成都能通科技有限公司 基于xml的asterix报文解析代码生成方法
CN107181738A (zh) * 2017-04-25 2017-09-19 中国科学院信息工程研究所 一种软件化入侵检测系统及方法
CN107832149A (zh) * 2017-11-01 2018-03-23 西安微电子技术研究所 一种针对多核处理器动态分组管理的Receive‑side Scaling电路
CN107911349A (zh) * 2017-11-01 2018-04-13 西安微电子技术研究所 一种面向UDP传输的对称性Receive‑side Scaling电路
CN108566297A (zh) * 2018-04-12 2018-09-21 福建升腾资讯有限公司 VOI虚拟化下的Windows网卡驱动加载方法
CN108881172A (zh) * 2018-05-22 2018-11-23 阿里巴巴集团控股有限公司 报文的解析方法及装置
CN108965261A (zh) * 2018-06-25 2018-12-07 网易(杭州)网络有限公司 信息处理方法及装置、存储介质、电子装置

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
FEI315412: ""网卡多队列技术与RSS功能介绍"", 《百度文库》 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111835709A (zh) * 2020-05-29 2020-10-27 深圳市风云实业有限公司 一种基于可控数据流向的网络安全监控系统及方法
CN111835709B (zh) * 2020-05-29 2022-11-04 深圳市风云实业有限公司 一种基于可控数据流向的网络安全监控系统及方法

Similar Documents

Publication Publication Date Title
US9294590B2 (en) Frame conversion apparatus for converting controller area network frame into ethernet frame and frame conversion method thereof
CN104620235B (zh) 用于自适应串流中的区段分界及识别的系统及方法
CN110798415A (zh) 一种业务传输的方法、设备及计算机存储介质
KR20140133491A (ko) 네트워크 추상 계층 유닛의 패킷 구성방법, 이를 이용한 비디오 부호화 및 복호화 알고리즘 및 장치, 서비스품질 제어를 위한IPv6 라벨 스위칭 알고리즘 및 장치
US11316644B2 (en) Data transmission method, and new as sublayer entity
CN108847248B (zh) 蓝牙设备音频处理方法、系统、可读存储介质和蓝牙设备
KR20060063329A (ko) 네트워크를 통해 멀티미디어 컨텐츠를 전송하는 장치 및방법
US9871893B2 (en) Method for making 32-bit addressing of SV data by utilizing FPGA
US11165845B2 (en) Method and apparatus for efficiently prioritizing elements in a video stream for low-bandwidth transmission
CN106209640B (zh) Down MEP报文处理方法与系统
US9270367B2 (en) Method and system for automatically discovering ODUflex bandwith lossless adjustment capability
US11438098B2 (en) Data transmission method, sending apparatus, and receiving apparatus
CN108111416A (zh) 直接识别mpls内部封装报文的方法
WO2021088629A1 (zh) DetNet数据包处理方法及装置
CN109451045A (zh) 一种可配置自定义以太头的高速报文采集网卡控制方法
CN108419041A (zh) 一种视频数据处理的方法和装置
CN114666681B (zh) 一种有状态的带内网络遥测方法及系统
EP3541088B1 (en) Method, device and system for bearing a frame sequence number in a multichannel passive optical network
CN107426307A (zh) 数据处理方法及装置
WO2021208843A1 (zh) 分段路由头压缩方法及装置、业务处理方法及装置
CN114979093B (zh) 一种基于rtp的数据传输方法、装置、设备和介质
CN110868373A (zh) 多媒体数据传输方法、装置及计算机可读存储介质
CN112788000B (zh) 一种udp数据包解析方法、系统和存储介质
US7792159B2 (en) Multiplexing device and data processing method thereof
JP2023007048A (ja) ストリーミングサーバ、送信方法及びプログラム

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
CB03 Change of inventor or designer information
CB03 Change of inventor or designer information

Inventor after: Yang Yang

Inventor after: Li Lijuan

Inventor after: Yuan Xiaowei

Inventor before: Yang Yang

Inventor before: Yuan Xiaowei

RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20190308