[发明专利]名字查找方法及路由器有效
申请号: | 201711202737.1 | 申请日: | 2017-11-23 |
公开(公告)号: | CN109831384B | 公开(公告)日: | 2021-08-03 |
发明(设计)人: | 黄昆;王兆华;谢高岗 | 申请(专利权)人: | 华为技术有限公司 |
主分类号: | H04L12/743 | 分类号: | H04L12/743;H04L12/741 |
代理公司: | 广州三环专利商标代理有限公司 44202 | 代理人: | 郝传鑫;熊永强 |
地址: | 518129 广东*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 名字 查找 方法 路由器 | ||
1.一种名字查找方法,其特征在于,包括:
接收到终端主机的数据包后,获取所述数据包的名字前缀和所述数据包的名字前缀的外形字串,所述外形字串为所述名字前缀每层的字符长度构成的字符串;
根据所述数据包的名字前缀的外形字串,在三态内容寻址存储器TCAM表中按位搜索以得到第一目标外形字串,所述第一目标外形字串为在所述TCAM表中与所述数据包的名字前缀的外形字串匹配的外形字串中最长的外形字串;
根据所述数据包的名字前缀在静态随机接入存储器SRAM中与所述第一目标外形字串对应的哈希表中进行搜索,若在与所述第一目标外形字串对应的哈希表中未搜索到与所述数据包的名字前缀匹配的名字前缀,在所述第一目标外形字串的前驱字串对应的哈希表中进行搜索,以获取第一目标名字前缀,所述第一目标名字前缀为所述SRAM中与所述数据包的名字前缀匹配的名字前缀中最长的名字前缀,所述哈希表中存储有具有相同外形字串的名字前缀;
将数据包从所述第一目标名字前缀对应的下一跳端口转发出去。
2.根据权利要求1所述的方法,其特征在于,所述获取所述数据包的名字前缀和所述数据包的名字前缀的外形字串,包括:
对所述数据包的名字前缀进行裁剪,以得到裁剪后的名字前缀;
根据所述裁剪后的名字前缀获取所述数据包的名字前缀的外形字串。
3.根据权利要求1或2所述的方法,其特征在于,所述接收到终端主机的数据包后,获取所述数据包的名字前缀和所述数据包的名字前缀的外形字串之前,所述方法还包括:
根据名字前缀规则集构建名字外形树;
对所述名字外形树进行深度收缩操作和节点数量缩减操作。
4.根据权利要求3所述的方法,其特征在于,所述对所述名字外形树进行深度收缩操作和节点数量缩减操作,包括:
从所述名字外形树的底层节点开始,将所述名字外形树中每个节点的位宽度与TCAM的位宽度进行比较,所述节点的位宽度为该节点对应的外形字串在所述TCAM表中存储的位宽度,所述节点的位宽度通过如下方式得到:
获取所述名字外形树的所有节点对应的外形字串中的每个层次的字符长度,并得到所述所有节点对应的外形字串在每个层次的字符长度的最大值;
每个节点对应的外形字串在每个层次的所占位数为该层次的字符长度的最大值,所述节点的位宽度为所有层次的所占位数之和;
当所述名字外形树中节点A的位宽度大于所述TCAM的位宽度时,将所述节点A收缩至其父节点;
其中,所述节点A为所述名字外形树中任一节点。
5.根据权利要求3所述的方法,其特征在于,所述对所述名字外形树进行深度收缩操作和节点数量缩减操作,包括:
当所述名字外形树的节点数量大于TCAM的表项数时,根据负荷最小深度最大优先原则确定所述名字外形树中待缩减节点;
将所述待缩减节点缩减至其前驱节点,以使所述名字外形树的节点数量小于或者等于所述TCAM的表项数。
6.根据权利要求4所述的方法,其特征在于,所述对所述名字外形树进行深度收缩操作和节点数量缩减操作,包括:
当所述名字外形树的节点数量大于TCAM的表项数时,根据负荷最小深度最大优先原则确定所述名字外形树中待缩减节点;
将所述待缩减节点缩减至其前驱节点,以使所述名字外形树的节点数量小于或者等于所述TCAM的表项数。
7.根据权利要求1或2所述的方法,其特征在于,所述方法还包括:
当接收到插入指令和待插入的名字前缀时,获取所述待插入名字前缀的外形字串;
当根据所述待插入名字前缀的外形字串在所述TCAM表中获取第二目标外形字串时,在与所述第二目标外形字串对应的哈希表中插入所述待插入名字前缀;
其中,所述第二目标外形字串为在所述TCAM表中与所述待插入名字前缀的外形字串相匹配的外形字串中最长的外形字串。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为技术有限公司,未经华为技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711202737.1/1.html,转载请声明来源钻瓜专利网。