CN111865683A - 虚拟网关版本灰度发布方法、装置、设备以及存储介质 - Google Patents

虚拟网关版本灰度发布方法、装置、设备以及存储介质 Download PDF

Info

Publication number
CN111865683A
CN111865683A CN202010690949.4A CN202010690949A CN111865683A CN 111865683 A CN111865683 A CN 111865683A CN 202010690949 A CN202010690949 A CN 202010690949A CN 111865683 A CN111865683 A CN 111865683A
Authority
CN
China
Prior art keywords
cluster
virtual gateway
concurrent
gray level
list
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.)
Granted
Application number
CN202010690949.4A
Other languages
English (en)
Other versions
CN111865683B (zh
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.)
Beijing Baidu Netcom Science and Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and Technology 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 Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN202010690949.4A priority Critical patent/CN111865683B/zh
Publication of CN111865683A publication Critical patent/CN111865683A/zh
Application granted granted Critical
Publication of CN111865683B publication Critical patent/CN111865683B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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
    • H04L41/0813Configuration setting characterised by the conditions triggering a change of settings
    • H04L41/082Configuration setting characterised by the conditions triggering a change of settings the condition being updates or upgrades of network functionality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • 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/0889Techniques to speed-up the configuration process
    • 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/0893Assignment of logical groups to network elements

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本申请公开了虚拟网关版本灰度发布方法、装置、设备以及存储介质,涉及云计算、灰度发布技术领域。该方法的一具体实施方式包括:基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表;基于集群与设备分级列表,生成并发发布列表序列;对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。该实施方式能够平滑地、快速地、不重不漏地将虚拟网关版本发布到所有区域的所有网关设备上。

Description

虚拟网关版本灰度发布方法、装置、设备以及存储介质
技术领域
本申请实施例涉及计算机技术领域,具体涉及云计算、灰度发布技术领域,尤其涉及虚拟网关版本灰度发布方法、装置、设备以及存储介质。
背景技术
在大规模云服务中,虚拟网关集群是虚拟网络中重要的转发设备,承载着云主机的绝大部分场景的流量。虚拟网关集群上运行的软件由于功能迭代或者缺陷(Bug)修复等需求,需要频繁的进行版本升级。在云服务中,往往会存在多个区域(Region),每个区域又会有多个可用区(Availability Zone,AZ),每个可用区都有各自的虚拟网关集群,每个虚拟网关集群中存在多台网关设备。软件的新版本发布时需要发布到所有区域的所有网关设备上,可能涉及到上百台网关设备。这就需要从旧版本平滑地过渡到新版本,使用户对整个发布过程无感,也即灰度发布。
然而,如果灰度不够,可能会造成多个区域的多个可用区的虚拟网关集群中全部或部分网关设备发生故障,进而影响到云上用户的业务;如果灰度过多,又会影响软件版本的迭代速度,影响业务的快速上线。
发明内容
本申请实施例提出了虚拟网关版本灰度发布方法、装置、设备以及存储介质。
第一方面,本申请实施例提出了一种虚拟网关版本灰度发布方法,包括:基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表;基于集群与设备分级列表,生成并发发布列表序列;对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。
第二方面,本申请实施例提出了一种虚拟网关版本灰度发布装置,包括:集群间优先级确定模块,被配置成基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;集群内优先级确定模块,被配置成基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;分级列表生成模块,被配置成基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表;并发发布列表生成模块,被配置成基于集群与设备分级列表,生成并发发布列表序列;并发发布模块,被配置成对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。
第三方面,本申请实施例提出了一种电子设备,包括:至少一个处理器;以及与至少一个处理器通信连接的存储器;其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行如第一方面中任一实现方式描述的方法。
第四方面,本申请实施例提出了一种存储有计算机指令的非瞬时计算机可读存储介质,计算机指令用于使计算机执行如第一方面中任一实现方式描述的方法。
本申请实施例提供的虚拟网关版本灰度发布方法、装置、设备以及存储介质,首先考虑不同虚拟网关集群和不同网关设备的差异,确定集群间灰度优先级和集群内灰度优先级;然后基于集群间灰度优先级和集群内灰度优先级,生成并发发布列表序列;最后对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。提供了一种自动灰度方式,考虑不同虚拟网关集群和不同网关设备的差异,输出合理的并发发布列表序列,能够平滑地、快速地、不重不漏地将虚拟网关版本发布到所有区域的所有网关设备上。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显。附图用于更好地理解本方案,不构成对本申请的限定。其中:
图1是本申请可以应用于其中的示例性系统架构;
图2是根据本申请的虚拟网关版本灰度发布方法的一个实施例的流程图;
图3是根据本申请的虚拟网关版本灰度发布方法的又一个实施例的流程图;
图4是根据本申请的虚拟网关版本灰度发布装置的一个实施例的结构示意图;
图5是用来实现本申请实施例的虚拟网关版本灰度发布方法的电子设备的框图。
具体实施方式
以下结合附图对本申请的示范性实施例做出说明,其中包括本申请实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本申请的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的虚拟网关版本灰度发布方法或虚拟网关版本灰度发布装置的实施例的示例性系统架构100。
如图1所示,系统架构100中可以包括虚拟网关集群101、102,网络103和服务器104。其中,虚拟网关集群101、102可以分布在不同的区域。虚拟网关集群101可以包括网关设备1011、1012、1013、1014。虚拟网关集群102可以包括网关设备1021、1022、1023、1024。网络103用以在虚拟网关集群101、102和服务器104之间提供通信链路的介质。网络103可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
服务器104可以是提供各种服务的服务器,例如发布虚拟网关版本的后台服务器。后台服务器可以基于不用虚拟网关集群和不同网关设备的差异,将虚拟网关版本发布到虚拟网关集群101、102中的所有网关设备上。
服务器104可以是硬件,也可以是软件。当服务器104为硬件时,可以实现成多个服务器组成的分布式服务器集群,也可以实现成单个服务器。当服务器104为软件时,可以实现成多个软件或软件模块(例如用来提供分布式服务),也可以实现成单个软件或软件模块。在此不做具体限定。
需要说明的是,本申请实施例所提供的虚拟网关版本灰度发布方法一般服务器104执行,相应地,虚拟网关版本灰度发布装置一般设置于服务器104中。
应该理解,图1中的虚拟网关集群、网关设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的虚拟网关集群、网关设备、网络和服务器。
继续参考图2,其示出了根据本申请的虚拟网关版本灰度发布方法的一个实施例的流程200。该虚拟网关版本灰度发布方法包括以下步骤:
步骤201,基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级。
在本实施例中,虚拟网关版本灰度发布方法的执行主体(例如图1所示的服务器103)可以基于不同虚拟网关集群(例如图1所示的虚拟网关集群101、102)之间的集群差异,确定集群间灰度优先级。
通常,在云环境中,不同虚拟网关集群之间存在差异。基于虚拟网关集群的差异,可以确定虚拟网关集群的优先级。其中,虚拟网关集群的优先级就是集群间灰度优先级。虚拟网关集群之间的差异可以包括但不限于部署的设备差异、承载的用户差异等等。以部署的设备差异为例,虚拟网关集群部署的设备越少,其集群间灰度优先级越高。
步骤202,基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级。
在本实施例中,上述执行主体可以基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级。
通常,在同一虚拟网关集群内部部署多台网关设备,不同网关设备之间存在差异。基于网关设备的差异,可以确定网关设备的优先级。其中,网关设备的优先级就是集群内灰度优先级。网关设备之间的差异可以包括但不限于分布位置的差异。由于分布在同一位置的不同网关设备不能同时发布版本,因此,同一位置的不同网关设备可以被随机设置成不同的集群内灰度优先级。
步骤203,基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表。
在本实施例中,上述执行主体可以基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表。
这里,集群间灰度优先级和集群内灰度优先级是两个维度的优先级。基于集群间灰度优先级,可以对不同虚拟网关集群进行分级;基于集群内灰度优先级,可以对同一虚拟网关集群中的不同网关设备进行分级,从而生成集群与设备分级列表。其中,集群与设备分级列表的列和行分别与集群间灰度优先级和集群内灰度优先级对应。例如,按照集群间灰度优先级从高到低的顺序,将虚拟网关集群从上到下依次填写在集群与设备分级列表的列中。对于同一虚拟网关集群,按照集群内灰度优先级从高到低的顺序,将该虚拟网关集群中的网关设备从左到右依次填写在集群与设备分级列表中该虚拟网关集群所对应的行中。
步骤204,基于集群与设备分级列表,生成并发发布列表序列。
在本实施例中,上述执行主体可以基于集群与设备分级列表,生成并发发布列表序列。
通常,在集群与设备分级列表中,同一列的网关设备属于不同的虚拟网关集群,没有集群内的限制,可以并发发布。不同列的网关设备属于同一虚拟网关集群,有集群内的限制,需要级联发布。因此,基于以上规则,可以生成并发发布列表序列。其中,同一并发发布列表中的网关设备不是属于同一虚拟网关集群的所有网关设备,可以并发发布。不同并发发布列表中的网关设备级联发布。并且,同一并发发布列表包括在集群与设备分级列表中连续排列的至少一个虚拟网关集群中的网关设备。并发发布列表在并发发布列表序列中的顺序由并发发布列表中的网关设备对应的集群间灰度优先级和集群内灰度优先级确定。例如,对于属于不同集群间灰度优先级的网关设备,按照集群间灰度优先级从高到低的顺序,将对应的并发发布列表从前往后依次填写在并发发布列表序列中。而对于属于同一集群间灰度优先级且不同集群内灰度优先级的网关设备,按照集群内灰度优先级从高到低的顺序,将对应的并发发布列表从前往后依次填写在并发发布列表序列中。
步骤205,对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。
在本实施例中,上述执行主体可以基于并发发布列表序列,将虚拟网关版本发布到所有虚拟网关集群中的所有网关设备上。具体地,对于不同并发发布列表中的设备,可以按照在并发发布列表序列中的次序级联发布虚拟网关版本;对于同一并发发布列表中的设备,可以并发发布虚拟网关版本。
本申请实施例提供的虚拟网关版本灰度发布方法,首先考虑不同虚拟网关集群和不同网关设备的差异,生成集群间灰度优先级和集群内灰度优先级;然后基于集群间灰度优先级和集群内灰度优先级,生成并发发布列表序列;最后对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。提供了一种自动灰度方式,考虑不同虚拟网关集群和不同网关设备的差异,输出合理的并发发布列表序列,能够平滑地、快速地、不重不漏地将虚拟网关版本发布到所有区域的所有网关设备上。
进一步参考图3,其示出了根据本申请的虚拟网关版本灰度发布方法的又一个实施例的流程300。该虚拟网关版本灰度发布方法包括以下步骤:
步骤301,提取不同虚拟网关集群之间的集群级特征。
在本实施例中,虚拟网关版本灰度发布方法的执行主体(例如图1所示的服务器103)可以提取不同虚拟网关集群之间的集群级特征。
通常,不同虚拟网关集群的差异,可以由虚拟网关集群的至少一种特征来确定。其中,虚拟网关集群的特征就是集群级特征,可以包括但不限于以下至少一项:
1、承载用户规模:虚拟网关集群承载的用户规模越大,其集群间灰度优先级越低。
2、承载单客户重要性:承载着大客户、头部客户的虚拟网关集群的集群间灰度优先级低。
3、物理架构:在云业务的发展过程中,虚拟网关集群的物理架构也在不断的变化。不同物理架构的虚拟网关集群可以随机对应一种集群间灰度优先级。
4、业务场景:虚拟网关集群具有的云上业务场景越全面,其集群间灰度优先级越高。
步骤302,基于集群级特征,确定集群间灰度优先级。
在本实施例中,上述执行主体可以基于集群级特征,确定集群间灰度优先级。
通常,在仅提取一种集群级特征的情况下,可以直接基于该集群级特征与集群间灰度优先级之间的关联关系,确定集群间灰度优先级。在提取多种集群级特征,且同一虚拟网关集群具有的集群级特征不冲突的情况下(例如承载用户规模大,且承载单客户重要性高),可以分别基于多种集群级特征,确定多个集群间灰度优先级,然后对多个集群间灰度优先级进行加权,即可得到最终的集群间灰度优先级。在提取多种集群级特征,且同一虚拟网关集群具有的集群级特征相互冲突的情况下(例如承载用户规模大,且具有的云上业务场景全面),可以根据实际情况来确定集群间灰度优先级。
步骤303,提取同一虚拟网关集群之内的设备级特征。
在本实施例中,上述执行主体可以提取同一虚拟网关集群之内的设备级特征。
通常,为了容灾考虑,在同一虚拟网关集群内部,在部署时一般分布在多个TOR(The Onion Router,洋葱路由)下、多个机柜中。在版本发布时也需要考虑到容灾,也即一个TOR下或者一个机柜内的网关设备不能同时全部发布版本,否则可能会造成物理网络拓扑变化,影响云上用户业务。同一虚拟网关集群之内的设备差异,可以由网关设备的至少一种特征来决定。其中,网关设备的特征就是设备级特征,可以包括但不限于以下至少一项:
1、TOR的分布特征:同一个TOR下的网关设备不能同时发布版本,同一个TOR下的不同网关设备可以随机对应一种集群内灰度优先级。
2、机柜的分布特征:同一个机柜下的网关设备不能同时发布版本,同一个机柜下的不同网关设备可以随机对应一种集群内灰度优先级。
3、容量:同时发布版本的网格设备不能超过容量冗余的1/2,否则可能有容量风险,因此同一集群内灰度优先级的网关设备不能超过容量冗余的1/2。
步骤304,基于设备级特征,确定集群内灰度优先级。
在本实施例中,上述执行主体可以基于设备级特征,确定集群内灰度优先级。
通常,在仅提取一种设备级特征的情况下,可以直接基于该设备级特征与集群内灰度优先级之间的关联关系,确定集群内灰度优先级。在提取多种设备级特征的情况下,可以分别基于多种设备级特征,确定多个集群内灰度优先级,然后对多个集群内灰度优先级进行加权,即可得到最终的集群内灰度优先级。
步骤305,基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表。
在本实施例中,步骤305具体操作已在图2所示的实施例中步骤203进行了详细的介绍,在此不再赘述。
步骤306,对于同一集群内灰度优先级的不同虚拟网关集群,按照集群间灰度优先级顺序,依次生成同一集群内灰度优先级对应的并发发布列表。
在本实施例中,对于同一集群内灰度优先级的不同虚拟网关集群,上述执行主体可以按照集群间灰度优先级顺序,依次生成同一集群内灰度优先级对应的并发发布列表。其中,同一集群内灰度优先级对应的不同并发发布列表包括的集群间灰度优先级的数目相同。
例如,对于集群与设备分级列表中的第一列,按照集群间灰度优先级顺序依次生成并发发布列表。其中,不同并发发布列表包括的集群间灰度优先级的数目是1,包括的虚拟网关集群的数目是N(N为正整数)。也就是说,在第一列中,若m(m为正整数)个虚拟网关集群的集群间灰度优先级相同,那么对应的并发发布列表会同时包括这几个虚拟网关集群,即N=m;若同一集群间灰度优先级仅包括一个虚拟网关集群,那么对应的并发发布列表仅包括这一个虚拟网关集群,即N=1。
步骤307,对于相邻集群内灰度优先级对应的并发发布列表,后一集群内灰度优先级对应的并发发布列表包括的集群间灰度优先级的数目相对于前一集群内灰度优先级呈等差数列增长。
在本实施例中,对于相邻集群内灰度优先级对应的并发发布列表,后一集群内灰度优先级对应的并发发布列表包括的集群间灰度优先级的数目可以相对于前一集群内灰度优先级呈等差数列增长。其中,等差数列可以包括但不限于奇数的等差数列、偶数的等差数列等等。
通常,在发布执行一段时间之后,如果监控没有发现问题或者没有用户反馈问题,说明新的虚拟网关版本没有问题,这时可以加速发布速度,从而缩短版本发布速度。
例如,在集群与设备分级列表中的第一列结束后,其后的列对应的并发发布列表包括的集群间灰度优先级的数目以3、5、7,…,奇数的等差数列增长。具体地,对于集群与设备分级列表中的第二列,按照集群间灰度优先级顺序依次生成并发发布列表。其中,不同并发发布列表包括的集群间灰度优先级的数目是3,包括的虚拟网关集群的数目是N。也就是说,在第二列中,若m个虚拟网关集群的集群间灰度优先级相同,那么对应的并发发布列表会同时包括这几个虚拟网关集群,即N=m+2;若同一集群间灰度优先级仅包括一个虚拟网关集群,那么对应的并发发布列表仅包括这一个虚拟网关集群,即N=3。
步骤308,对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。
在本实施例中,步骤308具体操作已在图2所示的实施例中步骤205进行了详细的介绍,在此不再赘述。
从图3中可以看出,与图2对应的实施例相比,本实施例中的虚拟网关版本灰度发布方法的流程300突出了集群间灰度优先级和集群内灰度优先级的确定步骤和并发发布列表序列的生成步骤。由此,在本实施例描述的方案中,基于虚拟网关集群和网关设备的特征来分别确定集群间灰度优先级和集群内灰度优先级,提高了确定出的集群间灰度优先级和集群内灰度优先级的准确度。并且,基于网关设备的特征来确定集群内灰度优先级,能够考虑容灾,避免同一TOR下或者同一机柜内的网关设备同时全部发布版本,造成的物理网络拓扑变化,影响云上用户业务。为同一列的并发发布列表设置相同的集群间灰度优先级数目,为不同列的并发发布列表设置不同的集群间灰度优先级数目,能够考虑发布速度的变化。先让版本发布执行一段时间,在确定版本没有问题之后,加速发布速度,从而缩短版本发布速度。
为了便于理解,下面提供一种可以应用本申请实施例提供的虚拟网关版本灰度发布方法的应用场景。
首先,基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级,并生成集群间灰度优先级列表,具体如表1所示:
集群间优先级 虚拟网关集群
1 Cluster-1
2 Cluster-2
3 Cluster-3
3 Cluster-4
4 Cluster-5
表1
之后,基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级,并结合表1生成集群与设备分级列表,具体如表2所示:
Figure BDA0002589339540000111
表2
然后,对于集群与设备分级列表中的第一列,按照集群间灰度优先级顺序依次生成并发发布列表。其中,不同并发发布列表包括的集群间灰度优先级的数目是1。在集群与设备分级列表中的第一列结束后,其后的列对应的并发发布列表包括的集群间灰度优先级的数目以3、5、7,…,奇数的等差数列增长。并发发布列表序列如下所示:
第一批:
Cluster-1-device0
Cluster-1-device1
第二批:
Cluster-2-device0
Cluster-2-device1
第三批:
Cluster-3-device0
Cluster-3-device1
Cluster-3-device2
Cluster-4-device0
Cluster-4-device1
Cluster-4-device2
第四批:
Cluster-5-device0
Cluster-5-device1
第五批:
Cluster-1-device2
Cluster-1-device3
Cluster-2-device2
Cluster-2-device3
Cluster-3-device3
Cluster-3-device4
Cluster-3-device5
Cluster-4-device3
Cluster-4-device4
Cluster-4-device5
第六批:
最后,对于同一并发发布列表中的设备,并发发布虚拟网关版本;对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本。
进一步参考图4,作为对上述各图所示方法的实现,本申请提供了一种虚拟网关版本灰度发布装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图4所示,本实施例的虚拟网关版本灰度发布装置400可以包括:集群间优先级确定模块401、集群内优先级确定模块402、分级列表生成模块403、并发发布列表生成模块404和并发发布模块405。其中,集群间优先级确定模块401,被配置成基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;集群内优先级确定模块402,被配置成基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;分级列表生成模块403,被配置成基于集群间灰度优先级和集群内灰度优先级,生成集群与设备分级列表;并发发布列表生成模块404,被配置成基于集群与设备分级列表,生成并发发布列表序列;并发发布模块405,被配置成对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。
在本实施例中,虚拟网关版本灰度发布装置400中:集群间优先级确定模块401、集群内优先级确定模块402、分级列表生成模块403、并发发布列表生成模块404和并发发布模块405的具体处理及其所带来的技术效果可分别参考图2对应实施例中的步骤201-205的相关说明,在此不再赘述。
在本实施例的一些可选的实现方式中,集群间优先级确定模块501进一步被配置成:提取不同虚拟网关集群之间的集群级特征,其中,集群级特征包括以下至少一项:承载用户规模、承载单客户重要性、物理架构和业务场景;基于集群级特征,确定集群间灰度优先级。
在本实施例的一些可选的实现方式中,集群内优先级确定模块502进一步被配置成:提取同一虚拟网关集群之内的设备级特征,其中,设备级特征包括以下至少一项:洋葱路由TOR的分布特征、机柜的分布特征和容量;基于设备级特征,确定集群内灰度优先级。
在本实施例的一些可选的实现方式中,并发发布列表生成模块404进一步被配置成:对于同一集群内灰度优先级的不同虚拟网关集群,按照集群间灰度优先级顺序,依次生成同一集群内灰度优先级对应的并发发布列表,其中,同一集群内灰度优先级对应的不同并发发布列表包括的集群间灰度优先级的数目相同。
在本实施例的一些可选的实现方式中,并发发布列表生成模块404进一步被配置成:对于相邻集群内灰度优先级对应的并发发布列表,后一集群内灰度优先级对应的并发发布列表包括的集群间灰度优先级的数目相对于前一集群内灰度优先级呈等差数列增长。
根据本申请的实施例,本申请还提供了一种电子设备和一种可读存储介质。
如图5所示,是根据本申请实施例虚拟网关版本灰度发布方法的电子设备的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本申请的实现。
如图5所示,该电子设备包括:一个或多个处理器501、存储器502,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在电子设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在其它实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个电子设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图5中以一个处理器501为例。
存储器502即为本申请所提供的非瞬时计算机可读存储介质。其中,所述存储器存储有可由至少一个处理器执行的指令,以使所述至少一个处理器执行本申请所提供的虚拟网关版本灰度发布方法。本申请的非瞬时计算机可读存储介质存储计算机指令,该计算机指令用于使计算机执行本申请所提供的虚拟网关版本灰度发布方法。
存储器502作为一种非瞬时计算机可读存储介质,可用于存储非瞬时软件程序、非瞬时计算机可执行程序以及模块,如本申请实施例中的虚拟网关版本灰度发布方法对应的程序指令/模块(例如,附图4所示的集群间优先级确定模块401、集群内优先级确定模块402、分级列表生成模块403、并发发布列表生成模块404和并发发布模块405)。处理器501通过运行存储在存储器502中的非瞬时软件程序、指令以及模块,从而执行服务器的各种功能应用以及数据处理,即实现上述方法实施例中的虚拟网关版本灰度发布方法。
存储器502可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据虚拟网关版本灰度发布方法的电子设备的使用所创建的数据等。此外,存储器502可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些实施例中,存储器502可选包括相对于处理器501远程设置的存储器,这些远程存储器可以通过网络连接至虚拟网关版本灰度发布方法的电子设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
虚拟网关版本灰度发布方法的电子设备还可以包括:输入装置503和输出装置504。处理器501、存储器502、输入装置503和输出装置504可以通过总线或者其他方式连接,图5中以通过总线连接为例。
输入装置503可接收输入的数字或字符信息,以及产生与虚拟网关版本灰度发布方法的电子设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等输入装置。输出装置504可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。该显示设备可以包括但不限于,液晶显示器(LCD)、发光二极管(LED)显示器和等离子体显示器。在一些实施方式中,显示设备可以是触摸屏。
此处描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、专用ASIC(专用集成电路)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
这些计算程序(也称作程序、软件、软件应用、或者代码)包括可编程处理器的机器指令,并且可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。如本文使用的,术语“机器可读介质”和“计算机可读介质”指的是用于将机器指令和/或数据提供给可编程处理器的任何计算机程序产品、设备、和/或装置(例如,磁盘、光盘、存储器、可编程逻辑装置(PLD)),包括,接收作为机器可读信号的机器指令的机器可读介质。术语“机器可读信号”指的是用于将机器指令和/或数据提供给可编程处理器的任何信号。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。
根据本申请的技术方案,首先考虑不同虚拟网关集群和不同网关设备的差异,生成集群间灰度优先级和集群内灰度优先级;然后基于集群间灰度优先级和集群内灰度优先级,生成并发发布列表序列;最后对于不同并发发布列表中的设备,按照在并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布虚拟网关版本。提供了一种自动灰度方式,考虑不同虚拟网关集群和不同网关设备的差异,输出合理的并发发布列表序列,能够平滑地、快速地、不重不漏地将虚拟网关版本发布到所有区域的所有网关设备上。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发申请中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本申请公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本申请保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本申请的精神和原则之内所作的修改、等同替换和改进等,均应包含在本申请保护范围之内。

Claims (12)

1.一种虚拟网关版本灰度发布方法,包括:
基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;
基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;
基于所述集群间灰度优先级和所述集群内灰度优先级,生成集群与设备分级列表;
基于所述集群与设备分级列表,生成并发发布列表序列;
对于不同并发发布列表中的设备,按照在所述并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布所述虚拟网关版本。
2.根据权利要求1所述的方法,其中,所述基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级,包括:
提取不同虚拟网关集群之间的集群级特征,其中,所述集群级特征包括以下至少一项:承载用户规模、承载单客户重要性、物理架构和业务场景;
基于所述集群级特征,确定所述集群间灰度优先级。
3.根据权利要求1所述的方法,其中,所述基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级,包括:
提取同一虚拟网关集群之内的设备级特征,其中,所述设备级特征包括以下至少一项:洋葱路由TOR的分布特征、机柜的分布特征和容量;
基于所述设备级特征,确定所述集群内灰度优先级。
4.根据权利要求1所述的方法,其中,所述基于所述集群与设备分级列表,生成并发发布列表序列,包括:
对于同一集群内灰度优先级的不同虚拟网关集群,按照集群间灰度优先级顺序,依次生成同一集群内灰度优先级对应的并发发布列表,其中,同一集群内灰度优先级对应的不同并发发布列表包括的集群间灰度优先级的数目相同。
5.根据权利要求4所述的方法,其中,所述基于所述集群与设备分级列表,生成并发发布列表序列,还包括:
对于相邻集群内灰度优先级对应的并发发布列表,后一集群内灰度优先级对应的并发发布列表包括的集群间灰度优先级的数目相对于前一集群内灰度优先级呈等差数列增长。
6.一种虚拟网关版本灰度发布装置,包括:
集群间优先级确定模块,被配置成基于不同虚拟网关集群之间的集群差异,确定集群间灰度优先级;
集群内优先级确定模块,被配置成基于同一虚拟网关集群之内的设备差异,确定集群内灰度优先级;
分级列表生成模块,被配置成基于所述集群间灰度优先级和所述集群内灰度优先级,生成集群与设备分级列表;
并发发布列表生成模块,被配置成基于所述集群与设备分级列表,生成并发发布列表序列;
并发发布模块,被配置成对于不同并发发布列表中的设备,按照在所述并发发布列表序列中的次序级联发布虚拟网关版本,以及对于同一并发发布列表中的设备,并发发布所述虚拟网关版本。
7.根据权利要求6所述的装置,其中,所述集群间优先级确定模块进一步被配置成:
提取不同虚拟网关集群之间的集群级特征,其中,所述集群级特征包括以下至少一项:承载用户规模、承载单客户重要性、物理架构和业务场景;
基于所述集群级特征,确定所述集群间灰度优先级。
8.根据权利要求6所述的装置,其中,所述集群内优先级确定模块进一步被配置成:
提取同一虚拟网关集群之内的设备级特征,其中,所述设备级特征包括以下至少一项:洋葱路由TOR的分布特征、机柜的分布特征和容量;
基于所述设备级特征,确定所述集群内灰度优先级。
9.根据权利要求6所述的装置,其中,所述并发发布列表生成模块进一步被配置成:
对于同一集群内灰度优先级的不同虚拟网关集群,按照集群间灰度优先级顺序,依次生成同一集群内灰度优先级对应的并发发布列表,其中,同一集群内灰度优先级对应的不同并发发布列表包括的集群间灰度优先级的数目相同。
10.根据权利要求9所述的装置,其中,所述并发发布列表生成模块进一步被配置成:
对于相邻集群内灰度优先级对应的并发发布列表,后一集群内灰度优先级对应的并发发布列表包括的集群间灰度优先级的数目相对于前一集群内灰度优先级呈等差数列增长。
11.一种电子设备,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的方法。
12.一种计算机可读介质,其上存储有计算机程序,其中,所述计算机程序被处理器执行时实现如权利要求1-5中任一所述的方法。
CN202010690949.4A 2020-07-17 2020-07-17 虚拟网关版本灰度发布方法、装置、设备以及存储介质 Active CN111865683B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010690949.4A CN111865683B (zh) 2020-07-17 2020-07-17 虚拟网关版本灰度发布方法、装置、设备以及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010690949.4A CN111865683B (zh) 2020-07-17 2020-07-17 虚拟网关版本灰度发布方法、装置、设备以及存储介质

Publications (2)

Publication Number Publication Date
CN111865683A true CN111865683A (zh) 2020-10-30
CN111865683B CN111865683B (zh) 2023-07-14

Family

ID=73000503

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010690949.4A Active CN111865683B (zh) 2020-07-17 2020-07-17 虚拟网关版本灰度发布方法、装置、设备以及存储介质

Country Status (1)

Country Link
CN (1) CN111865683B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114422440A (zh) * 2022-03-28 2022-04-29 北京沃丰时代数据科技有限公司 灰度发布方法、装置、电子设备及存储介质

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103164202A (zh) * 2011-12-15 2013-06-19 深圳市腾讯计算机系统有限公司 一种灰度发布方法和装置
CN107360010A (zh) * 2016-05-09 2017-11-17 阿里巴巴集团控股有限公司 一种网站灰度发布方法及装置
CN108011891A (zh) * 2017-12-22 2018-05-08 深圳乐信软件技术有限公司 一种应用访问方法、装置、服务器及计算机存储介质
CN108632085A (zh) * 2018-04-08 2018-10-09 深圳乐信软件技术有限公司 灰度用户管理方法、装置、平台及存储介质
CN109240708A (zh) * 2018-07-02 2019-01-18 北京百度网讯科技有限公司 应用部署方法、装置、计算机设备及存储介质
CN109739552A (zh) * 2019-01-04 2019-05-10 深圳壹账通智能科技有限公司 微服务灰度发布方法、装置、计算机设备和存储介质
CN110399147A (zh) * 2019-06-04 2019-11-01 菜鸟智能物流控股有限公司 版本发布系统和方法以及电子设备

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103164202A (zh) * 2011-12-15 2013-06-19 深圳市腾讯计算机系统有限公司 一种灰度发布方法和装置
CN107360010A (zh) * 2016-05-09 2017-11-17 阿里巴巴集团控股有限公司 一种网站灰度发布方法及装置
CN108011891A (zh) * 2017-12-22 2018-05-08 深圳乐信软件技术有限公司 一种应用访问方法、装置、服务器及计算机存储介质
CN108632085A (zh) * 2018-04-08 2018-10-09 深圳乐信软件技术有限公司 灰度用户管理方法、装置、平台及存储介质
CN109240708A (zh) * 2018-07-02 2019-01-18 北京百度网讯科技有限公司 应用部署方法、装置、计算机设备及存储介质
CN109739552A (zh) * 2019-01-04 2019-05-10 深圳壹账通智能科技有限公司 微服务灰度发布方法、装置、计算机设备和存储介质
CN110399147A (zh) * 2019-06-04 2019-11-01 菜鸟智能物流控股有限公司 版本发布系统和方法以及电子设备

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114422440A (zh) * 2022-03-28 2022-04-29 北京沃丰时代数据科技有限公司 灰度发布方法、装置、电子设备及存储介质

Also Published As

Publication number Publication date
CN111865683B (zh) 2023-07-14

Similar Documents

Publication Publication Date Title
JP2022023769A (ja) サーバリソースを割り当てるための方法、装置、電子デバイス、コンピュータ可読記憶媒体及びコンピュータプログラム
CN111694646B (zh) 资源调度方法、装置、电子设备及计算机可读存储介质
CN111506401B (zh) 自动驾驶仿真任务调度方法、装置、电子设备及存储介质
CN111913998B (zh) 数据处理方法、装置、设备和存储介质
CN110619002A (zh) 数据处理方法、装置及存储介质
CN113051446A (zh) 拓扑关系查询方法、装置、电子设备和介质
CN111880914A (zh) 资源调度方法、资源调度装置、电子设备和存储介质
CN111461343A (zh) 模型参数更新方法及其相关设备
CN111698326A (zh) 用于确定云服务资源的成本归属的方法和装置
CN111865683B (zh) 虚拟网关版本灰度发布方法、装置、设备以及存储介质
US20210312240A1 (en) Header Model For Instance Segmentation, Instance Segmentation Model, Image Segmentation Method and Apparatus
CN111782357B (zh) 标签控制方法及装置、电子设备和可读存储介质
CN111079813B (zh) 基于模型并行的分类模型计算方法和装置
CN111984545A (zh) 检测单元测试稳定性的方法、装置、电子设备及存储介质
CN112486644A (zh) 用于生成信息的方法、装置、设备以及存储介质
CN111738325A (zh) 图像识别方法、装置、设备以及存储介质
CN111596897A (zh) 代码复用的处理方法、装置及电子设备
CN111292223A (zh) 图计算的处理方法、装置、电子设备及存储介质
CN112346512A (zh) 时间同步方法和装置
CN112101447A (zh) 数据集的质量评估方法、装置、设备以及存储介质
CN111523000A (zh) 用于导入数据的方法、装置、设备以及存储介质
CN111461340A (zh) 权重矩阵的更新方法、装置及电子设备
CN112148563B (zh) 信息生成方法、装置、设备以及存储介质
CN112734454A (zh) 一种用户信息确定方法、装置、电子设备和存储介质
CN111488366B (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