CN112506559A - 基于网关的灰度发布方法、装置、电子设备及存储介质 - Google Patents

基于网关的灰度发布方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN112506559A
CN112506559A CN202011465923.6A CN202011465923A CN112506559A CN 112506559 A CN112506559 A CN 112506559A CN 202011465923 A CN202011465923 A CN 202011465923A CN 112506559 A CN112506559 A CN 112506559A
Authority
CN
China
Prior art keywords
request
application
gateway
program package
version program
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
CN202011465923.6A
Other languages
English (en)
Other versions
CN112506559B (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.)
China Merchants Finance Technology Co Ltd
Original Assignee
China Merchants Finance 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 China Merchants Finance Technology Co Ltd filed Critical China Merchants Finance Technology Co Ltd
Priority to CN202011465923.6A priority Critical patent/CN112506559B/zh
Publication of CN112506559A publication Critical patent/CN112506559A/zh
Application granted granted Critical
Publication of CN112506559B publication Critical patent/CN112506559B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Abstract

本发明涉及软件更新技术,揭露了一种基于网关的灰度发布方法,包括:利用网关拦截应用的用户端向服务端传输的数据,得到请求数据;获取用户的角色信息,并根据角色信息修改所述请求数据,得到改进请求;利用网关将改进请求发送至所述应用的新版本程序包及旧版本程序包中,并利用新版本程序包及旧版本程序包对所述改进请求的进行分析,得到响应数据;利用响应数据对应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将应用的旧版本程序包更新为新版本程序包。本发明还提出了基于网关的灰度发布装置、设备及计算机可读存储介质。本发明能够逐渐进行应用的更新,以减少更新产生的技术问题。

Description

基于网关的灰度发布方法、装置、电子设备及存储介质
技术领域
本发明涉及软件更新技术领域,尤其涉及一种基于网关的灰度发布方法、装置、电子设备及计算机可读存储介质。
背景技术
随着时代的发展,各种产品,如各种应用程序更新换代成为必不可少的工作,然而在应用程序更换或更新时,如果变动过大,或更新出现技术问题,都会大大影响用户的使用体验,甚至产生重大操作事故,影响用户工作效率。
发明内容
本发明提供一种基于网关的灰度发布方法、装置、电子设备及计算机可读存储介质,目的在于逐渐进行应用的更新,以减少更新产生的技术问题。
为实现上述目的,本发明提供的一种基于网关的灰度发布方法,包括:
利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
可选的,所述利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中之前,所述方法还包括:
对所述应用的新版本程序包中不同的功能块进行分布式存储,得到存储编号;
利用所述存储编号,将所述功能块进行灰度排序,得到灰度顺序表,并利用所述灰度顺序表构建灰度策略。
可选的,所述利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包,包括:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果;
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包;
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
可选的,所述利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求,包括:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;
根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;
利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
可选的,所述利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据,包括:
根据所述改进请求中的请求地址,利用所述网关将所述改进请求中的请求内容传输至所述应用的旧版本程序包中的各个功能块,得到旧响应数据;
根据所述灰度策略,将所述请求内容从所述应用的旧版本服务中各个旧功能块逐一转移到所述应用的新版本服务对应的新功能块中,得到新响应数据;
整合所述旧响应数据及所述新响应数据得到响应数据。
为解决上述问题,本发明实施例还提供一种基于网关的灰度发布装置,所述装置包括:
请求获取模块,用于利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
请求修改模块,用于利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
响应获取模块,用于利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
灰度发布模块,用于利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
可选的,所述灰度发布模块具体用于执行:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果;
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包;
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
可选的,所述请求修改模块具体用于:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;
根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;
利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
为了解决上述问题,本发明还提供一种电子设备,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序指令,所述计算机程序指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述所述的基于网关的灰度发布方法。
为了解决上述问题,本发明还提供一种计算机可读存储介质,包括存储数据区和存储程序区,存储数据区存储创建的数据,存储程序区存储有计算机程序;其中,所述计算机程序被处理器执行时实现上述所述的基于网关的灰度发布方法。
本发明实施例利用网关将应用前端发送至后台服务的请求数据进行拦截,根据用户的版本信息,更改所述请求数据中的请求地址,得到改进请求,并利用网关使所述改进请求发送至所述应用的后台服务中,使得本发明根据不同用版本的应用开始进行灰度发布。根据预构建的灰度策略,利用服务网格,逐渐将改进请求从旧后台服务的功能块上转移到新后台服务的对应功能块上,并且每转移依次,对新功能块产生响应数据进行性能测试,使得应用更新实现实时检测。总之,本发明目的在于逐渐进行应用的更新,以减少更新产生的技术问题。
附图说明
图1为本发明一实施例提供的基于网关的灰度发布方法的流程示意图;
图2为本发明一实施例提供的基于网关的灰度发布装置的模块示意图;
图3为本发明一实施例提供的实现基于网关的灰度发布方法的电子设备的内部结构示意图;
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本申请实施例提供一种基于网关的灰度发布方法。所述基于网关的灰度发布方法的执行主体包括但不限于服务端、终端等能够被配置为执行本申请实施例提供的该方法的电子设备中的至少一种。换言之,所述基于网关的灰度发布方法可以由安装在终端设备或服务端设备的软件或硬件来执行,所述软件可以是区块链平台。所述服务端包括但不限于:单台服务器、服务器集群、云端服务器或云端服务器集群等。
参照图1所示,为本发明一实施例提供的基于网关的灰度发布方法的流程示意图。在本实施例中,所述基于网关的灰度发布方法包括:
S1、利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据。
本发明实施例中,所述待更新的应用为需要更新版本的应用程序,例如,应用程序A增加或者改进了几个功能,则所述应用程序A为待更新的应用。本发明实施例利用预构建的网关内部的http协议拦截所述应用的用户端向服务端发送的请求数据,并将所述请求数据进行存储。其中,所述用户端是指安装应用的用户手机、电脑等,以及所述服务端是指提供应用更新及下载功能的服务平台。所述网关是一种网络互连设备,用于在不同的通信协议、数据格式或语言,甚至体系结构完全不同的两种系统之间传递数据。本发明实施例利用所述网关传递所述应用的所述用户端与所述服务端之间的数据。
进一步地,本发明实施例中,所述请求数据可以包括,但不限于,对资源的请求地址、请求方法、请求内容、资源的标识符及使用的协议等。所述服务端会根据所述请求数据产生对应的响应数据。
S2、利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求。
为保证所述应用的用户能够从所述应用的各个版本开始进行版本更新,本发明实施例中利用所述应用的用户管理平台获取各个用户的角色信息。其中,所述角色信息包括,但不仅限于,每个用户的账户ID信息及所述账户ID对应的应用的版本信息等。
详细地,本发明实施例中,所述根据所述角色信息修改所述请求数据,得到改进请求,包括:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
本发明实施例利用登录账号密码与预存储的校验账号密码相验证,当验证通过时,获取用户的角色信息,并利用所述网关,根据所述角色信息产生一个缓存空间session,根据所述缓存空间的身份标识号session_id,获取所述缓存空间中的验证令牌token,所述验证令牌token中含有所述用户对应应用的服务端旧版本程序包的地址信息及所述用户的登录账号密码,可以时刻验证密码信息,保持网关畅通,并利用所述服务端旧版本程序包的地址信息,更改拦截获取的所述请求数据中的请求地址,得到所述改进请求。
S3、利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据。
本发明实施例中,所述新版本程序包是刚发布的待更新的版本,所述旧版本程序包是以前发布的,已经又部分用户使用过的版本。其中,所述旧版本程序包包含了以前发布过的所有版本。本发明实施例中,所述灰度策略为运营团队构建的一种描述多阶段灰度发布过程的请求数据分发规则。
详细地,本发明实施例中,所述S3,包括:
根据所述改进请求中的请求地址,利用所述网关将所述改进请求中的请求内容传输至所述应用的旧版本程序包的各个功能块,得到旧响应数据;根据所述灰度策略,将所述请求内容从所述应用的旧版本程序包中各个旧功能块逐一转移到所述应用的新版本程序包中对应的新功能块,得到新响应数据;整合所述旧响应数据及所述新响应数据得到响应数据。
本发明实施例根据改进请求中的请求地址,利用所述网关,将改进请求中的请求内容,发送至所述用户角色对应版本程序包中的各个旧功能块上,根据所述旧功能块产生旧响应数据。根据所述灰度策略,将发送到旧功能块上的请求内容转移到新版本程序包中对应的新功能块上,使得新功能块产生新响应数据。本发明实施例中所述旧响应数据及所述新响应数据统称为响应数据。
进一步的,本发明实施例中,所述利用所述网关将所述改进请求发送至所述后台服务中所述应用的新版本服务及旧版本服务中之前,所述方法还包括:
对所述应用的新版本程序包中不同的新功能块进行分布式存储,得到存储编号;利用所述存储编号,将所述新功能块进行灰度排序,得到灰度顺序表,并利用所述灰度顺序表构建灰度策略。
本发明实施例利用分布式存储算法可以将各个所述新功能块进行编号存储,得到所述存储编号,再根据运营人员预设置的更新计划,将旧功能块与新功能块设置的更新关系,构建灰度发布的灰度顺序表,利用所述灰度顺序表构建所述灰度策略。
S4、利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
本发明实施例根据所述灰度策略中灰度顺序表的更新阶段顺序进行应用的更新,当判断指定阶段的性能测试结果为正常后,进行下一阶段的新功能块替换旧功能块的过程,当各个阶段的性能测试全部合格,完成整个应用的灰度发布过程。
详细地,本发明实施例中,所述S4,包括:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果。
本发明实施例,对所述响应数据产生的响应界面进行操作,可以根据预构建的测试用例进行性能测试,检查新版本的指定功能块有无漏洞,此外,还可以根据用户的使用情况,反馈使用体验,对所述指定功能块进行修改。
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包。
当所述检测结果为正常时,根据所述灰度顺序表,将所述指定功能块的下一阶段功能块开始替换,当所述下一阶段功能块替换完成时,对所述下一阶段功能块进行响应数据的性能检测。
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
本发明实施例,完成所述步骤A至步骤C的操作可以完成灰度发布的过程,并保证及时检测出应用新版本后台服务中的漏洞。
本发明实施例利用网关将应用前端发送至后台服务的请求数据进行拦截,根据用户的版本信息,更改所述请求数据中的请求地址,得到改进请求,并利用网关使所述改进请求发送至所述应用的后台服务中,使得本发明根据不同用版本的应用开始进行灰度发布。根据预构建的灰度策略,利用服务网格,逐渐将改进请求从旧后台服务的功能块上转移到新后台服务的对应功能块上,并且每转移依次,对新功能块产生响应数据进行性能测试,使得应用更新实现实时检测。因此,本发明实现了逐渐进行应用的更新,以减少更新产生的技术问题。
如图2所示,是本发明基于网关的灰度发布装置的模块示意图。
本发明所述基于网关的灰度发布装置100可以安装于电子设备中。根据实现的功能,所述基于网关的灰度发布装置可以包括请求获取模块101、请求修改模块102、响应获取模块103、灰度发布模块104。本发明所述模块也可以称之为单元,是指一种能够被电子设备处理器所执行,并且能够完成固定功能的一系列计算机程序段,其存储在电子设备的存储器中。
在本实施例中,关于各模块/单元的功能如下:
所述请求获取模块101,用于利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据。
本发明实施例中,所述待更新的应用为需要更新版本的应用程序,例如,应用程序A增加或者改进了几个功能,则所述应用程序A为待更新的应用。本发明实施例利用预构建的网关内部的http协议拦截所述应用的用户端向服务端发送的请求数据,并将所述请求数据进行存储。其中,所述用户端是指安装应用的用户手机、电脑等,以及所述服务端是指提供应用更新及下载功能的服务平台。所述网关是一种网络互连设备,用于在不同的通信协议、数据格式或语言,甚至体系结构完全不同的两种系统之间传递数据。本发明实施例利用所述网关传递所述应用的所述用户端与所述服务端之间的数据。
进一步地,本发明实施例中,所述请求数据可以包括,但不限于,对资源的请求地址、请求方法、请求内容、资源的标识符及使用的协议等。所述服务端会根据所述请求数据产生对应的响应数据。
所述请求修改模块102,用于利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求。
为保证所述应用的用户能够从所述应用的各个版本开始进行版本更新,本发明实施例中利用所述应用的用户管理平台获取各个用户的角色信息。其中,所述角色信息包括,但不仅限于,每个用户的账户ID信息及所述账户ID对应的应用的版本信息等。
详细地,本发明实施例中,所述请求修改模块102具体用于:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
本发明实施例利用登录账号密码与预存储的校验账号密码相验证,当验证通过时,获取用户的角色信息,并利用所述网关,根据所述角色信息产生一个缓存空间session,根据所述缓存空间的身份标识号session_id,获取所述缓存空间中的验证令牌token,所述验证令牌token中含有所述用户对应应用的服务端旧版本程序包的地址信息及所述用户的登录账号密码,可以时刻验证密码信息,保持网关畅通,并利用所述服务端旧版本程序包的地址信息,更改拦截获取的所述请求数据中的请求地址,得到所述改进请求。
所述响应获取模块103,用于利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据。本发明实施例中,所述新版本程序包是刚发布的待更新的版本,所述旧版本程序包是以前发布的,已经又部分用户使用过的版本。其中,所述旧版本程序包包含了以前发布过的所有版本。本发明实施例中,所述灰度策略为运营团队构建的一种描述多阶段灰度发布过程的请求数据分发规则。
详细地,本发明实施例中,所述响应获取模块103具体用于:
根据所述改进请求中的请求地址,利用所述网关将所述改进请求中的请求内容传输至所述应用的旧版本程序包的各个功能块,得到旧响应数据;根据所述灰度策略,将所述请求内容从所述应用的旧版本程序包中各个旧功能块逐一转移到所述应用的新版本程序包中对应的新功能块,得到新响应数据;整合所述旧响应数据及所述新响应数据得到响应数据。
本发明实施例根据改进请求中的请求地址,利用所述网关,将改进请求中的请求内容,发送至所述用户角色对应版本程序包中的各个旧功能块上,根据所述旧功能块产生旧响应数据。根据所述灰度策略,将发送到旧功能块上的请求内容转移到新版本程序包中对应的新功能块上,使得新功能块产生新响应数据。本发明实施例中所述旧响应数据及所述新响应数据统称为响应数据。
进一步的,本发明实施例中,所述利用所述网关将所述改进请求发送至所述后台服务中所述应用的新版本服务及旧版本服务中之前,所述方法还包括:
对所述应用的新版本程序包中不同的新功能块进行分布式存储,得到存储编号;利用所述存储编号,将所述新功能块进行灰度排序,得到灰度顺序表,并利用所述灰度顺序表构建灰度策略。
本发明实施例利用分布式存储算法可以将各个所述新功能块进行编号存储,得到所述存储编号,再根据运营人员预设置的更新计划,将旧功能块与新功能块设置的更新关系,构建灰度发布的灰度顺序表,利用所述灰度顺序表构建所述灰度策略。
所述灰度发布模块104,用于利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
本发明实施例根据所述灰度策略中灰度顺序表的更新阶段顺序进行应用的更新,当判断指定阶段的性能测试结果为正常后,进行下一阶段的新功能块替换旧功能块的过程,当各个阶段的性能测试全部合格,完成整个应用的灰度发布过程。
详细地,本发明实施例中,所述灰度发布模块104具体用于:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果。
本发明实施例,对所述响应数据产生的响应界面进行操作,可以根据预构建的测试用例进行性能测试,检查新版本的指定功能块有无漏洞,此外,还可以根据用户的使用情况,反馈使用体验,对所述指定功能块进行修改。
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包。
当所述检测结果为正常时,根据所述灰度顺序表,将所述指定功能块的下一阶段功能块开始替换,当所述下一阶段功能块替换完成时,对所述下一阶段功能块进行响应数据的性能检测。
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
本发明实施例,完成所述步骤A至步骤C的操作可以完成灰度发布的过程,并保证及时检测出应用新版本后台服务中的漏洞。
如图3所示,是本发明实现基于网关的灰度发布方法的电子设备的结构示意图。
所述电子设备1可以包括处理器10、存储器11和总线,还可以包括存储在所述存储器11中并可在所述处理器10上运行的计算机程序,如基于网关的灰度发布程序12。
其中,所述存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、移动硬盘、多媒体卡、卡型存储器(例如:SD或DX存储器等)、磁性存储器、磁盘、光盘等。所述存储器11在一些实施例中可以是电子设备1的内部存储单元,例如该电子设备1的移动硬盘。所述存储器11在另一些实施例中也可以是电子设备1的外部存储设备,例如电子设备1上配备的插接式移动硬盘、智能存储卡(Smart Media Card,SMC)、安全数字(SecureDigital,SD)卡、闪存卡(Flash Card)等。进一步地,所述存储器11还可以既包括电子设备1的内部存储单元也包括外部存储设备。所述存储器11不仅可以用于存储安装于电子设备1的应用软件及各类数据,例如基于网关的灰度发布程序12的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
所述处理器10在一些实施例中可以由集成电路组成,例如可以由单个封装的集成电路所组成,也可以是由多个相同功能或不同功能封装的集成电路所组成,包括一个或者多个中央处理器(Central Processing unit,CPU)、微处理器、数字处理芯片、图形处理器及各种控制芯片的组合等。所述处理器10是所述电子设备的控制核心(Control Unit),利用各种接口和线路连接整个电子设备的各个部件,通过运行或执行存储在所述存储器11内的程序或者模块(例如执行基于网关的灰度发布程序等),以及调用存储在所述存储器11内的数据,以执行电子设备1的各种功能和处理数据。
所述总线可以是外设部件互连标准(peripheral component interconnect,简称PCI)总线或扩展工业标准结构(extended industry standard architecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。所述总线被设置为实现所述存储器11以及至少一个处理器10等之间的连接通信。
图3仅示出了具有部件的电子设备,本领域技术人员可以理解的是,图3示出的结构并不构成对所述电子设备1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
例如,尽管未示出,所述电子设备1还可以包括给各个部件供电的电源(比如电池),优选地,电源可以通过电源管理装置与所述至少一个处理器10逻辑相连,从而通过电源管理装置实现充电管理、放电管理、以及功耗管理等功能。电源还可以包括一个或一个以上的直流或交流电源、再充电装置、电源故障检测电路、电源转换器或者逆变器、电源状态指示器等任意组件。所述电子设备1还可以包括多种传感器、蓝牙模块、Wi-Fi模块等,在此不再赘述。
进一步地,所述电子设备1还可以包括网络接口,可选地,所述网络接口可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该电子设备1与其他电子设备之间建立通信连接。
可选地,该电子设备1还可以包括用户接口,用户接口可以是显示器(Display)、输入单元(比如键盘(Keyboard)),可选地,用户接口还可以是标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在电子设备1中处理的信息以及用于显示可视化的用户界面。
应该了解,所述实施例仅为说明之用,在专利申请范围上并不受此结构的限制。
所述电子设备1中的所述存储器11存储的基于网关的灰度发布程序12是多个计算机程序的组合,在所述处理器10中运行时,可以实现:
利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
进一步地,所述电子设备1集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。所述计算机可读存储介质可以是易失性的,也可以是非易失性的。例如,所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)。
进一步地,所述计算机可用存储介质可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序等;存储数据区可存储根据区块链节点的使用所创建的数据等。
本发明还提供一种计算机可读存储介质,所述可读存储介质存储有计算机程序,所述计算机程序在被电子设备的处理器所执行时,可以实现:
利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能块的形式实现。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图表记视为限制所涉及的权利要求。
本发明所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。系统权利要求中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。

Claims (10)

1.一种基于网关的灰度发布方法,其特征在于,所述方法包括:
利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
2.如权利要求1所述的基于网关的灰度发布方法,其特征在于,所述利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中之前,所述方法还包括:
对所述应用的新版本程序包中不同的功能块进行分布式存储,得到存储编号;
利用所述存储编号,将所述功能块进行灰度排序,得到灰度顺序表,并利用所述灰度顺序表构建灰度策略。
3.如权利要求2所述的基于网关的灰度发布方法,其特征在于,所述利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包,包括:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果;
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包;
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
4.如权利要求1所述的基于网关的灰度发布方法,其特征在于,所述利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求,包括:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;
根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;
利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
5.如权利要求1至4中任意一项所述的基于网关的灰度发布方法,其特征在于,所述利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据,包括:
根据所述改进请求中的请求地址,利用所述网关将所述改进请求中的请求内容传输至所述应用的旧版本程序包中的各个功能块,得到旧响应数据;
根据所述灰度策略,将所述请求内容从所述应用的旧版本服务中各个旧功能块逐一转移到所述应用的新版本服务对应的新功能块中,得到新响应数据;
整合所述旧响应数据及所述新响应数据得到响应数据。
6.一种基于网关的灰度发布装置,其特征在于,所述装置包括:
请求获取模块,用于利用预构建的网关拦截待更新的应用的用户端向服务端传输的数据,得到请求数据;
请求修改模块,用于利用所述应用的用户管理平台,获取用户的角色信息,并根据所述角色信息修改所述请求数据,得到改进请求;
响应获取模块,用于利用所述网关将所述改进请求发送至所述服务端中所述应用的新版本程序包及旧版本程序包中,并根据预构建的灰度策略,利用所述新版本程序包及旧版本程序包对所述改进请求的进行分析,得到的响应数据;
灰度发布模块,用于利用所述响应数据对所述应用进行程序性能检测,当检测结果为合格时,根据所述灰度策略,将所述应用的旧版本程序包更新为所述新版本程序包。
7.如权利要求6所述的基于网关的灰度发布装置,其特征在于,所述灰度发布模块具体用于:
步骤A:将所述响应数据导入所述用户端,得到响应界面,对所述响应界面进行操作测试,得到性能检测结果;
步骤B:当所述检测结果为正常时,根据所述灰度策略中预设的灰度顺序表,逐一利用新版本程序包中的不同功能块代替旧版本程序包中对应的功能块,并返回步骤A继续对所述响应数据进行性能检测,直至所述新版本程序包完全替换所述旧版本程序包;
步骤C、当所述检测结果为异常时,修改所述响应数据对应的新版本程序包中的功能块,并重新返回步骤A继续对所述响应数据进行性能检测。
8.如权利要求6所述的基于网关的灰度发布装置,其特征在于,所述请求修改模块具体用于:
利用所述应用的用户管理平台,对用户输入的登录账号密码进行校验,当校验通过时,利用所述网关产生缓存空间;
根据所述缓存空间的身份标识号,获取所述缓存空间中的验证令牌;
利用所述验证令牌,修改所述请求数据中的请求地址,得到改进请求。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序指令,所述计算机程序指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至5中任一项所述基于网关的灰度发布方法。
10.一种计算机可读存储介质,包括存储数据区和存储程序区,存储数据区存储创建的数据,存储程序区存储有计算机程序;其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5中任一项所述的基于网关的灰度发布方法。
CN202011465923.6A 2020-12-14 2020-12-14 基于网关的灰度发布方法、装置、电子设备及存储介质 Active CN112506559B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011465923.6A CN112506559B (zh) 2020-12-14 2020-12-14 基于网关的灰度发布方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011465923.6A CN112506559B (zh) 2020-12-14 2020-12-14 基于网关的灰度发布方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN112506559A true CN112506559A (zh) 2021-03-16
CN112506559B CN112506559B (zh) 2024-02-06

Family

ID=74972883

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011465923.6A Active CN112506559B (zh) 2020-12-14 2020-12-14 基于网关的灰度发布方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN112506559B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113138880A (zh) * 2021-04-09 2021-07-20 浙商银行股份有限公司 区块链系统灰度发布方法、装置、设备及存储介质
CN113138774A (zh) * 2021-05-11 2021-07-20 中国工商银行股份有限公司 灰度发布方法、装置、电子设备、介质和程序产品
CN113542387A (zh) * 2021-07-09 2021-10-22 平安银行股份有限公司 系统发布方法、装置、电子设备及存储介质
CN113946353A (zh) * 2021-09-30 2022-01-18 北京五八信息技术有限公司 一种数据处理方法、装置、电子设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2019029457A1 (zh) * 2017-08-07 2019-02-14 阿里巴巴集团控股有限公司 客户端上应用程序的更新方法、装置及电子设备
CN109376322A (zh) * 2018-09-07 2019-02-22 平安科技(深圳)有限公司 一种灰度版本页面访问方法、装置、计算机设备及计算机存储介质
CN110071960A (zh) * 2019-03-12 2019-07-30 平安科技(深圳)有限公司 管理灰度发布的方法、系统、设备及存储介质
CN112000348A (zh) * 2020-07-28 2020-11-27 金蝶医疗软件科技有限公司 服务灰度发布的控制方法、装置、计算机设备

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2019029457A1 (zh) * 2017-08-07 2019-02-14 阿里巴巴集团控股有限公司 客户端上应用程序的更新方法、装置及电子设备
CN109376322A (zh) * 2018-09-07 2019-02-22 平安科技(深圳)有限公司 一种灰度版本页面访问方法、装置、计算机设备及计算机存储介质
CN110071960A (zh) * 2019-03-12 2019-07-30 平安科技(深圳)有限公司 管理灰度发布的方法、系统、设备及存储介质
CN112000348A (zh) * 2020-07-28 2020-11-27 金蝶医疗软件科技有限公司 服务灰度发布的控制方法、装置、计算机设备

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113138880A (zh) * 2021-04-09 2021-07-20 浙商银行股份有限公司 区块链系统灰度发布方法、装置、设备及存储介质
CN113138880B (zh) * 2021-04-09 2023-11-28 浙商银行股份有限公司 区块链系统灰度发布方法、装置、设备及存储介质
CN113138774A (zh) * 2021-05-11 2021-07-20 中国工商银行股份有限公司 灰度发布方法、装置、电子设备、介质和程序产品
CN113138774B (zh) * 2021-05-11 2024-02-09 中国工商银行股份有限公司 灰度发布方法、装置、电子设备和介质
CN113542387A (zh) * 2021-07-09 2021-10-22 平安银行股份有限公司 系统发布方法、装置、电子设备及存储介质
CN113542387B (zh) * 2021-07-09 2023-07-04 平安银行股份有限公司 系统发布方法、装置、电子设备及存储介质
CN113946353A (zh) * 2021-09-30 2022-01-18 北京五八信息技术有限公司 一种数据处理方法、装置、电子设备及存储介质
CN113946353B (zh) * 2021-09-30 2022-08-09 北京五八信息技术有限公司 一种数据处理方法、装置、电子设备及存储介质

Also Published As

Publication number Publication date
CN112506559B (zh) 2024-02-06

Similar Documents

Publication Publication Date Title
CN112506559B (zh) 基于网关的灰度发布方法、装置、电子设备及存储介质
CN112528307A (zh) 服务请求校验方法、装置、电子设备及存储介质
CN112506779A (zh) 软件接口测试方法、装置、电子设备及存储介质
CN111897548A (zh) 前端资源发布方法、装置、电子设备及计算机存储介质
CN111651121A (zh) 数据逻辑计算方法、装置、电子设备及存储介质
CN114356530A (zh) 任务调度方法、装置、电子设备及存储介质
CN113221154A (zh) 服务密码获取方法、装置、电子设备及存储介质
CN112579452A (zh) 软件自动化测试方法、装置、设备及存储介质
CN112580079A (zh) 权限配置方法、装置、电子设备及可读存储介质
CN112541688A (zh) 业务数据校验方法、装置、电子设备及计算机存储介质
CN114826725A (zh) 数据交互方法、装置、设备及存储介质
CN114820132A (zh) 订单派发方法、装置、电子设备及存储介质
CN114897624A (zh) 保单数据合并方法、装置、设备及存储介质
CN114036068A (zh) 基于隐私安全的更新检测方法、装置、设备及存储介质
CN112667244A (zh) 数据校验方法、装置、电子设备及计算机可读存储介质
CN113127109A (zh) 接口调用方法、装置、电子设备及可读存储介质
CN113542387B (zh) 系统发布方法、装置、电子设备及存储介质
CN113064797B (zh) 前端监控方法、装置、电子设备及存储介质
CN112637280B (zh) 数据传输方法、装置、电子设备及存储介质
CN114185502B (zh) 基于产线环境的日志打印方法、装置、设备及介质
CN116303522A (zh) 数据调用方法、装置、电子设备及计算机可读存储介质
CN114185748A (zh) 系统监控方法、装置、电子设备及存储介质
CN114546854A (zh) 接口测试方法、装置、电子设备及存储介质
CN114416575A (zh) Mock数据生成方法、装置、设备及存储介质
CN114942855A (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