CN105791170A - 基于逻辑端口实现端口扩展的方法及装置 - Google Patents
基于逻辑端口实现端口扩展的方法及装置 Download PDFInfo
- Publication number
- CN105791170A CN105791170A CN201610128418.XA CN201610128418A CN105791170A CN 105791170 A CN105791170 A CN 105791170A CN 201610128418 A CN201610128418 A CN 201610128418A CN 105791170 A CN105791170 A CN 105791170A
- Authority
- CN
- China
- Prior art keywords
- port
- virtual
- mapping relations
- extended capabilities
- message
- 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.)
- Withdrawn
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/70—Virtual switches
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/30—Peripheral units, e.g. input or output ports
- H04L49/3045—Virtual queuing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/35—Switches specially adapted for specific applications
- H04L49/354—Switches specially adapted for specific applications for supporting virtual local area networks [VLAN]
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明揭示了一种基于逻辑端口实现端口扩展的方法,该方法基于一交换芯片,该交换芯片具有多个物理端口和多个逻辑端口,逻辑端口对应于虚拟机的虚拟端口,每个物理端口具有一逻辑端口基值和一扩展端口标识基值,根据物理端口的这两个基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。本发明还对应揭示了一种基于逻辑端口实现端口扩展的装置,包括交换芯片、虚拟机和映射关系定义模块。本发明通过交换芯片的逻辑端口实现与虚拟机的虚拟端口的对应,在芯片内部端口有限的情况下,极大的扩展了可以支持的最大虚拟端口数量。
Description
技术领域
本发明涉及一种虚拟端口扩展技术,尤其是涉及一种基于逻辑端口实现端口扩展的方法及装置。
背景技术
数据中心通常使用可用CPU、存储装置和存储器容量的小部分。这导致部署了比所需要的更多的服务器来执行指定量的工作。额外的服务器增加了成本,并且产生了可能难以管理的、更复杂且各异的环境。因此,随着数据中心技术的兴起,许多数据中心管理者正借助于虚拟化,以使得可跨越网络共享资源,而服务器中虚拟机的流量需要引入到交换机上才能进行管理。
思科提出了802.1BR协议的虚拟机(VM)接入技术来实现上述过程,在该技术中提出了两个主要思路:一是将网络相关内容虚拟到一个逻辑上的交换机(CB)来集中管理;二是给每个VM提供一个虚拟的交换接口,并通过PE(接口板)接入到CB来进行管理。
传统交换芯片一般通过芯片中现有端口来对应于扩展VM使用的虚拟交换接口,并实现出芯片内部端口和E-CID(802.1BR中定义E-channelidentifier)的映射关系。然而,传统交换机芯片由于内部端口资源受限,因此扩展出来的虚拟端口数目也有限。
发明内容
本发明的目的在于克服现有技术的缺陷,提供一种基于逻辑端口实现端口扩展的方法,通过将交换芯片的逻辑端口来对应扩展的虚拟端口,从而极大提高虚拟机端口扩展的数量。
为实现上述目的,本发明提出如下技术方案:一种基于逻辑端口实现端口扩展的方法,所述方法基于一交换芯片,所述交换芯片具有多个物理端口和多个逻辑端口,所述逻辑端口对应于虚拟机的虚拟端口,每个所述物理端口具有一逻辑端口基值和一扩展端口标识基值,所述方法包括:
根据物理端口的两个所述基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
优选地,所述映射关系为:
LogicPort=LogicPortBase+(ECID-ECIDbase),其中,LogicPort表示虚拟端口的逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECID表示虚拟端口的扩展端口标识,ECIDbase表示物理端口的扩展端口标识基值。
优选地,在交换机芯片的入方向上:
报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),其中,LogicSourcePort表示虚拟端口的源逻辑端口号,ECID为报文自身携带的扩展端口标识;
在交换机芯片的出方向上:
报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase,其中,LogicDestPort表示虚拟端口的目的逻辑端口号。
优选地,报文在两个虚拟端口间转发的过程包括:
报文从交换芯片的物理端口进入芯片内,根据其自身携带的虚拟端口的扩展端口标识及定义的所述映射关系,计算出虚拟端口的源逻辑端口号;
查找芯片内的转发表项,得到报文的目的逻辑端口号;
根据所述目的逻辑端口号及其对应的物理端口的逻辑端口基值和扩展端口标识基值,计算出报文在出方向上的扩展端口标识;
编辑报文,并将报文从目的逻辑端口号对应的物理端口发送出去。
优选地,所述编辑报文包括:将报文中出方向上的扩展端口标识编辑为计算出的扩展端口标识。
本发明还提出了另外一种技术方案:一种基于逻辑端口实现端口扩展的装置,包括交换芯片、虚拟机和映射关系定义模块,其中,
所述交换芯片具有多个物理端口和多个逻辑端口,所述逻辑端口对应于所述虚拟机的虚拟端口,每个所述物理端口具有一逻辑端口基值和一扩展端口标识基值;
所述映射关系定义模块用于根据物理端口的两个所述基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
优选地,所述映射关系定义模块包括入方向映射关系定义模块和出方向映射关系定义模块,其中,
所述入方向映射关系定义模块用于在交换机芯片的入方向上,定义扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系;
所述出方向映射关系定义模块用于在交换机芯片的出方向上,定义扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
优选地,所述入方向映射关系定义模块定义的映射关系为:
报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),其中,LogicSourcePort表示虚拟端口的源逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECID为报文自身携带的扩展端口标识,ECIDbase表示物理端口的扩展端口标识基值。
优选地,所述出方向映射关系定义模块定义的映射关系为:
报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase,其中,ECID表示虚拟端口的扩展端口标识,LogicDestPort表示虚拟端口的目的逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECIDbase表示物理端口的扩展端口标识基值。
本发明的有益效果是:本发明通过交换芯片的逻辑端口实现与虚拟机的虚拟端口的对应,在芯片内部端口有限的情况下,极大的扩展了可以支持的最大虚拟端口数量。
附图说明
图1是本发明实施例基于逻辑端口实现端口扩展的原理示意图;
图2是本发明实施例报文在虚拟机的两个虚拟端口间转发的流程示意图。
具体实施方式
下面将结合本发明的附图,对本发明实施例的技术方案进行清楚、完整的描述。
本发明所揭示的一种基于逻辑端口实现端口扩展的方法,利用交换芯片的逻辑端口来对应虚拟机的虚拟端口,并在交换芯片的物理端口上实现扩展端口标识(ECID)和逻辑端口的映射。
交换芯片具有多个物理端口和多个逻辑端口,物理端口即对应于对外的接口,本发明的逻辑端口则对应于虚拟机的虚拟端口,每个物理端口具有一逻辑端口基值(LogicPortBase)和一扩展端口标识基值(ECIDBase)。
基于物理端口的这两个基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系如下:
LogicPort=LogicPortBase+(ECID-ECIDbase),其中,LogicPort表示虚拟端口的逻辑端口号,ECID表示虚拟端口的扩展端口标识。
具体地,在交换机芯片的入方向上:
报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),其中,LogicSourcePort表示虚拟端口的源逻辑端口号,ECID为报文自身携带的扩展端口标识。
在交换机芯片的出方向上:
报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase,其中,LogicDestPort表示虚拟端口的目的逻辑端口号。
下面以一具体实施例来详细描述本发明的实现原理,以及报文在虚拟机的两个虚拟端口间转发的工作原理。
以二层报文的转发为例,如图1所示,交换芯片(CB)具有4个物理端口,其中物理端口1和物理端口4用来扩展虚拟端口,每个物理端口扩展出4个虚拟端口,物理端口1的逻辑端口基值和扩展端口标识基值均为1,物理端口4的逻辑端口基值为16,扩展端口标识基值均为5。
根据上述定义的映射关系,得到扩展出的虚拟端口的LogicPort和ECID之间的映射关系如下面表格所示:
当一个虚拟端口2进来一个报文转发到虚拟端口18的时候,如图2所示,过程如下:
1、带有扩展端口标识为2的报文从物理Port1进入到交换芯片,先根据报文的扩展端口标识=2,计算出logicPort为2。
2、然后查找转发表项,得出报文的出口为logicPort18.
3、LogicPort18对应的物理端口为Port4,获取到Port4上面的LogicPortBase16和ECIDbase5,计算出报文应该携带的扩展端口标识为7。
4、编辑报文中的扩展端口标识为7,并将编辑后的报文从物理Port4发送出去。
本发明还对应揭示了一种基于逻辑端口实现端口扩展的装置,包括交换芯片、虚拟机和映射关系定义模块,其中,交换芯片具有多个物理端口和多个逻辑端口,逻辑端口对应于虚拟机的虚拟端口,每个物理端口具有一逻辑端口基值和一扩展端口标识基值;映射关系定义模块用于根据物理端口的两个基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
具体地,映射关系定义模块包括入方向映射关系定义模块和出方向映射关系定义模块,入方向映射关系定义模块定义的映射关系为:报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),出方向映射关系定义模块定义的映射关系为:报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase。其中,本装置的实现原理及报文在虚拟机的两个虚拟端口间转发的工作原理可参见上述方法中的详细描述,这里便不再赘述。
本发明的技术内容及技术特征已揭示如上,然而熟悉本领域的技术人员仍可能基于本发明的教示及揭示而作种种不背离本发明精神的替换及修饰,因此,本发明保护范围应不限于实施例所揭示的内容,而应包括各种不背离本发明的替换及修饰,并为本专利申请权利要求所涵盖。
Claims (9)
1.一种基于逻辑端口实现端口扩展的方法,其特征在于,所述方法基于一交换芯片,所述交换芯片具有多个物理端口和多个逻辑端口,所述逻辑端口对应于虚拟机的虚拟端口,每个所述物理端口具有一逻辑端口基值和一扩展端口标识基值,所述方法包括:
根据物理端口的两个所述基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
2.根据权利要求1所述的方法,其特征在于,所述映射关系为:
LogicPort=LogicPortBase+(ECID-ECIDbase),其中,LogicPort表示虚拟端口的逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECID表示虚拟端口的扩展端口标识,ECIDbase表示物理端口的扩展端口标识基值。
3.根据权利要求2所述的方法,其特征在于,
在交换机芯片的入方向上:
报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),其中,LogicSourcePort表示虚拟端口的源逻辑端口号,ECID为报文自身携带的扩展端口标识;
在交换机芯片的出方向上:
报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase,其中,LogicDestPort表示虚拟端口的目的逻辑端口号。
4.根据权利要求3所述的方法,其特征在于,报文在两个虚拟端口间转发的过程包括:
报文从交换芯片的物理端口进入芯片内,根据其自身携带的虚拟端口的扩展端口标识及定义的所述映射关系,计算出虚拟端口的源逻辑端口号;
查找芯片内的转发表项,得到报文的目的逻辑端口号;
根据所述目的逻辑端口号及其对应的物理端口的逻辑端口基值和扩展端口标识基值,计算出报文在出方向上的扩展端口标识;
编辑报文,并将报文从目的逻辑端口号对应的物理端口发送出去。
5.根据权利要求4所述的方法,其特征在于,所述编辑报文包括:将报文中出方向上的扩展端口标识编辑为计算出的扩展端口标识。
6.一种基于逻辑端口实现端口扩展的装置,其特征在于,包括交换芯片、虚拟机和映射关系定义模块,其中,
所述交换芯片具有多个物理端口和多个逻辑端口,所述逻辑端口对应于所述虚拟机的虚拟端口,每个所述物理端口具有一逻辑端口基值和一扩展端口标识基值;
所述映射关系定义模块用于根据物理端口的两个所述基值,定义出扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
7.根据权利要求6所述的装置,其特征在于,所述映射关系定义模块包括入方向映射关系定义模块和出方向映射关系定义模块,其中,
所述入方向映射关系定义模块用于在交换机芯片的入方向上,定义扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系;
所述出方向映射关系定义模块用于在交换机芯片的出方向上,定义扩展出的虚拟端口的逻辑端口号和扩展端口标识之间的映射关系。
8.根据权利要求7所述的装置,其特征在于,所述入方向映射关系定义模块定义的映射关系为:
报文LogicSourcePort=LogicPortBase+(ECID-ECIDbase),其中,LogicSourcePort表示虚拟端口的源逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECID为报文自身携带的扩展端口标识,ECIDbase表示物理端口的扩展端口标识基值。
9.根据权利要求7所述的装置,其特征在于,所述出方向映射关系定义模块定义的映射关系为:
报文ECID=(LogicDestPort-LogicPortBase)+ECIDbase,其中,ECID表示虚拟端口的扩展端口标识,LogicDestPort表示虚拟端口的目的逻辑端口号,LogicPortBase表示物理端口的逻辑端口基值,ECIDbase表示物理端口的扩展端口标识基值。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610128418.XA CN105791170A (zh) | 2016-03-08 | 2016-03-08 | 基于逻辑端口实现端口扩展的方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610128418.XA CN105791170A (zh) | 2016-03-08 | 2016-03-08 | 基于逻辑端口实现端口扩展的方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN105791170A true CN105791170A (zh) | 2016-07-20 |
Family
ID=56387237
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610128418.XA Withdrawn CN105791170A (zh) | 2016-03-08 | 2016-03-08 | 基于逻辑端口实现端口扩展的方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN105791170A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107612783A (zh) * | 2017-10-18 | 2018-01-19 | 盛科网络(苏州)有限公司 | 包转发芯片中bpe的pe基于ecid的报文统计方法 |
CN107454021B (zh) * | 2017-07-13 | 2020-09-22 | 北京神州绿盟信息安全科技股份有限公司 | 一种通信方法及装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102316043A (zh) * | 2011-09-29 | 2012-01-11 | 中国联合网络通信集团有限公司 | 端口虚拟化方法、交换机及通信系统 |
CN102594649A (zh) * | 2011-01-07 | 2012-07-18 | 中兴通讯股份有限公司 | 虚拟通道组播数据远端复制方法及系统 |
CN102684892A (zh) * | 2011-03-14 | 2012-09-19 | 中兴通讯股份有限公司 | 一种端口扩展中实现源端口过滤的方法和装置 |
CN102769558A (zh) * | 2011-05-06 | 2012-11-07 | 中兴通讯股份有限公司 | 获知端口扩展拓扑信息的方法、系统和控制桥 |
US20130322457A1 (en) * | 2012-05-31 | 2013-12-05 | Broadcom Corporation | Multi-homing in an extended bridge |
CN104092595A (zh) * | 2014-07-21 | 2014-10-08 | 杭州华三通信技术有限公司 | 基于802.1br的虚拟化系统中的报文处理方法及装置 |
-
2016
- 2016-03-08 CN CN201610128418.XA patent/CN105791170A/zh not_active Withdrawn
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102594649A (zh) * | 2011-01-07 | 2012-07-18 | 中兴通讯股份有限公司 | 虚拟通道组播数据远端复制方法及系统 |
CN102684892A (zh) * | 2011-03-14 | 2012-09-19 | 中兴通讯股份有限公司 | 一种端口扩展中实现源端口过滤的方法和装置 |
CN102769558A (zh) * | 2011-05-06 | 2012-11-07 | 中兴通讯股份有限公司 | 获知端口扩展拓扑信息的方法、系统和控制桥 |
CN102316043A (zh) * | 2011-09-29 | 2012-01-11 | 中国联合网络通信集团有限公司 | 端口虚拟化方法、交换机及通信系统 |
US20130322457A1 (en) * | 2012-05-31 | 2013-12-05 | Broadcom Corporation | Multi-homing in an extended bridge |
CN104092595A (zh) * | 2014-07-21 | 2014-10-08 | 杭州华三通信技术有限公司 | 基于802.1br的虚拟化系统中的报文处理方法及装置 |
Non-Patent Citations (1)
Title |
---|
IEEE COMPUTER SOCIETY: "Virtual Bridged Local Area Networks—Bridge Port Extension", 《IEEE》 * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107454021B (zh) * | 2017-07-13 | 2020-09-22 | 北京神州绿盟信息安全科技股份有限公司 | 一种通信方法及装置 |
CN107612783A (zh) * | 2017-10-18 | 2018-01-19 | 盛科网络(苏州)有限公司 | 包转发芯片中bpe的pe基于ecid的报文统计方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10873521B2 (en) | Methods and apparatus for SDI support for fast startup | |
CN104350467B (zh) | 用于使用sdn的云安全性的弹性实行层 | |
JP2007519110A5 (zh) | ||
US20160337236A1 (en) | Data center network system based on software-defined network and packet forwarding method, address resolution method, routing controller thereof | |
US20100275199A1 (en) | Traffic forwarding for virtual machines | |
CN106936715A (zh) | 虚拟机报文控制方法及装置 | |
CN103560951A (zh) | 报文处理方法及物理转发设备 | |
CN103731377B (zh) | 处理报文的方法与设备 | |
JP6618610B2 (ja) | ルーティング管理 | |
US10164914B2 (en) | Network function virtualization (NFV) software-defined network (SDN) network-to-network interfaces (NNIs) | |
US20170026274A1 (en) | Method for processing packet in network, forwarding device, and packet processing system | |
CN108023761A (zh) | 分配资源的方法和设备 | |
CN108092923B (zh) | 基于sr-iov的报文处理方法以及装置 | |
CN105791170A (zh) | 基于逻辑端口实现端口扩展的方法及装置 | |
KR20130133249A (ko) | 물리적 정보에 기초한 가상 머신들의 할당을 위한 시스템 및 방법 | |
CN103354520A (zh) | 一种标签处理的方法及装置 | |
EP3399424B1 (en) | Using unified api to program both servers and fabric for forwarding for fine-grained network optimizations | |
US11025756B2 (en) | Network function virtualization (NFV) multi-protocol virtual probe control | |
CN111522772A (zh) | 一种业务板配置的方法及装置 | |
CN104205745B (zh) | 报文处理的方法与设备 | |
US10320645B2 (en) | System and method of using atomic flow counters in data center switching | |
EP3240251A1 (en) | Line card determination, determination processing method and device, and line card determination system | |
CN107493245B (zh) | 交换机的板卡以及数据流转发方法 | |
US20180205671A1 (en) | Method for Managing Traffic Item in Software-Defined Networking | |
CN111654559B (zh) | 一种容器数据传输方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
WW01 | Invention patent application withdrawn after publication | ||
WW01 | Invention patent application withdrawn after publication |
Application publication date: 20160720 |