CN110874227A - 实现于api网关的灰度发布的分流方法、系统和电子设备 - Google Patents
实现于api网关的灰度发布的分流方法、系统和电子设备 Download PDFInfo
- Publication number
- CN110874227A CN110874227A CN201810999480.5A CN201810999480A CN110874227A CN 110874227 A CN110874227 A CN 110874227A CN 201810999480 A CN201810999480 A CN 201810999480A CN 110874227 A CN110874227 A CN 110874227A
- Authority
- CN
- China
- Prior art keywords
- application information
- user request
- module
- forwarding
- uniform resource
- 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 59
- 238000004590 computer program Methods 0.000 claims description 13
- 230000015654 memory Effects 0.000 claims description 12
- 238000010586 diagram Methods 0.000 description 12
- 230000008569 process Effects 0.000 description 9
- 230000006870 function Effects 0.000 description 8
- 238000004891 communication Methods 0.000 description 7
- 238000012545 processing Methods 0.000 description 6
- 230000003287 optical effect Effects 0.000 description 4
- 230000004048 modification Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 238000010276 construction Methods 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 238000004806 packaging method and process Methods 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 241001270131 Agaricus moelleri Species 0.000 description 1
- 108010001267 Protein Subunits Proteins 0.000 description 1
- 235000014510 cooky Nutrition 0.000 description 1
- 238000005315 distribution function Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000012360 testing method Methods 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
Abstract
本公开提供了一种实现于API网关的灰度发布的分流方法,包括接收用户请求,确定是否存在与所述用户请求对应的应用信息,在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。本公开还提供了一种实现于API网关的灰度发布的分流系统、一种电子设备以及一种计算机可读介质。
Description
技术领域
本公开涉及互联网技术领域,更具体地,涉及一种实现于API网关的灰度发布的分流方法、系统和电子设备。
背景技术
灰度发布是指在软件发布过程中,能够平滑过渡的一种发布方式。例如,假设当前软件的版本有新旧两个版本,当用户向服务器发送该软件的请求消息时,服务器控制一部分用户继续使用旧版本,另一部分用户使用新版本。如果用户在使用新版本的过程中没有什么异常,那么逐渐扩大新版本的发布范围,最终把所有用户迁移到新版本。互联网产品迭代更新快,每一次升级都伴随着各种各样的风险。灰度发布可以保证整体系统的稳定,在初始灰度的时候可以发现、调整问题,以减小风险。
现有技术中,为了实现灰度发布,一般采用如下方法:1)通过修改cookie,使得调用端直接访问灰度或非灰度服务器;2)通过修改前端代理服务器的业务逻辑,通过配置灰度规则,使用户请求在前端代理服务器处实现分流。发明人在实现本发明的过程中,发现现有技术存在如下问题:现有技术中的方法的灰度发布的内容均耦合在业务系统中,开发或修改灰度逻辑非常复杂,并且由于前端代理服务器的灰度逻辑通常使用lua开发,造成开发人员学习成本高。
发明内容
有鉴于此,本公开提供了一种实现于API网关的灰度发布的分流方法、系统和电子设备。
本公开的一个方面提供了一种实现于API网关的灰度发布的分流方法,包括接收用户请求,确定是否存在与所述用户请求对应的应用信息,在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
根据本公开实施例,所述将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器包括,确定是否存在与所述应用信息对应的分流规则,在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器,在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
根据本公开实施例,所述方法还包括基于用户输入配置所述分流规则。
根据本公开实施例,所述方法还包括基于用户输入配置应用信息表,其中,所述确定是否存在与所述用户请求对应的应用信息包括,基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
根据本公开实施例,所述确定是否存在与所述用户请求对应的应用信息包括,获得所述用户请求中的统一资源定位符,确定与所述统一资源定位符对应的统一资源标识符,基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
本公开的另一个方面提供了一种实现于API网关的灰度发布的分流系统,包括用户请求接收模块、应用信息查询模块以及用户请求转发模块。用户请求接收模块,用于接收用户请求。应用信息查询模块,用于确定是否存在与所述用户请求对应的应用信息。用户请求转发模块,用于在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
根据本公开实施例,所述用户请求转发模块包括分流规则查询子模块、第一转发子模块以及第二转发子模块。分流规则查询子模块,用于确定是否存在与所述应用信息对应的分流规则。第一转发子模块,用于在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器。第二转发子模块,用于在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
根据本公开实施例,所述系统还包括分流规则配置模块,用于基于用户输入配置所述分流规则。
根据本公开实施例,所述系统还包括应用信息配置模块,用于基于用户输入配置应用信息表,其中,所述应用信息查询模块用于基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
根据本公开实施例,所述应用信息查询模块包括获得子模块、确定子模块以及查询子模块。获得子模块,用于获得所述用户请求中的统一资源定位符。确定子模块,用于确定与所述统一资源定位符对应的统一资源标识符。接口查询子模块,用于基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
本公开的另一个方面提供了一种电子设备,包括,至少一个处理器以及至少一个存储器,用于存储一个或多个计算机可读指令,其中,当所述一个或多个计算机可读指令被所述至少一个处理器执行时,使得所述处理器执行如上所述的方法。
本公开的另一个方面提供了一种计算机可读介质,其上存储有计算机可读指令,该指令被执行时使处理器执行如上所述的方法。
本公开的另一方面提供了一种计算机程序,所述计算机程序包括计算机可执行指令,所述指令在被执行时用于实现如上所述的方法。
本公开实施例的方法将灰度发布的分流实现在API网关,使得灰度发布的内容与业务解耦,简化配置过程,并且由于配置API网关的学习成本较低,便于开发人员应用。
附图说明
通过以下参照附图对本公开实施例的描述,本公开的上述以及其他目的、特征和优点将更为清楚,在附图中:
图1示意性示出了根据本公开实施例的分流方法的应用场景;
图2示意性示出了根据本公开实施例的实现于API网关的灰度发布的分流方法的流程图;
图3示意性示出了根据本公开实施例的将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器的流程图;
图4示意性示出了根据本公开实施例的分类方法的示意图;
图5示意性示出了根据本公开实施例的实现于API网关的灰度发布的分流系统的框图;以及
图6示意性示出了根据本公开实施例的适于实现分流方法和系统的计算机系统的方框图。
具体实施方式
以下,将参照附图来描述本公开的实施例。但是应该理解,这些描述只是示例性的,而并非要限制本公开的范围。在下面的详细描述中,为便于解释,阐述了许多具体的细节以提供对本公开实施例的全面理解。然而,明显地,一个或多个实施例在没有这些具体细节的情况下也可以被实施。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本公开的概念。
在此使用的术语仅仅是为了描述具体实施例,而并非意在限制本公开。在此使用的术语“包括”、“包含”等表明了所述特征、步骤、操作和/或部件的存在,但是并不排除存在或添加一个或多个其他特征、步骤、操作或部件。
在此使用的所有术语(包括技术和科学术语)具有本领域技术人员通常所理解的含义,除非另外定义。应注意,这里使用的术语应解释为具有与本说明书的上下文相一致的含义,而不应以理想化或过于刻板的方式来解释。
在使用类似于“A、B和C等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有A、B和C中至少一个的系统”应包括但不限于单独具有A、单独具有B、单独具有C、具有A和B、具有A和C、具有B和C、和/或具有A、B、C的系统等)。在使用类似于“A、B或C等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有A、B或C中至少一个的系统”应包括但不限于单独具有A、单独具有B、单独具有C、具有A和B、具有A和C、具有B和C、和/或具有A、B、C的系统等)。本领域技术人员还应理解,实质上任意表示两个或更多可选项目的转折连词和/或短语,无论是在说明书、权利要求书还是附图中,都应被理解为给出了包括这些项目之一、这些项目任一方、或两个项目的可能性。例如,短语“A或B”应当被理解为包括“A”或“B”、或“A和B”的可能性。
本公开的实施例提供了一种实现于API网关的灰度发布的分流方法,包括接收用户请求,确定是否存在与所述用户请求对应的应用信息,在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
图1示意性示出了根据本公开实施例的分流方法的应用场景。需要注意的是,图1所示仅为可以应用本公开实施例的系统架构的示例,以帮助本领域技术人员理解本公开的技术内容,但并不意味着本公开实施例不可以用于其他设备、系统、环境或场景。
如图1所示,根据该实施例的系统架构100可以包括终端设备101、102、103,网络104、包含API网关的分流服务器105、灰度服务器106以及非灰度服务器107。网络104用以在终端设备101、102、103和分流服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104以及分流服务器105与灰度服务器106或非灰度服务器107交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
灰度服务器106和非灰度服务器107可以是提供各种服务的服务器,例如对用户利用终端设备101、102、103所浏览的网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的用户请求等数据进行分析等处理,并将处理结果(例如根据用户请求获取或生成的网页、信息、或数据等)反馈给终端设备。
其中,非灰度服务器107可以是提供稳定版本的应用服务的服务器,灰度服务器106是提供灰度版本的应用服务的服务器,例如用于在小规模内测试新版本,以防止更新过程中带来的各种风险。
需要说明的是,本公开实施例所提供的实现于API网关的灰度发布的分流方法一般可以由分流服务器105执行。相应地,本公开实施例所提供的实现于API网关的灰度发布的分流系统一般可以设置于分裂服务器105中。本公开实施例所提供的实现于API网关的灰度发布的分流方法电可以由不同于分流服务器105且能够与终端设备101、102、103、灰度服务器106、非灰度服务器107和/或分流服务器105通信的服务器或服务器集群执行。相应地,本公开实施例所提供的实现于API网关的灰度发布的分流系统也可以设置于不同于分流服务器105且能够与终端设备101、102、103、灰度服务器106、非灰度服务器107和/或分流服务器105通信的服务器或服务器集群中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
图2示意性示出了根据本公开实施例的实现于API网关的灰度发布的分流方法的流程图。
如图2所示,该方法包括操作S210~S230。
在操作S210,接收用户请求。根据本公开实施例,API网关获得用户请求,请求访问某一应用对应的服务器,以获得该服务。
在操作S220,确定是否存在与所述用户请求对应的应用信息。根据本公开实施例,API网关通过查询相应的应用信息,可以确定用户所请求的应用是否存在。现有技术中的实现分流功能的分流模块集成在业务系统中,每个分流模块对应于一个应用,在确定用户请求对应的应用信息后,才会到达分流模块,因此,现有技术的分流模块并不会查询应用信息。本公开实施例的方法将分流功能设置在API网关中,与业务系统解耦,并且,通过查询独立的分流规则,可以实现对不同应用的分流。
在操作S230,在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
该方法将灰度发布的分流实现在API网关,使得灰度发布的内容与业务解耦,简化配置过程,并且由于配置API网关的学习成本较低,便于开发人员应用。
根据本公开实施例,在操作S230,所述将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器包括,确定是否存在与所述应用信息对应的分流规则,在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器,在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
下面结合图3对本公开实施例的方法进行说明。
图3示意性示出了根据本公开实施例的将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器的流程图。
如图3所示,该方法包括操作S310~S350。
在操作S310,确定是否存在与所述应用信息对应的分流规则。若存在,则执行操作S320,否则,直接跳转到操作S350。
在操作S320,获得分流规则。
在操作S330,判断是否满足分流规则。若满足,则执行操作S340,否则,执行操作S350。
在操作S340,将所述用户请求转发到灰度服务器。
在操作S350,将所述用户请求转发到非灰度服务器。
根据本公开实施例,所述方法还包括基于用户输入配置所述分流规则。
根据本公开实施例,所述方法还包括基于用户输入配置应用信息表,其中,所述确定是否存在与所述用户请求对应的应用信息包括,基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
下面结合图4对本公开实施例的方法进行说明。
图4示意性示出了根据本公开实施例的分类方法的示意图。
如图4所示,分流服务器105例如可以包括API网关模块、后台管理模块、应用信息模块以及分流规则模块。
后台管理模块,用于为管理员提供控制功能,例如配置应用信息或配置分流规则等。
API网关模块,用于处理用户请求,并将用户请求转发到相应的灰度服务器106或非灰度服务器107。
应用信息模块,用于存储应用信息,该些应用信息例如可以表示与该分流服务器连接,并能够通过API网关转发的应用服务器。
分流规则模块,用于存储分流规则,在确定应用信息后,可以根据分流规则模块中存储的分流规则,确定转发到灰度服务器106或者是非灰度服务器107。
具体地,在操作S410,管理员可以通过后台管理模块配置应用信息,并将其保存在应用信息模块。
在操作S420,应用信息模块向后台管理模块返回保存成功或失败的返回结果。
在操作S430,管理员可以通过后台管理模块配置分流规则,并将其保存在分流规则模块。
在操作S440,分流规则模块向后台管理模块返回保存成功或失败的返回结果。
应当注意的是,以上S410和S430随时可以发生,本公开实施例并不限定操作S410与S430的执行顺序,甚至,S410和S430可以发生在操作S450~480之后,以实现对已有应用信息或分流规则的修改。
在获得用户请求时,请求调用了API网关模块,则开始执行操作S450。
在操作S450,API网关模块向应用信息模块请求查询应用信息。
在操作S460,应用信息模块向API网关模块返回查询结果。
根据本公开实施例,所述确定是否存在与所述用户请求对应的应用信息包括,获得所述用户请求中的统一资源定位符(URL),确定与所述统一资源定位符对应的统一资源标识符(URI),基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
根据本公开实施例,在不存在应用信息的情况下,请求存在错误,无法调用所请求的应用服务器,流程结束。在存在应用信息的情况下,继续执行操作S470。
在操作S470,API网关模块向分流规则模块请求查询分流规则。
在操作S480,分流规则模块向API网关模块返回查询结果。
根据本公开实施例,在不存在分流规则的情况下,说明该应用当前并不需要灰度发布,直接将用户请求转发到非灰度服务器;在存在分流规则的情况下,根据分流规则,判断当前用户请求是否命中分流规则,若命中,则转发到灰度服务器,否则,转发到非灰度服务器,流程结束。
图5示意性示出了根据本公开实施例的实现于API网关的灰度发布的分流系统500的框图。
如图5所示,该实现于API网关的灰度发布的分流系统500包括用户请求接收模块510、应用信息查询模块520以及用户请求转发模块530。
用户请求接收模块510,例如执行上文参考图2描述的操作S210,用于接收用户请求。
应用信息查询模块520,例如执行上文参考图2描述的操作S220,用于确定是否存在与所述用户请求对应的应用信息。
用户请求转发模块530,例如执行上文参考图2描述的操作S230,用于在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
根据本公开实施例,所述用户请求转发模块包括分流规则查询子模块、第一转发子模块以及第二转发子模块。分流规则查询子模块,用于确定是否存在与所述应用信息对应的分流规则。第一转发子模块,用于在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器。第二转发子模块,用于在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
根据本公开实施例,所述系统还包括分流规则配置模块,用于基于用户输入配置所述分流规则。
根据本公开实施例,所述系统还包括应用信息配置模块,用于基于用户输入配置应用信息表,其中,所述应用信息查询模块用于基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
根据本公开实施例,所述应用信息查询模块包括获得子模块、确定子模块以及查询子模块。获得子模块,用于获得所述用户请求中的统一资源定位符。确定子模块,用于确定与所述统一资源定位符对应的统一资源标识符。接口查询子模块,用于基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
根据本公开的实施例的模块、子模块、单元、子单元中的任意多个、或其中任意多个的至少部分功能可以在一个模块中实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以被拆分成多个模块来实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以通过对电路进行集成或封装的任何其他的合理方式的硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,根据本公开实施例的模块、子模块、单元、子单元中的一个或多个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
例如,用户请求接收模块510、应用信息查询模块520、用户请求转发模块530、分流规则查询子模块、第一转发子模块、第二转发子模块、分流规则配置模块、应用信息配置模块、获得子模块、确定子模块以及接口查询子模块中的任意多个可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本公开的实施例,用户请求接收模块510、应用信息查询模块520、用户请求转发模块530、分流规则查询子模块、第一转发子模块、第二转发子模块、分流规则配置模块、应用信息配置模块、获得子模块、确定子模块以及接口查询子模块中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以通过对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,用户请求接收模块510、应用信息查询模块520、用户请求转发模块530、分流规则查询子模块、第一转发子模块、第二转发子模块、分流规则配置模块、应用信息配置模块、获得子模块、确定子模块以及接口查询子模块中的至少一个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
图6示意性示出了根据本公开实施例的适于实现分流方法和系统的计算机系统600的方框图。图6示出的计算机系统仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。图6示出的计算机系统可以实现为电子设备,包括至少一个处理器(例如处理器601)以及至少一个存储器(例如存储部分608)。
如图6所示,根据本公开实施例的计算机系统600包括处理器601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。处理器601例如可以包括通用微处理器(例如CPU)、指令集处理器和/或相关芯片组和/或专用微处理器(例如,专用集成电路(ASIC)),等等。处理器601还可以包括用于缓存用途的板载存储器。处理器601可以包括用于执行根据本公开实施例的方法流程的不同动作的单一处理单元或者是多个处理单元。
在RAM 603中,存储有系统600操作所需的各种程序和数据。处理器601、ROM 602以及RAM 603通过总线604彼此相连。处理器601通过执行ROM 602和/或RAM 603中的程序来执行根据本公开实施例的方法流程的各种操作。需要注意,所述程序也可以存储在除ROM 602和RAM 603以外的一个或多个存储器中。处理器601也可以通过执行存储在所述一个或多个存储器中的程序来执行根据本公开实施例的方法流程的各种操作。
根据本公开的实施例,系统600还可以包括输入/输出(I/O)接口605,输入/输出(I/O)接口605也连接至总线604。系统600还可以包括连接至I/O接口605的以下部件中的一项或多项:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
根据本公开的实施例,根据本公开实施例的方法流程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被处理器601执行时,执行本公开实施例的系统中限定的上述功能。根据本公开的实施例,上文描述的系统、设备、装置、模块、单元等可以通过计算机程序模块来实现。
本公开还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备/装置/系统中所包含的;也可以是单独存在,而未装配入该设备/装置/系统中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被执行时,实现根据本公开实施例的方法。
根据本公开的实施例,计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、有线、光缆、射频信号等等,或者上述的任意合适的组合。
例如,根据本公开的实施例,计算机可读介质可以包括上文描述的ROM 602和/或RAM 603和/或ROM 602和RAM 603以外的一个或多个存储器。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
本领域技术人员可以理解,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合或/或结合,即使这样的组合或结合没有明确记载于本公开中。特别地,在不脱离本公开精神和教导的情况下,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合。所有这些组合和/或结合均落入本公开的范围。
以上对本公开的实施例进行了描述。但是,这些实施例仅仅是为了说明的目的,而并非为了限制本公开的范围。尽管在以上分别描述了各实施例,但是这并不意味着各个实施例中的措施不能有利地结合使用。本公开的范围由所附权利要求及其等同物限定。不脱离本公开的范围,本领域技术人员可以做出多种替代和修改,这些替代和修改都应落在本公开的范围之内。
Claims (12)
1.一种实现于API网关的灰度发布的分流方法,包括:
接收用户请求;
确定是否存在与所述用户请求对应的应用信息;
在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
2.根据权利要求1所述的方法,其中,所述将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器包括:
确定是否存在与所述应用信息对应的分流规则;
在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器;
在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
3.根据权利要求2所述的方法,还包括基于用户输入配置所述分流规则。
4.根据权利要求1所述的方法,还包括基于用户输入配置应用信息表,其中,所述确定是否存在与所述用户请求对应的应用信息包括,基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
5.根据权利要求1所述的方法,其中,所述确定是否存在与所述用户请求对应的应用信息包括:
获得所述用户请求中的统一资源定位符;
确定与所述统一资源定位符对应的统一资源标识符;
基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
6.一种实现于API网关的灰度发布的分流系统,包括:
用户请求接收模块,用于接收用户请求;
应用信息查询模块,用于确定是否存在与所述用户请求对应的应用信息;
用户请求转发模块,用于在存在与所述用户请求对应的应用信息的情况下,将所述用户请求转发到与所述应用信息对应的灰度或非灰度服务器。
7.根据权利要求6所述的系统,其中,所述用户请求转发模块包括:
分流规则查询子模块,用于确定是否存在与所述应用信息对应的分流规则;
第一转发子模块,用于在存在所述分流规则的情况下,基于所述分流规则,将所述用户请求转发到灰度服务器或非灰度服务器;
第二转发子模块,用于在不存在所述分流规则的情况下,将所述用户请求转发到非灰度服务器。
8.根据权利要求7所述的系统,还包括:
分流规则配置模块,用于基于用户输入配置所述分流规则。
9.根据权利要求6所述的系统,还包括应用信息配置模块,用于基于用户输入配置应用信息表,其中,所述应用信息查询模块用于基于所述应用信息表,查询是否存在与所述用户请求对应的应用信息。
10.根据权利要求6所述的系统,其中,所述应用信息查询模块包括:
获得子模块,用于获得所述用户请求中的统一资源定位符;
确定子模块,用于确定与所述统一资源定位符对应的统一资源标识符;
接口查询子模块,用于基于所述统一资源标识符,调用按统一资源标识符查询应用信息的接口,获得返回值,其中,所述返回值包括与所述统一资源标识符对应的应用信息,或者,表示不存在与所述统一资源标识符对应的应用信息的特定值。
11.一种电子设备,包括:
一个或多个处理器;
存储器,用于存储一个或多个计算机程序,
其中,当一个或多个计算机程序被一个或多个处理器执行时,使得一个或多个处理器实现权利要求1至5中任一项的方法。
12.一种计算机可读介质,其上存储有可执行指令,该指令被处理器执行时使处理器实现权利要求1至5中任一项的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810999480.5A CN110874227A (zh) | 2018-08-29 | 2018-08-29 | 实现于api网关的灰度发布的分流方法、系统和电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810999480.5A CN110874227A (zh) | 2018-08-29 | 2018-08-29 | 实现于api网关的灰度发布的分流方法、系统和电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110874227A true CN110874227A (zh) | 2020-03-10 |
Family
ID=69714962
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810999480.5A Pending CN110874227A (zh) | 2018-08-29 | 2018-08-29 | 实现于api网关的灰度发布的分流方法、系统和电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110874227A (zh) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111431746A (zh) * | 2020-03-20 | 2020-07-17 | 杭州有赞科技有限公司 | 一种api网关迁移方法及系统 |
CN112073320A (zh) * | 2020-11-12 | 2020-12-11 | 深圳壹账通智能科技有限公司 | 基于云网关的api灰度发布方法、装置及计算机设备 |
CN112632430A (zh) * | 2020-12-28 | 2021-04-09 | 四川新网银行股份有限公司 | 一种实现渠道用户在h5页面中访问灰度环境api服务的方法 |
CN112685287A (zh) * | 2020-11-30 | 2021-04-20 | 青岛海尔科技有限公司 | 产品数据的测试方法、装置、存储介质及电子装置 |
CN114265607A (zh) * | 2022-03-03 | 2022-04-01 | 杭州朗澈科技有限公司 | 一种灰度发布方法、系统、电子设备和存储介质 |
CN114422440A (zh) * | 2022-03-28 | 2022-04-29 | 北京沃丰时代数据科技有限公司 | 灰度发布方法、装置、电子设备及存储介质 |
CN114650293A (zh) * | 2020-12-17 | 2022-06-21 | 中移(苏州)软件技术有限公司 | 一种流量分流的方法、装置、终端和计算机存储介质 |
CN116033015A (zh) * | 2022-12-29 | 2023-04-28 | 联通智网科技股份有限公司 | 流量切分方法和装置 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103176790A (zh) * | 2011-12-26 | 2013-06-26 | 阿里巴巴集团控股有限公司 | 应用发布方法和系统 |
CN103905495A (zh) * | 2012-12-27 | 2014-07-02 | 腾讯科技(深圳)有限公司 | 一种应用的同步方法及后台服务器 |
CN105450461A (zh) * | 2014-06-05 | 2016-03-30 | 阿里巴巴集团控股有限公司 | 一种分流方法及网络设备 |
CN107145347A (zh) * | 2017-04-27 | 2017-09-08 | 努比亚技术有限公司 | 一种应用灰度发布方法、设备及存储介质 |
CN108319468A (zh) * | 2017-01-16 | 2018-07-24 | 北京京东尚科信息技术有限公司 | 灰度发布方法、装置、系统及电子设备 |
-
2018
- 2018-08-29 CN CN201810999480.5A patent/CN110874227A/zh active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103176790A (zh) * | 2011-12-26 | 2013-06-26 | 阿里巴巴集团控股有限公司 | 应用发布方法和系统 |
CN103905495A (zh) * | 2012-12-27 | 2014-07-02 | 腾讯科技(深圳)有限公司 | 一种应用的同步方法及后台服务器 |
CN105450461A (zh) * | 2014-06-05 | 2016-03-30 | 阿里巴巴集团控股有限公司 | 一种分流方法及网络设备 |
CN108319468A (zh) * | 2017-01-16 | 2018-07-24 | 北京京东尚科信息技术有限公司 | 灰度发布方法、装置、系统及电子设备 |
CN107145347A (zh) * | 2017-04-27 | 2017-09-08 | 努比亚技术有限公司 | 一种应用灰度发布方法、设备及存储介质 |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111431746A (zh) * | 2020-03-20 | 2020-07-17 | 杭州有赞科技有限公司 | 一种api网关迁移方法及系统 |
CN111431746B (zh) * | 2020-03-20 | 2022-05-31 | 杭州有赞科技有限公司 | 一种api网关迁移方法及系统 |
CN112073320A (zh) * | 2020-11-12 | 2020-12-11 | 深圳壹账通智能科技有限公司 | 基于云网关的api灰度发布方法、装置及计算机设备 |
CN112685287A (zh) * | 2020-11-30 | 2021-04-20 | 青岛海尔科技有限公司 | 产品数据的测试方法、装置、存储介质及电子装置 |
CN112685287B (zh) * | 2020-11-30 | 2023-11-28 | 青岛海尔科技有限公司 | 产品数据的测试方法、装置、存储介质及电子装置 |
CN114650293A (zh) * | 2020-12-17 | 2022-06-21 | 中移(苏州)软件技术有限公司 | 一种流量分流的方法、装置、终端和计算机存储介质 |
CN114650293B (zh) * | 2020-12-17 | 2024-02-23 | 中移(苏州)软件技术有限公司 | 一种流量分流的方法、装置、终端和计算机存储介质 |
CN112632430A (zh) * | 2020-12-28 | 2021-04-09 | 四川新网银行股份有限公司 | 一种实现渠道用户在h5页面中访问灰度环境api服务的方法 |
CN114265607A (zh) * | 2022-03-03 | 2022-04-01 | 杭州朗澈科技有限公司 | 一种灰度发布方法、系统、电子设备和存储介质 |
CN114422440A (zh) * | 2022-03-28 | 2022-04-29 | 北京沃丰时代数据科技有限公司 | 灰度发布方法、装置、电子设备及存储介质 |
CN116033015A (zh) * | 2022-12-29 | 2023-04-28 | 联通智网科技股份有限公司 | 流量切分方法和装置 |
CN116033015B (zh) * | 2022-12-29 | 2024-03-12 | 联通智网科技股份有限公司 | 流量切分方法和装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110874227A (zh) | 实现于api网关的灰度发布的分流方法、系统和电子设备 | |
CN108319468B (zh) | 灰度发布方法、装置、系统及电子设备 | |
CN110120917B (zh) | 基于内容的路由方法及装置 | |
CN111913738B (zh) | 访问请求的处理方法、装置、计算设备和介质 | |
CN107656768B (zh) | 控制页面跳转的方法及其系统 | |
CN109729040B (zh) | 协议的选择的方法、设备以及计算机可读介质 | |
WO2019015272A1 (zh) | 信息处理方法和装置 | |
CN109992406B (zh) | 图片请求方法、响应图片请求的方法及客户端 | |
CN110888696A (zh) | 页面展示方法及其系统、计算机系统及计算机可读介质 | |
CN111125107A (zh) | 数据处理方法、装置、电子设备和介质 | |
CN113434241A (zh) | 页面跳转方法及装置 | |
US11463549B2 (en) | Facilitating inter-proxy communication via an existing protocol | |
CN111783005B (zh) | 显示网页的方法、装置和系统、计算机系统和介质 | |
CN113282589A (zh) | 一种数据获取方法和装置 | |
CN110708238B (zh) | 用于处理信息的方法和装置 | |
CN111866211A (zh) | 应用于终端的网络访问方法、装置、终端和介质 | |
CN111818179A (zh) | 用户请求的处理方法、装置、计算设备和介质 | |
CN111953718A (zh) | 一种页面调试方法和装置 | |
US20230088115A1 (en) | Generating early hints informational responses at an intermediary server | |
CN112688982B (zh) | 一种用户请求处理方法和装置 | |
CN110278133B (zh) | 由服务器执行的检查方法、装置、计算设备以及介质 | |
CN113596164A (zh) | 数据访问方法、装置、系统、设备和介质 | |
CN109213815B (zh) | 控制执行次数的方法、装置、服务器终端以及可读介质 | |
CN112882895A (zh) | 健康检查方法、装置、计算机系统及可读存储介质 | |
CN111580882A (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 | ||
CB02 | Change of applicant information |
Address after: Room 221, 2 / F, block C, 18 Kechuang 11th Street, Daxing District, Beijing, 100176 Applicant after: Jingdong Technology Holding Co.,Ltd. Address before: Room 221, 2 / F, block C, 18 Kechuang 11th Street, Daxing District, Beijing, 100176 Applicant before: JINGDONG DIGITAL TECHNOLOGY HOLDINGS Co.,Ltd. |
|
CB02 | Change of applicant information |