CN114040024A - 基于网关的微服务灰度发布方法、装置、设备及存储介质 - Google Patents
基于网关的微服务灰度发布方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN114040024A CN114040024A CN202010702050.XA CN202010702050A CN114040024A CN 114040024 A CN114040024 A CN 114040024A CN 202010702050 A CN202010702050 A CN 202010702050A CN 114040024 A CN114040024 A CN 114040024A
- Authority
- CN
- China
- Prior art keywords
- micro
- gray scale
- gateway
- service
- rule
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 43
- 238000006243 chemical reaction Methods 0.000 claims description 8
- 238000004891 communication Methods 0.000 description 9
- 238000010586 diagram Methods 0.000 description 4
- 238000001514 detection method Methods 0.000 description 2
- 238000010276 construction Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000000605 extraction Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/66—Arrangements for connecting between networks having differing types of switching systems, e.g. gateways
Abstract
本发明公开了一种基于网关的微服务灰度发布方法、装置、设备及存储介质,本发明基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将目标灰度发布规则发送至网关;基于网关获取服务注册中心的微服务信息,并根据微服务信息更新得到目标微服务列表;基于目标微服务列表与目标灰度发布规则,将灰度发布请求路由至微服务器。本发明在接收到灰度发布请求时,通过百分比权重或自定义属性的方式,配置用于对路由到更新应用的用户流量进行分配的目标灰度发布规则,根据目标灰度发布规则与目标微服务列表将灰度发布请求路由至微服务器,实现灵活地控制路由到更新应用的用户流量,提高对更新应用进行发布的灵活性。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种基于网关的微服务灰度发布方法、装置、设备及存储介质。
背景技术
随着计算机技术的快速发展,现如今人们对于各类应用的要求越来越严格,因此,各类应用的开发人员需要不断的根据用户的需求对应用进行相应的更新,以便于留住用户或者吸引更多用户,从而使应用得到更多的流量。
目前,开发人员在对应用进行更新后,根据版本号并通过轮询的方式发布更新后的应用,使得每个用户都具备对更新后的应用进行使用的权限。但是,由于更新后的应用可能存在漏洞或数据错误,若所有用户都可以进行访问并利用应用存在的漏洞,容易导致服务器出现问题。因此,现有技术通过轮询的方式发布更新后的应用,只能对路由到该版本服务器的用户流量进行均匀分配,而不能对用户流量的分配进行比例控制,导致对更新应用进行发布的灵活性较低。
发明内容
本发明的主要目的在于提供一种基于网关的微服务灰度发布方法、装置、设备及存储介质,旨在解决现有技术通过轮询的方式发布更新后的应用,导致对更新应用进行发布的灵活性较低的技术问题。
为实现上述目的,本发明实施例提供一种基于网关的微服务灰度发布方法,所述基于网关的微服务灰度发布方法包括:
当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。
优选地,所述基于百分比权重方式或自定义属性方式配置目标灰度发布规则的步骤包括:
构建初始灰度发布规则,检测灰度发布规则的配置方式;
若所述灰度发布规则的配置方式为百分比权重方式,则根据所述百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则;
若所述灰度发布规则的配置方式为自定义属性方式,则根据所述自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则。
优选地,所述若所述灰度发布规则的配置方式为所述百分比权重方式,则根据百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为百分比权重方式,则获取所述百分比权重方式对应的第一规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第一规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
优选地,所述若所述灰度发布规则的配置方式为所述自定义属性方式,则根据自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为自定义属性方式,则获取所述自定义属性方式对应的第二规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第二规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
优选地,所述基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表的步骤包括:
基于所述网关获取服务注册中心的微服务信息,提取所述微服务信息中的新增版本号信息与新增版本号对应的新增接口参数信息;
根据所述新增版本号信息与所述新增接口参数信息,对所述网关的微服务列表进行更新,得到目标微服务列表。
优选地,所述基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器的步骤包括:
确定所述目标微服务列表与所述灰度发布规则是否存在相同的版本号;
若存在相同的所述版本号,则基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至所述版本号对应的微服务器。
优选地,所述将所述目标灰度发布规则发送至网关的步骤包括:
确定所述目标灰度发布规则的格式是否为预设类型;
若所述目标灰度发布规则的格式为预设类型,则将所述目标灰度发布规则发送至网关;
若所述目标灰度发布规则的格式不为预设类型,则对所述目标灰度发布规则进行格式转换,并将转换后的目标灰度发布规则发送至网关。
为实现上述目的,本发明还提供一种基于网关的微服务灰度发布装置,所述基于网关的微服务灰度发布装置包括:
配置模块,用于当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
更新模块,用于基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
路由模块,用于基于目标微服务列表与目标灰度发布规则,将所述灰度发布请求路由至微服务器。
进一步地,为实现上述目的,本发明还提供一种基于网关的微服务灰度发布设备,所述基于网关的微服务灰度发布设备包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的基于网关的微服务灰度发布程序,所述基于网关的微服务灰度发布程序被所述处理器执行时实现上述的基于网关的微服务灰度发布方法的步骤。
进一步地,为实现上述目的,本发明还提供一种存储介质,所述存储介质上存储有基于网关的微服务灰度发布程序,所述基于网关的微服务灰度发布程序被处理器执行时实现上述的基于网关的微服务灰度发布方法的步骤。
本发明实施例提供一种基于网关的微服务灰度发布方法、装置、设备及存储介质,当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。本发明在接收到灰度发布请求时,通过百分比权重或自定义属性的方式,配置用于对路由到更新应用的用户流量进行分配的目标灰度发布规则,并通过网关从服务注册中心获取微服务信息更新得到目标微服务列表,最后根据目标灰度发布规则与目标微服务列表将灰度发布请求路由至微服务器,实现灵活地控制路由到更新应用的用户流量,提高对更新应用进行发布的灵活性。
附图说明
图1为本发明基于网关的微服务灰度发布方法实施例方案涉及的硬件运行环境的结构示意图;
图2为本发明基于网关的微服务灰度发布方法第一实施例的流程示意图;
图3本发明基于网关的微服务灰度发布方法的整体流程示意图;
图4为本发明基于网关的微服务灰度发布方法第二实施例的流程示意图;
图5为本发明基于网关的微服务灰度发布装置较佳实施例的功能模块示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本发明实施例提供一种基于网关的微服务灰度发布方法、装置、设备及存储介质,当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。本发明在接收到灰度发布请求时,通过百分比权重或自定义属性的方式,配置用于对路由到更新应用的用户流量进行分配的目标灰度发布规则,并通过网关从服务注册中心获取微服务信息更新得到目标微服务列表,最后根据目标灰度发布规则与目标微服务列表将灰度发布请求路由至微服务器,实现灵活地控制路由到更新应用的用户流量,提高对更新应用进行发布的灵活性。
如图1所示,图1是本发明实施例方案涉及的硬件运行环境的基于网关的微服务灰度发布设备结构示意图。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
本发明实施例基于网关的微服务灰度发布设备可以是PC,也可以是平板电脑、便携计算机等可移动式终端设备。
如图1所示,该基于网关的微服务灰度发布设备可以包括:处理器1001,例如CPU,网络接口1004,用户接口1003,存储器1005,通信总线1002。其中,通信总线1002用于实现这些组件之间的连接通信。用户接口1003可以包括显示屏(Display)、输入单元比如键盘(Keyboard),可选用户接口1003还可以包括标准的有线接口、无线接口。网络接口1004可选的可以包括标准的有线接口、无线接口(如WI-FI接口)。存储器1005可以是高速RAM存储器,也可以是稳定的存储器(non-volatile memory),例如磁盘存储器。存储器1005可选的还可以是独立于前述处理器1001的存储装置。
本领域技术人员可以理解,图1中示出的基于网关的微服务灰度发布设备结构并不构成对基于网关的微服务灰度发布设备的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
如图1所示,作为一种存储介质的存储器1005中可以包括操作系统、网络通信模块、用户接口模块以及基于网关的微服务灰度发布程序。
在图1所示的设备中,网络接口1004主要用于连接后台服务器,与后台服务器进行数据通信;用户接口1003主要用于连接客户端(用户端),与客户端进行数据通信;而处理器1001可以用于调用存储器1005中存储的基于网关的微服务灰度发布程序,并执行以下操作:
当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。
进一步地,所述基于百分比权重方式或自定义属性方式配置目标灰度发布规则的步骤包括:
构建初始灰度发布规则,检测灰度发布规则的配置方式;
若所述灰度发布规则的配置方式为百分比权重方式,则根据所述百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则;
若所述灰度发布规则的配置方式为自定义属性方式,则根据所述自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述若所述灰度发布规则的配置方式为所述百分比权重方式,则根据百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为百分比权重方式,则获取所述百分比权重方式对应的第一规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第一规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述若所述灰度发布规则的配置方式为所述自定义属性方式,则根据自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为自定义属性方式,则获取所述自定义属性方式对应的第二规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第二规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表的步骤包括:
基于所述网关获取服务注册中心的微服务信息,提取所述微服务信息中的新增版本号信息与新增版本号对应的新增接口参数信息;
根据所述新增版本号信息与所述新增接口参数信息,对所述网关的微服务列表进行更新,得到目标微服务列表。
进一步地,所述基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器的步骤包括:
确定所述目标微服务列表与所述灰度发布规则是否存在相同的版本号;
若存在相同的所述版本号,则基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至所述版本号对应的微服务器。
进一步地,所述将所述目标灰度发布规则发送至网关的步骤包括:
确定所述目标灰度发布规则的格式是否为预设类型;
若所述目标灰度发布规则的格式为预设类型,则将所述目标灰度发布规则发送至网关;
若所述目标灰度发布规则的格式不为预设类型,则对所述目标灰度发布规则进行格式转换,并将转换后的目标灰度发布规则发送至网关。
为了更好的理解上述技术方案,下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
为了更好的理解上述技术方案,下面将结合说明书附图以及具体的实施方式对上述技术方案进行详细的说明。
参照图2,本发明第一实施例提供一种基于网关的微服务灰度发布方法的流程示意图。该实施例中,所述基于网关的微服务灰度发布方法包括以下步骤:
步骤S10,当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
本实施例中基于网关的微服务灰度发布方法应用于灰度发布系统,系统中至少包含有配置管理器、网关、服务注册中心,其中配置管理器在本实施例中为用于配置目标灰度发布规则的装置,网关是一个网络连接到另一个网络的“关口”,网关在本实施例中用于将用户流量路由至一个或多个版本对应的微服务器,以实现微服务灰度发布,服务注册中心是一个实时存储更新服务提供者信息及该服务的实时调用者信息的数据库,在本实施例中用于接收微服务更新版本的信息并供网关进行调用,以便于完成微服务灰度发布,网关通过网络分别与配置管理器以及服务注册中心通信连接。
进一步地,当接收到用户在具有灰度发布需求而发送的灰度发布请求时,系统调用配置管理器,构建初始灰度发布规则,并根据用户的灰度发布需求,通过百分比权重方式或自定义属性方式,对构建的初始灰度发布规则进行配置,得到目标灰度发布规则,其中初始灰度发布规则为具有基本规则信息的文件,百分比权重方式为:一套环境中可以同时运行微服务的多个版本,并指定某个微服务版本的百分比权重,使得位于该百分比范围内的用户流量可以路由到该版本的服务器,而剩余用户流量不会路由到该版本,自定义属性方式为:通过配置自定义的灰度发布规则和微服务版本号的映射,当满足该灰度发布规则时,才会将灰度发布请求路由至该版本的微服务器。进一步地,系统将通过配置管理器配置得到的目标灰度发布规则发送至网关,以供网关通过目标灰度发布规则与目标微服务列表,将灰度发布请求路由至微服务器,完成灰度发布。
进一步地,所述将所述目标灰度发布规则发送至网关的步骤包括:
步骤S11,确定所述目标灰度发布规则的格式是否为预设类型;
步骤S12,若所述目标灰度发布规则的格式为预设类型,则将所述目标灰度发布规则发送至网关;
步骤S13,若所述目标灰度发布规则的格式不为预设类型,则对所述目标灰度发布规则进行格式转换,并将转换后的目标灰度发布规则发送至网关。
进一步地,为确保网关可以顺利对目标灰度发布规则的内容进行识别,系统需要确保由配置管理器得到的目标灰度发布规则的文件的格式为网关可以识别的格式,本实施例中网关可以识别的灰度发布规则的格式优选为YAML(Yet Another Markup Language,仍是一种标记语言)。进一步地,系统获取目标灰度发布规则的文件信息,并识别文件信息中包含的原始文件格式是否为预设类型YAML,若经检测目标灰度发布规则的格式为YAML,则将目标灰度发布规则发送至网关,以便于网关识别目标灰度发布规则的内容,并完成灰度发布;若经检测目标灰度发布规则的格式不是YAML,系统对目标灰度发布规则的格式进行格式转换,具体地,系统根据原始文件格式与预设的YAML格式之间的转换关系,将目标灰度发布规则由原始文件格式转换为预设的YAML格式,并将完成格式转换的目标灰度发布规则发送至网关,以便于网关识别目标灰度发布规则的内容,并完成灰度发布。
步骤S20,基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
进一步地,系统调用网关,对服务注册中心存储的微服务信息进行获取,其中微服务信息至少包含微服务的多个旧版本的版本号信息以及多个旧版本对应的接口参数信息。进一步地,系统获取网关中存储的微服务列表,并根据从服务注册中心中获取的微服务信息对微服务列表进行更新,得到包含微服务得最新版本信息的目标微服务列表,以根据网关中存储的目标灰度发布规则与目标微服务列表,完成灰度发布,其中微服务列表存储有一个或多个微服务的信息,一个微服务可以由一个或多个版本,每个版本具有不同的版本号与接口参数。
进一步地,所述基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表的步骤包括:
步骤S21,基于所述网关获取服务注册中心的微服务信息,提取所述微服务信息中的新增版本号信息与新增版本号对应的新增接口参数信息;
步骤S22,根据所述新增版本号信息与所述新增接口参数信息,对所述网关的微服务列表进行更新,得到目标微服务列表。
进一步地,系统调用网关,通过网关从服务注册中心中获取其存储的微服务信息,并提取微服务信息中包含的新增版本号信息与新增版本号对应的新增接口参数信息,其中新增版本号信息为用户在对旧版本的微服务进行更新后,为对微服务的新版本与旧版本进行区分而设置的数字序列信息,新增接口参数信息用于通过网关将符合目标灰度发布规则的用户流量路由到新增版本号对应的微服务器。进一步地,系统根据新增版本号信息与新增接口参数信息,对网关的微服务列表进行更新,具体地,系统获取网关中存储的微服务列表,在微服务列表中新增一列微服务项,并在原有列表的基础上,将从微服务信息中提取的新增版本号信息与新增接口参数对应添加至新增的微服务项中,在完成信息的添加后得到目标微服务列表。
步骤S30,基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。
进一步地,系统确定目标微服务列表中的版本号是否与目标灰度发布规则中的版本号相同,并在目标微服务列表中的版本号与目标灰度发布规则中的版本号相同时,通过网关将灰度发布请求路由至版本号对应的微服务器,以完成灰度发布。
进一步地,所述基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器的步骤包括:
步骤S31,确定所述目标微服务列表与所述灰度发布规则是否存在相同的版本号;
步骤S32,若存在相同的所述版本号,则基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至所述版本号对应的微服务器。
进一步地,系统将网关中的目标微服务列表与目标灰度发布规则进行对比,若目标微服务列表中的版本号与目标灰度发布规则中的版本号相同,则判定达到了灰度发布的条件,通过网关将灰度发布请求路由至版本号对应的微服务器,以完成灰度发布;若目标微服务列表中的版本号与目标灰度发布规则中的版本号不相同,则判定未达到灰度发布的条件,终止灰度发布,并输出灰度发布失败的提示信息,以提示用户进行相应的调整。
进一步地,参照图3,图3为本发明基于网关的微服务灰度发布方法的整体流程示意图。
进一步地,系统通过配置管理器配置目标灰度发布规则,并将目标灰度发布规则发送至网关,其中配置管理器通过网络与网关通信连接。进一步地,系统调用网关对目标灰度发布规则进行解析,以检测是否满足灰度发布的条件。进一步地,系统通过网关从服务注册中心中获取微服务信息,并根据微服务信息更新微服务列表,得到目标微服务列表,其中网关与服务注册中心通过网络通信连接。进一步地,系统根据目标灰度发布规则与目标微服务列表,通过网关将灰度发布请求路由至微服务器,完成灰度发布。
本实施例提供一种基于网关的微服务灰度发布方法、装置、设备及存储介质,当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。本发明在接收到灰度发布请求时,通过百分比权重或自定义属性的方式,配置用于对路由到更新应用的用户流量进行分配的目标灰度发布规则,并通过网关从服务注册中心获取微服务信息更新得到目标微服务列表,最后根据目标灰度发布规则与目标微服务列表将灰度发布请求路由至微服务器,实现灵活地控制路由到更新应用的用户流量,提高对更新应用进行发布的灵活性。
进一步地,参照图4,基于本发明基于网关的微服务灰度发布方法的第一实施例,提出本发明基于网关的微服务灰度发布方法的第二实施例,在第二实施例中,所述基于百分比权重方式或自定义属性方式配置目标灰度发布规则的步骤包括:
步骤S14,构建初始灰度发布规则,检测灰度发布规则的配置方式;
步骤S15,若所述灰度发布规则的配置方式为百分比权重方式,则根据所述百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则;
步骤S16,若所述灰度发布规则的配置方式为自定义属性方式,则根据所述自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,在接收到用户发送的灰度发布请求时,系统构建初始灰度发布规则,并检测用户对于灰度发布规则的配置方式,具体地,在构建初始灰度发布规则的同时,系统输出提示用户选择配置方式的提示信息,并在接收到用户基于提示信息发送的选择指令时,检测选择指令对应的配置方式。进一步地,若检测到灰度发布规则的配置方式为百分比权重方式,则根据百分比权重方式包含的第一规则信息与灰度发布请求对应的请求信息,对构建的初始灰度发布规则进行配置,得到目标灰度发布规则,其中第一规则信息可以为用于配置目标灰度发布规则的权重模板信息,请求信息中包含有用户对于灰度发布设置的条件信息;若检测到灰度发布规则的配置方式为自定义属性方式,则根据自定义属性方式包含的第二规则信息与灰度发布请求对应的请求信息,对构建的初始灰度发布规则进行配置,得到目标灰度发布规则,其中第二规则信息可以为用于配置目标灰度发布规则的自定义模板信息。
进一步地,所述若所述灰度发布规则的配置方式为所述百分比权重方式,则根据百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
步骤S151,若所述灰度发布规则的配置方式为百分比权重方式,则获取所述百分比权重方式对应的第一规则信息,并获取所述灰度发布请求对应的请求信息;
步骤S152,根据所述第一规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,若通过对选择指令对应配置方式的检测,确定灰度发布规则的配置方式为百分比权重方式,系统对百分比权重方式进行解析,通过解析得到百分比权重方式对应的第一规则信息。进一步地,系统对灰度发布请求进行解析,通过解析得到灰度发布请求对应的请求信息。进一步地,系统将第一规则信息与请求信息进行适应融合,并将适应融合后的信息添加至初始灰度发布规则,形成目标灰度发布规则。
进一步地,所述若所述灰度发布规则的配置方式为所述自定义属性方式,则根据自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
步骤S161,若所述灰度发布规则的配置方式为自定义属性方式,则获取所述自定义属性方式对应的第二规则信息,并获取所述灰度发布请求对应的请求信息;
步骤S162,根据所述第二规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,若通过对选择指令对应配置方式的检测,确定灰度发布规则的配置方式为自定义属性方式,系统对自定义属性方式进行解析,通过解析得到自定义属性方式对应的第二规则信息。进一步地,系统对灰度发布请求进行解析,通过解析得到灰度发布请求对应的请求信息。进一步地,系统将第二规则信息与请求信息进行适应融合,并将适应融合后的信息添加至初始灰度发布规则,形成目标灰度发布规则。
本实施例通过检测用户对于灰度发布规则的配置方式,并根据用户所选择的不同配置方式,灵活地对初始灰度发布规则进行配置,得到对用户流量进行路由的目标灰度发布规则,以便于根据目标灰度发布规则与目标微服务列表,完成灰度发布,实现灵活地控制路由到更新应用的用户流量,提高对更新应用进行发布的灵活性。
进一步地,本发明还提供一种基于网关的微服务灰度发布装置。
参照图5,图5为本发明基于网关的微服务灰度发布装置第一实施例的功能模块示意图。
所述基于网关的微服务灰度发布装置包括:
配置模块10,用于当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
更新模块20,用于基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
路由模块30,用于基于目标微服务列表与目标灰度发布规则,将所述灰度发布请求路由至微服务器。
进一步地,所述配置模块10包括:
构建单元,用于构建初始灰度发布规则,检测灰度发布规则的配置方式;
第一配置单元,用于若所述灰度发布规则的配置方式为百分比权重方式,则根据所述百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则;
第二配置单元,用于若所述灰度发布规则的配置方式为自定义属性方式,则根据所述自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述配置模块10还包括:
第一获取单元,用于若所述灰度发布规则的配置方式为百分比权重方式,则获取所述百分比权重方式对应的第一规则信息,并获取所述灰度发布请求对应的请求信息;
第三配置单元,用于根据所述第一规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述配置模块10还包括:
第二获取单元,用于若所述灰度发布规则的配置方式为自定义属性方式,则获取所述自定义属性方式对应的第二规则信息,并获取所述灰度发布请求对应的请求信息;
第四配置单元,用于根据所述第二规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
进一步地,所述配置模块10还包括:
第一确定单元,用于确定所述目标灰度发布规则的格式是否为预设类型;
发送单元,用于若所述目标灰度发布规则的格式为预设类型,则将所述目标灰度发布规则发送至网关;
转换单元,用于若所述目标灰度发布规则的格式不为预设类型,则对所述目标灰度发布规则进行格式转换,并将转换后的目标灰度发布规则发送至网关。
进一步地,所述更新模块20包括:
提取单元,用于基于所述网关获取服务注册中心的微服务信息,提取所述微服务信息中的新增版本号信息与新增版本号对应的新增接口参数信息;
更新单元,用于根据所述新增版本号信息与所述新增接口参数信息,对所述网关的微服务列表进行更新,得到目标微服务列表。
进一步地,所述路由模块30包括:
第二确定单元,用于确定所述目标微服务列表与所述灰度发布规则是否存在相同的版本号;
路由单元,用于若存在相同的所述版本号,则基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至所述版本号对应的微服务器。
此外,本发明还提供一种存储介质,所述存储介质优选为计算机可读存储介质,其上存储有基于网关的微服务灰度发布程序,所述基于网关的微服务灰度发布程序被处理器执行时实现上述基于网关的微服务灰度发布方法各实施例的步骤。
在本发明基于网关的微服务灰度发布装置和计算机可读介质的实施例中,包含了上述基于网关的微服务灰度发布方法各实施例的全部技术特征,说明和解释内容与上述基于网关的微服务灰度发布方法各实施例基本相同,在此不做赘述。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是固定终端,如物联网智能设备,包括智能空调、智能电灯、智能电源、智能路由器等智能家居;也可以是移动终端,包括智能手机、可穿戴的联网AR/VR装置、智能音箱、自动驾驶汽车等诸多联网设备)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (10)
1.一种基于网关的微服务灰度发布方法,其特征在于,所述基于网关的微服务灰度发布方法包括:
当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器。
2.如权利要求1所述的基于网关的微服务灰度发布方法,其特征在于,所述基于百分比权重方式或自定义属性方式配置目标灰度发布规则的步骤包括:
构建初始灰度发布规则,检测灰度发布规则的配置方式;
若所述灰度发布规则的配置方式为百分比权重方式,则根据所述百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则;
若所述灰度发布规则的配置方式为自定义属性方式,则根据所述自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则。
3.如权利要求2所述的基于网关的微服务灰度发布方法,其特征在于,所述若所述灰度发布规则的配置方式为所述百分比权重方式,则根据百分比权重方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为百分比权重方式,则获取所述百分比权重方式对应的第一规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第一规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
4.如权利要求2所述的基于网关的微服务灰度发布方法,其特征在于,所述若所述灰度发布规则的配置方式为所述自定义属性方式,则根据自定义属性方式对所述初始灰度发布规则进行配置,得到目标灰度发布规则的步骤包括:
若所述灰度发布规则的配置方式为自定义属性方式,则获取所述自定义属性方式对应的第二规则信息,并获取所述灰度发布请求对应的请求信息;
根据所述第二规则信息与所述请求信息,对初始灰度发布规则进行配置,得到目标灰度发布规则。
5.如权利要求1所述的基于网关的微服务灰度发布方法,其特征在于,所述基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表的步骤包括:
基于所述网关获取服务注册中心的微服务信息,提取所述微服务信息中的新增版本号信息与新增版本号对应的新增接口参数信息;
根据所述新增版本号信息与所述新增接口参数信息,对所述网关的微服务列表进行更新,得到目标微服务列表。
6.如权利要求1所述的基于网关的微服务灰度发布方法,其特征在于,所述基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至微服务器的步骤包括:
确定所述目标微服务列表与所述灰度发布规则是否存在相同的版本号;
若存在相同的所述版本号,则基于所述目标微服务列表与所述目标灰度发布规则,将所述灰度发布请求路由至所述版本号对应的微服务器。
7.如权利要求1所述的基于网关的微服务灰度发布方法,其特征在于,所述将所述目标灰度发布规则发送至网关的步骤包括:
确定所述目标灰度发布规则的格式是否为预设类型;
若所述目标灰度发布规则的格式为预设类型,则将所述目标灰度发布规则发送至网关;
若所述目标灰度发布规则的格式不为预设类型,则对所述目标灰度发布规则进行格式转换,并将转换后的目标灰度发布规则发送至网关。
8.一种基于网关的微服务灰度发布装置,其特征在于,所述基于网关的微服务灰度发布装置包括:
配置模块,用于当接收到灰度发布请求时,基于百分比权重方式或自定义属性方式配置目标灰度发布规则,并将所述目标灰度发布规则发送至网关;
更新模块,用于基于所述网关获取服务注册中心的微服务信息,并根据所述微服务信息对所述网关的微服务列表进行更新,得到目标微服务列表;
路由模块,用于基于目标微服务列表与目标灰度发布规则,将所述灰度发布请求路由至微服务器。
9.一种基于网关的微服务灰度发布设备,其特征在于,所述基于网关的微服务灰度发布设备包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的基于网关的微服务灰度发布程序,所述基于网关的微服务灰度发布程序被所述处理器执行时实现如权利要求1-7中任一项所述的基于网关的微服务灰度发布方法的步骤。
10.一种存储介质,其特征在于,所述存储介质上存储有基于网关的微服务灰度发布程序,所述基于网关的微服务灰度发布程序被处理器执行时实现如权利要求1-7中任一项所述的基于网关的微服务灰度发布方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010702050.XA CN114040024A (zh) | 2020-07-20 | 2020-07-20 | 基于网关的微服务灰度发布方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010702050.XA CN114040024A (zh) | 2020-07-20 | 2020-07-20 | 基于网关的微服务灰度发布方法、装置、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114040024A true CN114040024A (zh) | 2022-02-11 |
Family
ID=80134063
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010702050.XA Pending CN114040024A (zh) | 2020-07-20 | 2020-07-20 | 基于网关的微服务灰度发布方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114040024A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114422440A (zh) * | 2022-03-28 | 2022-04-29 | 北京沃丰时代数据科技有限公司 | 灰度发布方法、装置、电子设备及存储介质 |
CN114726919A (zh) * | 2022-03-22 | 2022-07-08 | 新华三大数据技术有限公司 | 灰度流量控制的方法、装置、计算机设备及存储介质 |
CN117170718A (zh) * | 2023-11-02 | 2023-12-05 | 绿城科技产业服务集团有限公司 | 基于微服务架构的灰度发布方法、装置及电子设备 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109995713A (zh) * | 2017-12-30 | 2019-07-09 | 华为技术有限公司 | 一种微服务框架中的服务处理方法及相关设备 |
CN110958314A (zh) * | 2019-11-28 | 2020-04-03 | 盛业信息科技服务(深圳)有限公司 | 服务的灰度发布方法、装置和计算机设备 |
CN111181858A (zh) * | 2019-12-24 | 2020-05-19 | 浙江大华技术股份有限公司 | 灰度发布的方法、系统、计算机设备和存储介质 |
-
2020
- 2020-07-20 CN CN202010702050.XA patent/CN114040024A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109995713A (zh) * | 2017-12-30 | 2019-07-09 | 华为技术有限公司 | 一种微服务框架中的服务处理方法及相关设备 |
CN110958314A (zh) * | 2019-11-28 | 2020-04-03 | 盛业信息科技服务(深圳)有限公司 | 服务的灰度发布方法、装置和计算机设备 |
CN111181858A (zh) * | 2019-12-24 | 2020-05-19 | 浙江大华技术股份有限公司 | 灰度发布的方法、系统、计算机设备和存储介质 |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114726919A (zh) * | 2022-03-22 | 2022-07-08 | 新华三大数据技术有限公司 | 灰度流量控制的方法、装置、计算机设备及存储介质 |
CN114726919B (zh) * | 2022-03-22 | 2024-02-13 | 新华三大数据技术有限公司 | 灰度流量控制的方法、装置、计算机设备及存储介质 |
CN114422440A (zh) * | 2022-03-28 | 2022-04-29 | 北京沃丰时代数据科技有限公司 | 灰度发布方法、装置、电子设备及存储介质 |
CN117170718A (zh) * | 2023-11-02 | 2023-12-05 | 绿城科技产业服务集团有限公司 | 基于微服务架构的灰度发布方法、装置及电子设备 |
CN117170718B (zh) * | 2023-11-02 | 2024-02-02 | 绿城科技产业服务集团有限公司 | 基于微服务架构的灰度发布方法、装置及电子设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107276864B (zh) | 智能语音设备控制家电的方法、装置及系统 | |
CN114040024A (zh) | 基于网关的微服务灰度发布方法、装置、设备及存储介质 | |
CN107515764B (zh) | 应用程序页面打开方法、终端以及计算机可读存储介质 | |
CN109120684B (zh) | 信息化管理方法、装置、esb总线平台以及存储介质 | |
CN110011875B (zh) | 拨测方法、装置、设备及计算机可读存储介质 | |
CN108039173B (zh) | 语音信息输入方法、移动终端、系统以及可读存储介质 | |
CN111935802A (zh) | 设备配网方法、装置及计算机可读存储介质 | |
CN109408090B (zh) | 设备软件的升级方法、数据转化器及可读存储介质 | |
CN103152722A (zh) | 应用操作的控制方法及系统 | |
CN107172206A (zh) | 一种路由器升级方法及系统 | |
CN115525533A (zh) | 信息处理方法、装置、计算机设备及存储介质 | |
CN113691455B (zh) | 路由调度方法、装置、设备及可读存储介质 | |
CN108111496B (zh) | 为dubbo分布式应用暴露http服务的方法、装置及系统 | |
US8456671B2 (en) | Communication system, information storage device, management device, and terminal device | |
CN111061637B (zh) | 接口测试方法、接口测试装置及存储介质 | |
JP2005323093A (ja) | Webサーバを利用した遠隔操作制御プログラム | |
US20200137667A1 (en) | Method and apparatus for publishing information at wireless routing device end | |
CN111756817A (zh) | 设备发现方法、装置及计算机可读存储介质 | |
CN108156534B (zh) | 演示应用的生成方法、装置及计算机可读存储介质 | |
CN105426532A (zh) | 文件操作方法和装置 | |
EP3015990B1 (en) | Information processing device, and destination information updating method and program | |
CN111176622B (zh) | 对解决方案的语音技能进行统一管理的实现方法、管理系统及管理方法 | |
CN114500510A (zh) | 请求信息响应方法、装置、通信设备及存储介质 | |
CN109032651B (zh) | 应用更新方法、智能终端及计算机可读存储介质 | |
CN109298831B (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 |