[发明专利]基于两级存储的正则表达式匹配方法有效

专利信息
申请号: 201310207309.3 申请日: 2013-05-30
公开(公告)号: CN103312627A 公开(公告)日: 2013-09-18
发明(设计)人: 陈曙晖;徐成成;唐勇;赵国鸿;陈一骄;孙一品 申请(专利权)人: 中国人民解放军国防科学技术大学
主分类号: H04L12/883 分类号: H04L12/883;H04L12/955;H04L29/06
代理公司: 湖南兆弘专利事务所 43008 代理人: 周长清
地址: 410073 湖南省长沙市砚瓦池正*** 国省代码: 湖南;43
权利要求书: 查看更多 说明书: 查看更多
摘要: 一种基于两级存储的正则表达式匹配方法,其步骤为:第一步、处理模式集,生成自动机;第二步、求解自动机的稳态向量;第三步、匹配引擎的存储架构;将正则表达式的匹配分为控制平面和数据平面两个层次,控制平面运行在通用存储器上,控制特征码的编译和引擎的空间;数据平面主要负责高速的数据处理;第四步、状态表的配置;对状态的标识进行重新命名,使那些高概率的状态拥有较小的连续的标识,使一级存储器中直接用初始地址加偏移量的方法来查找指定标识的状态表项;第五步、报文处理。本发明能够降低存储费用、提高匹配性能、使系统整体性价比大幅提升。
搜索关键词: 基于 两级 存储 正则 表达式 匹配 方法
【主权项】:
一种基于两级存储的正则表达式匹配方法,其特征在于,步骤为:第一步、处理模式集,生成自动机;将正则表达式模式集编译成一个NFA,并将NFA转换成DFA;然后对DFA状态表进行改写,对每个状态的状态表项增加一个字长的标志位,若该状态为可接受状态,则置1,否则置0;第二步、求解自动机的稳态向量;首先根据DFA的状态转移表求解单步转移概率矩阵,然后根据高效自动机状态空间划分方法,对自动机的可约性进行判断;若自动机是可约的,则可直接用矩阵的幂运算求解稳态向量;若自动机不可约,就先对自动机的状态空间进行划分,得到一个过渡状态集和若干个闭态集,用矩阵的幂运算求解各闭态集的稳态向量,然后求解整个状态空间的稳态向量;第三步、匹配引擎的存储架构;将正则表达式的匹配分为控制平面和数据平面两个层次,控制平面运行在通用存储器上,控制特征码的编译和引擎的空间;数据平面主要负责高速的数据处理;即,将FPGA片内存储器上每个RAM块存储同样的状态表,则每个RAM块都可同时处理两个数据流的匹配,作为一级存储器;将多块SRAM并联起来,作为存储架构的二级存储器;第四步、状态表的配置;对状态的标识进行重新命名,使那些高概率的状态拥有较小的连续的标识,使一级存储器中直接用初始地址加偏移量的方法来查找指定标识的状态表项;根据FPGA片内存储器上单块RAM的容量大小,将DFA中概率较高的那部分状态表项并行存储在各个RAM块中,将整个DFA状态表项存储于SRAM中;第五步、报文处理;首先,对网络报文进行预处理,去掉各层头部信息,仅保留有效载荷,并在尾部补0,使报文长度为2K;然后,根据各个报文缓冲区中的空闲情况,将该报文段分发到空闲率最高的报文缓冲区中,并将该缓冲区的尾指针后移一个位置;如果所有的报文缓冲区都被占满,则丢弃该段报文;匹配引擎根据id号从对应的报文缓冲区取出一段报文,并将该缓冲区队列头指针后移一个位置,若缓冲区为空则等待则缓冲区填充报文;从报文第一个字符开始依次进行匹配,若有状态命中规则,则将该状态存至结果缓冲区中对应位置,随后清空该段报文,进行下一段报文的匹配;否则直至匹配到报文的最后一个字符,然后进行下一段报文的匹配。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

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

本文链接:http://www.vipzhuanli.com/patent/201310207309.3/,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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