CN113225201B - 一种信息同步方法及装置 - Google Patents
一种信息同步方法及装置 Download PDFInfo
- Publication number
- CN113225201B CN113225201B CN202110173643.6A CN202110173643A CN113225201B CN 113225201 B CN113225201 B CN 113225201B CN 202110173643 A CN202110173643 A CN 202110173643A CN 113225201 B CN113225201 B CN 113225201B
- Authority
- CN
- China
- Prior art keywords
- controller
- information
- network device
- tenure
- new
- 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.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/084—Configuration by using pre-existing information, e.g. using templates or copying from other elements
- H04L41/0846—Configuration by using pre-existing information, e.g. using templates or copying from other elements based on copy from other elements
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Telephonic Communication Services (AREA)
Abstract
本说明书提供一种信息同步方法及装置,所述方法包括:接收集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:所述第一网络设备的状态信息、管理第一网络设备的第一控制器的任期信息;接收第二控制器发送的第二同步消息,第二同步消息中包括:第一网络设备的状态信息、管理网络设备的第二控制器的任期信息;根据第一控制器和第二控制器的任期信息确定管理第一网络设备的新控制器;根据新控制器发送的同步消息记录第一网络设备的状态信息。根据任期信息可以解决管理网络设备的新、旧控制器向l eader控制器同步信息导致的网络设备的状态不一致的问题。
Description
技术领域
本说明书涉及通信技术领域,尤其涉及一种信息同步方法及装置。
背景技术
控制器集群为数据中心网络、公有云、私有云、校园边缘网络等提供了一个软件平台发挥其不同的网络特性。它提供了开放的软件平台,提供可编程的用户接口,使用OpenFlow、NETCONF(Network Configuration Protocol,网络配置协议)等南向接口协议,实现对物理网络的管理。
控制器集群中包括多个控制器,每个控制器由leader领导控制器确定其管理的网络设备,然而如果集群中的某一个控制器与其管理的网络设备之间的链路发生故障,那么会由新控制器会接管故障链路对应的控制器(老控制器)管理的网络设备,此时新、老控制器均会向集群中的其他控制器同步被管理的网络设备的状态,而此时新、旧控制器同步网络设备的状态时是并发的,因此对于其他控制器这一端在处理新、旧控制器同步的信息时,可能会存在同步消息的乱序,进而导致出现的同步问题。
发明内容
为克服相关技术中存在的问题,本说明书提供了一种信息同步方法及装置。
根据本说明书实施例的第一方面,提供一种信息同步方法,该方法可以应用于控制器集群中的任一控制器,所述方法包括:
接收集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:所述第一网络设备的状态信息、管理所述第一网络设备的第一控制器的任期信息;
接收第二控制器发送的第二同步消息,所述第二同步消息中包括:所述第一网络设备的状态信息、管理所述网络设备的第二控制器的任期信息;
根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器;
根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
可选的,根据所述第一控制器和第二控制器的任期信息确定管理所述所述第一网络设备的新控制器,包括:
获取所述第一控制器的任期信息与第二控制器的任期信息中最大值对应的控制器;
则,根据新控制器发送的同步消息记录所述第一网络设备的状态信息包括:
根据所述最大值对应的控制器发送的同步消息记录所述第一网络设备的状态信息。
可选的,所述方法还包括:
接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,所述选举报文中携带所述任一控制器管理的第三网络设备的标识以及所述任一控制器作为管理网络设备的master设备的任期信息。
根据本说明书实施例的第二方面,提供一种信息同步方法,该方法可以应用于控制器集群中的leader控制器,所述方法包括:
若检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则为所述第三网络设备选举新的控制器;
根据所述第三控制器的任期信息更新所述新的控制器的任期信息;
将所述新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
可选的,所述根据所述第三控制器的任期信息更新所述新的控制器的任期信息,包括:
将所述第三控制器的任期信息加一更新作为新的控制器的任期信息。
根据本说明书实施例的第三方面,提供一种信息同步装置,该装置包括:接收模块、确定模块、记录模块;
接收模块,用于接收控制器集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:所述第一网络设备的状态信息、管理所述第一网络设备的第一控制器的任期信息;
所述接收模块还用于接收第二控制器发送的第二同步消息,所述第二同步消息中包括:所述第一网络设备的状态信息、管理所述网络设备的第二控制器的任期信息;
确定模块,用于根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器;
记录模块,用于根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
可选的,所述确定模块具体用于获取所述第一控制器的任期信息与第二控制器的任期信息中最大值对应的控制器;
相应的,所述记录模块用于根据所述最大值对应的控制器发送的同步消息记录所述第一网络设备的状态信息。
可选的,所述接收模块用于接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,所述选举报文中携带所述任一控制器管理的第三网络设备的标识以及所述任一控制器作为管理网络设备的master设备的任期信息。
根据本说明书实施例的第四方面,提供了一种信息同步装置,该装置包括:检测模块、选举模块、任期更新模块、发送模块;
所述检测模块用于若检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则选举模块为所述第三网络设备选举新的控制器;
任期更新模块用于根据所述第三控制器的任期信息更新所述新的控制器的任期信息;
所述发送模块用于将所述新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
可选的,所述任期更新模块具体用于将所述第三控制器的任期信息加一更新作为新的控制器的任期信息。
本说明书的实施例提供的技术方案可以包括以下有益效果:本申请中引入“任期”的概念,用来标识Master设备的有效期限。从而控制器集群中的控制器在接收到其他控制器的同步消息时,可以根据同步消息中携带的任期信息对新、旧控制器发送的同步消息进行区分,根据新控制器的同步消息记录网络设备的状态,从而可以避免对网络设备状态同步不准的问题。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本说明书。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本说明书的实施例,并与说明书一起用于解释本说明书的原理。
图1是本申请实施例提供的网络架构示意图;
图2是本申请实施例提供的信息同步方法的流程示意图;
图3是本申请另一实施例提供的信息同步方法的流程示意图;
图4是本申请一实施例提供的信息同步装置的结构示意图;
图5是本申请另一实施例提供的信息同步装置的结构示意图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本说明书相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本说明书的一些方面相一致的装置和方法的例子。
为了对本实施例提供的方法进行更好的说明,本实施例先对本申请中可能设计到的概念进行说明。
对于控制器集群可以由多个控制器组成,多个控制器中会有一个控制器作为领导者,对控制器集群中的其他控制器进行管理,例如进行网络设备的控制器的选举等。该领导者,在本申请中称为leader控制器;控制器集群中的其他的控制器称为Follower跟随控制器。
对于控制器集群管理的多个网络设备而言,可能网络设备1~100由控制器集群中的控制器1进行管理,网络设备201~300又控制器集群中的控制器2进行管理。从管理网络设备的角度,集群中管理网络设备的控制器称为网络设备的master设备。例如对于网络设备1~100而言,控制器1才是网络设备1~100的master主设备。本实施例中对于网络设备的类型并不加以限定,可以为路由器、交换机、服务器、摄像头等。
图1示出了一种控制器集群的组网架构示意图,如图1所示,控制器集群由控制器1、控制器2、控制器3这三个控制器控制器组成,其中控制器1是Leader领导控制器,控制器2、控制器3是Follower跟随控制器。
控制器集群支持负载均衡技术。对于不同的网络设备,Leader控制器根据特定规则,从集群中选择一个控制器对网络设备进行管理,本文称这个被选择的控制器为设备Master控制器。在图1中,以Leader控制器选择控制器1是DeviceA的Master主控制器,控制器3是DeviceB的Master控制器为例。
若DeviceB与控制器3网络通信出现故障,或者由于其他原因导致DeviceB与控制器3之间的设备连接出现故障。在这种情形下,Leader控制器需要为DeviceB重新选择Master控制器,若leader控制器为DeviceB重新确定的新Master控制器为控制器2,则控制器2会取代控制器3,对DeviceB进行管理。
在控制器2纳管DeviceB之后,会与DeviceB进行配置平滑等操作。
在DeviceB的Master控制器发生变化之前,控制器3是DeviceB的Master控制器。在DeviceB与控制器3进行配置平滑的过程中,控制器3向控制器1、控制器2实时发送同步消息,在集群范围内同步DeviceB的平滑进度。在DeviceB与控制器之间后,在集群中的所有控制器上,DeviceB的平滑进度均为100%。
当DeviceB与控制器3之间的设备连接出现故障后,DeviceB的Master控制器将由控制器3切换为控制器2,并重新进行配置平滑。
在这种情形下,控制器1可能同时收到如下两个同步消息:
由控制器3(老Master控制器)发送的同步消息,用来清空DeviceB的平滑进度,即将DeviceB的平滑进度更新为0;
由控制器2(新Master控制器)发送的同步消息,用来实时同步DeviceB的平滑进度,假设此时同步的DeviceB平滑进度为5%。
由于这两个同步消息是并发关系,控制器1在处理它们时可能会有如下两种情形。
第一种情形是:先处理老Master控制器发送的同步消息,再处理新Master控制器发送的同步消息:DeviceB的平滑进度变化过程为0->5%;
当新Master发送的下一个同步消息(假设同步DeviceB的平滑进度为10%)到来时,DeviceB的平滑进度变化过程为0->5%->10%,符合预期。
第二种情形是:先处理新Master控制器发送的同步消息,再处理老Master控制器发送的同步消息:DeviceB的平滑进度变化过程为5%->0;
当新Master发送的下一个同步消息(假设同步DeviceB的平滑进度为10%)到来时,DeviceB的平滑进度变化过程为5%->0–>10%,不符合预期。
综上所述,当控制器1按照第二种情形的方式,处理老Master、新Master发送的同步消息时,DeviceB的平滑进度变化不符合预期,导致出现同步问题。
为了解决上述问题,本申请中引入“任期”的概念,用来标识Master设备的有效期限。从而控制器集群中的控制器在接收到其他控制器的同步消息时,可以根据同步消息中携带的任期信息对新、旧控制器发送的同步消息进行区分,根据新控制器的同步消息记录网络设备的状态,从而可以避免对网络设备状态同步不准的问题。
实施例一
图2提供了一种信息同步方法的流程示意图,该流程示意图中示出了一种信息同步方法,该方法可以应用于控制器集群中的任一控制器。为了更好的描述本实施例提供的信息同步方法,本实施例以图1所示的网络架构为例,对该方法进行说明。具体的,以图1中的Device B为第一网络设备、第一控制器为控制器3、第二控制器为控制器2、Leader控制器为控制器1为例进行说明。其中,本实施中的任一控制器以控制器1为例,但应当理解的是,这里的任一控制器并不限于leader控制器。
如图1和图2所示,该信息同步方法具体包括:
步骤201,接收集群中控制器3发送的第一同步消息,第一同步消息中包括:第一网络设备Device B的状态信息、管理第一网络设备Device B的控制器3的任期信息。
控制器集群中的控制器在向集群中的其他控制器同步消息时,可以在同步消息中携带其管理的网络设备的任期消息,本实施例以控制器3的任期为Y为例进行说明。同步消息中还可以携带控制器管理的网络设备的状态信息,其中状态信息可以是第一网络设备Device B与控制器3之间进行配置平滑的进度、也可以是第一网络设备Device B的端口状态等等其他的设备状态。
在一种可选的实施方式中,同步消息中还可以包括网络设备的标识信息、网络设备的状态信息、管理该网络设备的控制器的标识、以及管理该网络设备的控制器的任期信息。
应当理解的,对于同步消息而言包括网络设备的标识以及管理该网络设备的任期信息是必要的,其余的信息只是可选的。
本实施例中对于状态信息的内容并不加以限定,为了便于理解本申请提供的信息同步方法,本实施例中以状态信息为控制器与其管理的网络设备之间配置平滑的进度为例进行说明。
应当理解的是,本申请中的第一网络设备指的是控制器管理的网络设备,其数量可以是一个,也可以是多个,只不过本实施例中仅仅以其中的一个deviceB为例进行介绍,因此不应当将以deviceB为例理解为是对第一网络设备数量的限制。
第一网络设备Device B如果与集群中负责管理第一网络设备Device B的控制器(又称为Device B的Master主设备)之间发生链路故障,则控制器集群中的leader控制器会为第一网络设备Device B重新选举Master主设备,本申请中对于重新选举的master主设备称为新控制器,原来管理第一网络设备Device B的控制器称为旧控制器。以控制器与其管理的网络设备的配置平滑进度为例,新控制器与旧控制器都会向控制器集群中的其他控制器发送其与网络设备之间配置平滑的进度。
因此可能集群中的控制器可能会接收到两个控制器发送的关于第一网络设备的同步消息。具体的,控制器在接收步骤201中的同步消息时,还可能如步骤203,接收到其他控制器发送的同步消息。
步骤203,接收控制器2发送的第二同步消息,所述第二同步消息中包括:第一网络设备Device B的状态信息、管理第一网络设备Device B的控制器2的任期信息。
本实施例以第二同步消息中携带的任期消息为Y+1为例进行说明。
步骤205,根据控制器3和控制器2的任期信息确定管理第一网络设备的新控制器。
步骤207,根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
控制器1根据控制器3的任期信息Y和控制器2携带的任期信息为Y+1可以判断,控制器2是在控制器3之后成为管理Device B的master设备的,即控制器2为管理第一网络设备Device B的新控制器。
针对步骤205的一种具体实施方式可以为:获取控制器3的任期信息与控制器2的任期信息中最大值对应的控制器。相应的,步骤207的一种具体实现方式为:控制器1最大值对应的控制器,即控制器2发送的同步消息记录第一网络设备Device B的状态信息。
当然,在另一种实现方式中,该任期信息可以为在先成为第一网络设备Device B的控制器的任期为Y,在后成为第一网络设备Device B的控制器的任期在Y的基础上减一。则任期值较小的控制器为网络设备对应的新的master设备。
还有一种可以实现的方式中,任期信息可以为leader控制器选举集群中的控制器成为网络设备的master设备的时间信息。相应的,可以根据时间信息确定出管理网络设备的新控制器。
实施例二
本实施例对于任期信息如何在集群中的控制器中进行同步进行说明。本实施例提供的方法中,是以集群中的leader控制器首先更新控制器的任期信息为例进行说明。图3示出了本实施例提供的信息同步方法的流程示意图,本实施例以第三控制器为控制器3、第三网络设备为Device B为例进行说明。如图1和图3所示,本实施例提供的信息同步方法包括:
步骤301,若leader控制器1检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则为所述第三网络设备选举新的控制器。
当控制器1检测到集群中原本管理Device B的控制器3和Device B之间的通信断开时,则为Device B选举新的master设备。
具体的,leader控制器1如何检测到Device B的控制器3之间的通信断开以及如何选举新的master设备本申请中不加以限定,可以采用现有技术中的方式。
步骤303,根据所述第三控制器的任期信息更新所述新的控制器的任期信息。
由于leader控制器中保存有集群中所有控制器针对任一网络设备的任期信息,因此leader控制器1可以根据控制器3针对Device B的任期信息更新控制器3针对Device B的任期信息。
具体的任期信息的更新可以采用实施例一中的方式进行更新,本实施例中不再详细赘述。
步骤305,将新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
Leader控制器1将新的控制器针对Device B的任期信息以及Device B的标识同步给控制器集群中的其他控制器。
由此,控制器集群中的所有控制器都可以获取到当前管理Device B的控制器的信息以及该控制器针对Device B的任期信息。
实施例三
与实施例二相对应的,在实施例一的基础上,实施例一中的任一控制器可以执行如下步骤:
步骤209,接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,选举报文中携带所述任一控制器管理的第三网络设备的标识以及任一控制器作为管理网络设备的master设备的任期信息。
在leader控制器更新了管理第三网络设备Device B的任期信息之后,会将上述任期信息同步至集群中的其他控制器,具体的可以将任期信息携带在选举报文中,选举报文中为leader控制器用于为网络设备新选举的master控制器,并向集群中同步选举结果的报文,选举报文可以采用不同的私有协议实现。
选举报文中可以携带网络设备的标识、为该网络设备选举的master设备的标识、以及该master设备的任期信息。
此外,步骤209可以在实施例一提供的方法的步骤201之前执行,也可以在实施一提供的步骤201之后执行,对于步骤209与实施例一各步骤之间的执行顺序并不加以限定。
实施例四
为了对本申请提供的信息同步方法加以说明。本实施例提供一种更为具体的实施方式对该方法进行说明。以图1所示的网络架构为例,如图1所示:
当DeviceB与控制器3出现通信故障时,DeviceB的Master节点将发生切换。假设Leader节点控制器1为DeviceB选择的新Master节点为控制器2,控制器2的任期将由Y增长为Y+1,然后DeviceB将与控制器2之间重新进行配置平滑。
在这种情形下,控制器1可能同时收到如下两个同步消息,同步信息中包括网络设备的标识、管理该网络设备的控制器的标识,即管理该网络设备的master设备的标识、该master设备的任期信息、配置平滑的进度信息,具体的可以如下所示:
{DeviceB,控制器3,Y,0}:由老Master节点控制器3发送的同步消息,用来清空DeviceB的配置平滑进度,将其更新为0;
{DeviceB,控制器2,Y+1,5%}:由新Master节点控制器2发送的同步消息,用来实时同步DeviceB的配置平滑进度,将其更新为5%。
这两个同步消息是并发关系,控制器1在处理它们时,会出现如下两种处理方式:
一种可能的处理顺序是:先处理{DeviceB,控制器3,Y,0},即先处理老Master节点发送的同步消息,将DeviceB的配置平滑进度更新为0,刷新DeviceB的最新任期为Y;
然后,处理{DeviceB,控制器2,Y+1,5%},这两个消息均为DeviceB的同步消息,比较它们的任期。由于{DeviceB,控制器2,Y+1,5%}的任期Y+1不小于最新任期Y,所以它是有效的同步消息,对其进行处理,将DeviceB的配置平滑进度更新为5%,刷新DeviceB的最新任期为Y+1;
在这种处理方式下,DeviceB的配置平滑进度变化过程为0->5%。
当新Master控制器2发送的下一个同步消息,假设该同步消息为{DeviceB,控制器2,Y+1,10%}到来时,由于它的任期Y+1不小于最新任期Y+1,所以它是有效的同步消息,按照相同方式处理。DeviceB的配置平滑进度变化过程为0->5%->10%,符合预期。
另一种可能的处理顺序是:先处理{DeviceB,控制器2,Y+1,5%},即先处理新Master节点发送的同步消息,将DeviceB的配置平滑进度更新为5%,刷新DeviceB的最新任期为Y+1;
然后,处理{DeviceB,控制器3,Y,0},这两个消息均为DeviceB的同步消息,比较它们的任期,由于{DeviceB,控制器3,Y,0}的任期Y小于最新任期Y+1,所以它是无效的同步消息,由已失效的老Master节点所发送,因此直接丢弃这个同步消息。
在这种处理方式下,DeviceB的配置平滑进度变化过程为5%。
当新Master控制器2发送的下一个同步消息,假设为{DeviceB,控制器2,Y+1,10%})到来时,由于它的任期Y+1不小于最新任期Y+1,所以它是有效的同步消息,按照相同方式处理。DeviceB的配置平滑进度变化过程为5%->10%,符合预期。
综上所述,按照本申请提出的技术方案,对老Master节点、新Master节点发送的同步消息(两者为并发关系)进行处理时,可以解决在前文中所述的同步问题。
实施例五
本实施例还提供一种信息同步装置,该信息同步装置可以用于执行上述实施例中控制器集群中任一控制器所执行的方法,图4为本申请一实施例提供的信息同步装置的结构示意图,如图4所示,该信息同步装置可以包括:接收模块501、确定模块502、记录模块503;
接收模块501,用于接收控制器集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:所述第一网络设备的状态信息、管理所述第一网络设备的第一控制器的任期信息;
所述接收模块501还用于接收第二控制器发送的第二同步消息,所述第二同步消息中包括:所述第一网络设备的状态信息、管理所述网络设备的第二控制器的任期信息;
确定模块502,用于根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器;
记录模块503,用于根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
在一种可选的实施方式中,确定模块502具体用于获取所述第一控制器的任期信息与第二控制器的任期信息中最大值对应的控制器;
相应的,记录模块503用于根据所述最大值对应的控制器发送的同步消息记录所述第一网络设备的状态信息。
可选的,接收模块501用于接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,所述选举报文中携带所述任一控制器管理的第三网络设备的标识以及所述任一控制器作为管理网络设备的master设备的任期信息。
本实施例信息同步装置执行的各个步骤可以参照实施例一~四种任一控制器所执行的方法,本实施例中不再详细赘述。
本实施例还提供另一种信息同步装置,该信息同步装置可以用于执行集群控制器中的leader控制器执行的方法,图5示出了一种信息同步装置的结构示意图,如图5所示,该装置包括:检测模块601、选举模块602、任期更新模块603、发送模块604;
检测模块601用于若检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则选举模块602为所述第三网络设备选举新的控制器;
任期更新模块603用于根据所述第三控制器的任期信息更新所述新的控制器的任期信息;
发送模块604用于将所述新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
可选的,任期更新模块603具体用于将所述第三控制器的任期信息加一更新作为新的控制器的任期信息。
本实施例提供的装置,对于管理网络设备的老控制器、新控制器发送的同步消息(两者为并发关系)进行处理时,可以解决在前文中所述的同步问题。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行计算机程序指令时,全部或部分地产生按照本申请的流程或功能。计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输。
在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包括于本申请的至少一个实施例或示例中。而且,描述的具体特征、结构、材料或者特点可以在任一个或多个实施例或示例中以合适的方式结合。此外,在不相互矛盾的情况下,本领域的技术人员可以将本说明书中描述的不同实施例或示例以及不同实施例或示例的特征进行结合和组合。
此外,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或隐含地包括至少一个该特征。在本申请的描述中,“多个”的含义是两个或两个以上,除非另有明确具体的限定。
流程图中或在此以其他方式描述的任何过程或方法描述可以被理解为,表示包括一个或更多个用于实现特定逻辑功能或过程的步骤的可执行指令的代码的模块、片段或部分。并且本申请的优选实施方式的范围包括另外的实现,其中可以不按所示出或讨论的顺序,包括根据所涉及的功能按基本同时的方式或按相反的顺序,来执行功能。
在流程图中表示或在此以其他方式描述的逻辑和/或步骤,例如,可以被认为是用于实现逻辑功能的可执行指令的定序列表,可以具体实现在任何计算机可读介质中,以供指令执行系统、装置或设备(如基于计算机的系统、包括处理器的系统或其他可以从指令执行系统、装置或设备取指令并执行指令的系统)使用,或结合这些指令执行系统、装置或设备而使用。
应理解的是,本申请的各部分可以用硬件、软件、固件或它们的组合来实现。在上述实施方式中,多个步骤或方法可以用存储在存储器中且由合适的指令执行系统执行的软件或固件来实现。上述实施例方法的全部或部分步骤是可以通过程序来指令相关的硬件完成,该程序可以存储于一种计算机可读存储介质中,该程序在执行时,包括方法实施例的步骤之一或其组合。
此外,在本申请各个实施例中的各功能单元可以集成在一个处理模块中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。上述集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,也可以存储在一个计算机可读存储介质中。该存储介质可以是只读存储器,磁盘或光盘等。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到其各种变化或替换,这些都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以权利要求的保护范围为准。
Claims (10)
1.一种信息同步方法,应用于控制器集群中的任一控制器,其特征在于,包括:
接收集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:第一网络设备的状态信息、管理所述第一网络设备的第一控制器的任期信息;
接收第二控制器发送的第二同步消息,所述第二同步消息中包括:所述第一网络设备的状态信息、管理所述网络设备的第二控制器的任期信息;
根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器;
根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
2.根据权利要求1所述的方法,其特征在于,根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器,包括:
获取所述第一控制器的任期信息与第二控制器的任期信息中最大值对应的控制器;
则,根据新控制器发送的同步消息记录所述第一网络设备的状态信息包括:
根据所述最大值对应的控制器发送的同步消息记录所述第一网络设备的状态信息。
3.根据权利要求1所述的方法,其特征在于,还包括:
接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,所述选举报文中携带所述任一控制器管理的第三网络设备的标识以及所述任一控制器作为管理网络设备的master设备的任期信息。
4.一种信息同步方法,应用于控制器集群中的leader控制器,其特征在于,所述方法包括:
若检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则为所述第三网络设备选举新的控制器;
根据所述第三控制器的任期信息更新所述新的控制器的任期信息;
将所述新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
5.根据权利要求4所述的方法,其特征在于,所述根据所述第三控制器的任期信息更新所述新的控制器的任期信息,包括:
将所述第三控制器的任期信息加一更新作为新的控制器的任期信息。
6.一种信息同步装置,其特征在于,包括:接收模块、确定模块、记录模块;
接收模块,用于接收控制器集群中第一控制器发送的第一同步消息,所述第一同步消息中包括:第一网络设备的状态信息、管理所述第一网络设备的第一控制器的任期信息;
所述接收模块还用于接收第二控制器发送的第二同步消息,所述第二同步消息中包括:所述第一网络设备的状态信息、管理所述网络设备的第二控制器的任期信息;
确定模块,用于根据所述第一控制器和第二控制器的任期信息确定管理所述第一网络设备的新控制器;
记录模块,用于根据新控制器发送的同步消息记录所述第一网络设备的状态信息。
7.根据权利要求6所述的装置,其特征在于,所述确定模块具体用于获取所述第一控制器的任期信息与第二控制器的任期信息中最大值对应的控制器;
相应的,所述记录模块用于根据所述最大值对应的控制器发送的同步消息记录所述第一网络设备的状态信息。
8.根据权利要求6所述的装置,其特征在于,所述接收模块用于接收集群中的leader控制器发送的被选举为第三网络设备的新控制器的选举报文,所述选举报文中携带任一控制器管理的第三网络设备的标识以及所述任一控制器作为管理网络设备的master设备的任期信息。
9.一种信息同步装置,其特征在于,所述装置包括:检测模块、选举模块、任期更新模块、发送模块;
所述检测模块用于若检测到集群中的第三控制器与所述第三控制器管理的第三网络设备之间的通信断开,则选举模块为所述第三网络设备选举新的控制器;
任期更新模块用于根据所述第三控制器的任期信息更新所述新的控制器的任期信息;
所述发送模块用于将所述新的控制器的任期信息以及所述的第三网络设备的信息同步给控制器集群中的其他控制器。
10.根据权利要求9所述的装置,其特征在于,所述任期更新模块具体用于将所述第三控制器的任期信息加一更新作为新的控制器的任期信息。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110173643.6A CN113225201B (zh) | 2021-02-05 | 2021-02-05 | 一种信息同步方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110173643.6A CN113225201B (zh) | 2021-02-05 | 2021-02-05 | 一种信息同步方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113225201A CN113225201A (zh) | 2021-08-06 |
CN113225201B true CN113225201B (zh) | 2022-05-24 |
Family
ID=77084670
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110173643.6A Active CN113225201B (zh) | 2021-02-05 | 2021-02-05 | 一种信息同步方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113225201B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104468201A (zh) * | 2014-11-26 | 2015-03-25 | 杭州华三通信技术有限公司 | 一种网络设备离线的自动删除方法和设备 |
CN104821923A (zh) * | 2015-05-15 | 2015-08-05 | 杭州华三通信技术有限公司 | Sdn网络中发送上送控制器协议报文的方法和装置 |
CN108462657A (zh) * | 2016-12-09 | 2018-08-28 | 诺基亚技术有限公司 | 获取不同运营商的sdn网络的资源及信息的方法和设备 |
CN108881059A (zh) * | 2018-05-29 | 2018-11-23 | 新华三技术有限公司 | 控制器角色确定方法、网络交换设备、控制器及网络系统 |
WO2021020935A1 (ko) * | 2019-07-31 | 2021-02-04 | 현대자동차주식회사 | 차량 내부 네트워크에 대한 sdn 기반의 침입 대응 방법 및 이를 이용한 시스템 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7664116B2 (en) * | 2005-04-12 | 2010-02-16 | Fujitsu Limited | Network based routing scheme |
-
2021
- 2021-02-05 CN CN202110173643.6A patent/CN113225201B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104468201A (zh) * | 2014-11-26 | 2015-03-25 | 杭州华三通信技术有限公司 | 一种网络设备离线的自动删除方法和设备 |
CN104821923A (zh) * | 2015-05-15 | 2015-08-05 | 杭州华三通信技术有限公司 | Sdn网络中发送上送控制器协议报文的方法和装置 |
CN108462657A (zh) * | 2016-12-09 | 2018-08-28 | 诺基亚技术有限公司 | 获取不同运营商的sdn网络的资源及信息的方法和设备 |
CN108881059A (zh) * | 2018-05-29 | 2018-11-23 | 新华三技术有限公司 | 控制器角色确定方法、网络交换设备、控制器及网络系统 |
WO2021020935A1 (ko) * | 2019-07-31 | 2021-02-04 | 현대자동차주식회사 | 차량 내부 네트워크에 대한 sdn 기반의 침입 대응 방법 및 이를 이용한 시스템 |
Non-Patent Citations (1)
Title |
---|
SDN中基于迁移优化的控制器负载均衡策略;胡涛等;《计算机应用研究》;20170315(第02期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN113225201A (zh) | 2021-08-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109729111B (zh) | 用于管理分布式系统的方法、设备和计算机程序产品 | |
CN103460203B (zh) | 群集唯一标识符 | |
CN112003961B (zh) | 一种kubernetes中资源暴露方法、系统、设备以及介质 | |
US7460527B2 (en) | Port aggregation for fibre channel interfaces | |
WO2019119212A1 (zh) | 识别osd亚健康的方法、装置和数据存储系统 | |
CN109005045B (zh) | 主备服务系统及主节点故障恢复方法 | |
US20150365320A1 (en) | Method and device for dynamically switching gateway of distributed resilient network interconnect | |
US20160330071A1 (en) | Network-based ip configuration recovery | |
CN108319617A (zh) | 确定数据库主从差异的方法、装置及切换控制方法、装置 | |
CN113810216B (zh) | 一种集群的故障切换方法、装置及电子设备 | |
CN104767794A (zh) | 一种分布式系统中的节点选举方法及节点 | |
CN106230622B (zh) | 一种集群实现方法及装置 | |
TW201824030A (zh) | 主備資料庫的管理方法、系統及其設備 | |
US20060059325A1 (en) | Apparatus and method for assigning addresses to components or modules in a system | |
CN109088830B (zh) | 一种端口状态同步方法及装置 | |
CN111966466A (zh) | 一种容器管理方法、设备以及介质 | |
CN111147312A (zh) | 资源配置的管理方法及装置、资源配置缓存的管理方法及装置、配置管理系统 | |
CN113225201B (zh) | 一种信息同步方法及装置 | |
CN108509296B (zh) | 一种处理设备故障的方法和系统 | |
CN116346582A (zh) | 一种实现主备双网冗余方法、装置、设备及存储介质 | |
CN106789304B (zh) | 网络设备配置同步方法和装置 | |
CN114124803B (zh) | 设备管理方法、装置、电子设备及存储介质 | |
CN116260827A (zh) | 一种集群中领导者的选举方法、选举系统及相关装置 | |
CN110351122A (zh) | 容灾方法、装置、系统与电子设备 | |
CN112988882B (zh) | 数据的异地灾备系统、方法及装置、计算设备 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |