基于代理的灰度配置方法、装置、电子设备和介质与流程

专利查询2023-5-11  114



1.本公开涉及计算机应用技术领域,尤其涉及灰度测试技术领域,具体涉及一种基于代理的灰度配置方法、装置、电子设备和介质。


背景技术:

2.随着计算机技术的快速发展,应用(app)的更新与发布也处于快速迭代的状态。在新版本的应用正式发布之前,会将其发布给小范围的用户,并基于这部分用户的使用结果和反馈来调整应用,以逐步将新版本的应用放量给全部用户,这一过程称为灰度测试。在现有灰度测试中,将配置数据加载到存储区中,并由客户端定期轮询,以从存储区中获取最新的配置。然而,该技术方案对客户端的业务代码侵入性较大,需要增加客户端的业务逻辑,以判断自己是否属于灰度测试对象,并获取相应的配置数据。


技术实现要素:

3.本公开提供了一种基于代理的灰度配置方法、装置、电子设备和介质。
4.根据本公开的一方面,提供了一种基于代理的灰度配置方法,包括:
5.响应于接收到来自客户端的第一请求,确定第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件;
6.在确定第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新第一关键字;
7.根据第二关键字,从存储区中获取与第二关键字相对应的第二配置数据;以及
8.将所获取的第二配置数据转发给客户端。
9.根据本公开的另一方面,提供了一种基于代理的灰度配置装置,包括:
10.确定模块,响应于接收到来自客户端的第一请求,确定第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件;
11.更新模块,在确定第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新第一关键字;
12.更新模块,在确定第一关键字中的预设检查项满足配置更新条件的情况下,更新第一关键字;
13.获取模块,根据第二关键字,从存储区中获取与第二关键字相对应的第二配置数据;以及
14.转发模块,将所获取的第二配置数据转发给客户端。
15.根据本公开的另一方面,提供了一种电子设备,包括:
16.至少一个处理器;以及
17.与所述至少一个处理器通信连接的存储器;其中,
18.所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行根据本公开的一方面的方法。
19.根据本公开的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据本公开的一方面的方法。
20.根据本公开的另一方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据本公开的一方面的方法。
21.应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
22.附图用于更好地理解本方案,不构成对本公开的限定。其中:
23.图1是根据本公开实施例的基于代理的灰度配置方法的流程图;
24.图2是根据本公开另一实施例的基于代理的灰度配置方法的流程图;
25.图3是根据本公开实施例的数据流图;
26.图4是根据本公开实施例的基于代理的灰度配置装置的示意图;以及
27.图5示出了可以用来实施本公开的实施例的示例电子设备的示意性框图。
具体实施方式
28.以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
29.图1是根据本公开实施例的基于代理的灰度配置方法100的流程图。
30.在步骤s110,响应于接收到来自客户端的第一请求,确定第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件。
31.在一些实施例中,在客户端与存储区之间增加缓存代理。缓存代理可以是代理网关、微服务、虚拟机等。客户端向缓存代理发送第一请求,第一请求中携带有第一关键字。
32.第一关键字包括客户端标识、用户标识、客户端网络地址中的至少一项。例如,第一关键字是由客户端标识、用户标识和客户端网络地址组成的一串字符串。
33.将第一关键字中的一项设置为预设检查项。例如,在希望某些客户端,如某个版本以上的智能终端为灰度测试对象的情况下,可以将客户端标识设置为预设检查项。或者,在希望某些地区的客户端为灰度测试对象的情况下,可以将客户端网络地址设置为预设检查项。此外,假设被推送新版本应用的用户不更新该新版本应用,则新版本应用长时间未被用户使用,无法实现灰度测试的需求,因此希望较活跃用户成为灰度测试对象,可以将用户标识设置为预设检查项。
34.在步骤s120,在确定第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新第一关键字。
35.在一些实施例中,应用的发布方在存储区中设置一个预设列表,预设列表中包含相应的检查项。缓存代理在接收到来自客户端的第一请求之后,确定其中的预设检查项是否与预设列表中的相应检查项匹配,在预设检查项与预设列表中的相应检查项匹配的情况下,确定预设检查项满足配置更新条件。
36.作为示例,将客户端网络地址设置为预设检查项,并将被配置为灰度测试对象的客户端网络地址添加到预设列表中。缓存代理在接收到来自客户端的第一请求之后,确定第一请求中的客户端网络地址是否与存储区的预设列表中的客户端网络地址匹配,在二者匹配的情况下,确定该客户端网络地址满足配置更新条件。
37.应当理解的是,也可以将该预设列表加载到缓存代理中,缓存代理在接收到来自客户端的第一请求之后,在本地进行第一关键字中的预设检查项是否满足配置更新条件的确定。
38.在确定第一关键字中的预设检查项满足配置更新条件的情况下,可以确定该客户端属于灰度测试对象,并且利用第二关键字来更新第一关键字。
39.应用的发布方还可以在存储区中预设第二关键字-第二配置数据对,例如第二键值对keysmall-value。在第一关键字中的预设检查项满足配置更新条件的情况下,确定该客户端属于灰度测试对象,利用第二键值对中的keysmall,即第二关键字,来更新第一关键字。
40.更新可以是将第二关键字直接下发给缓存代理,以替换该客户端的第一关键字,也可以是在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
41.应当理解的是,在预设列表已经加载到缓存代理中的情况下,可以在缓存代理处执行第一关键字的更新,例如在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
42.在步骤s130,根据第二关键字,从存储区中获取与第二关键字相对应的第二配置数据。
43.在一些实施例中,缓存代理利用key-value,即键值对方式,从存储区获取与第二关键字相对应的第二配置数据。第二配置数据例如可以是新版本的应用。
44.key-value是键值对数据库(例如远程字典服务器redis)中常用的数据读取方式,利用key(键)获取对应的value(值)。例如,存储区中可以预置{“keysmall”:“v3”,“key”:“v2”}等等的键值对,其中keysmall位第二关键字,利用keysmall获取第二配置数据,即应用的版本号v3。
45.作为示例,存储区可以包括内存缓存、redis缓存以及数据库等。一般地,内存缓存的查找速度较快,redis缓存的查找速度次之,数据库的查找速度最慢,因而可以设置查找优先顺序。例如,在从存储区中获取配置数据时,可以首先在内存缓存中查找配置数据。在内存缓存中未找到配置数据的情况下,则根据第二关键字在redis缓存中查找配置数据。在redis缓存中未找到配置数据的情况下,则根据第二关键字在数据库中查找配置数据。应当理解,也可以根据实际配置数据存储的特点设置其他的查找顺序。
46.在步骤s140,将所获取的第二配置数据转发给客户端。
47.在一些实施例中,缓存代理利用第二关键字keysmall,从存储区获取与第二关键字keysmall相对应的第二配置数据,然后,将所获取的第二配置数据转发给客户端。
48.备选地,还可以包括步骤s150,在确定第一关键字中的预设检查项不满足配置更新条件的情况下,根据第一关键字,从存储区中获取与第一关键字相对应的第一配置数据。
49.例如,已经在存储区中预置了{“keysmall”:“v3”,“key”:“v2”}等键值对,其中key为第一关键字,利用key获取第一配置数据,即应用的版本号v2。具有第一关键字key的该客
户端不属于灰度测试对象,向其发布当前版本的应用。
50.在步骤s160,将所获取的第一配置数据转发给客户端。
51.应当理解的是,第二配置数据可以是相对于第一配置数据的更新数据,而第一配置数据可以是相对于客户端已有版本应用的更新数据。例如,当客户端已有版本应用为v2时,利用第一关键字key获取到的应用版本号也为v2,则第一配置数据可以仅包括版本号的指示符,而无需其他数据。
52.通过在客户端与存储区之间增加缓存代理,将业务逻辑中判断是否满足配置更新条件(即是否属于灰度测试对象)以及读取关键字(第一关键字或第二关键字)的过程下沉到缓存代理中,可以实现对客户端的代码无侵入性,从而降低了实现的代码成本。
53.图2是根据本公开另一实施例的基于代理的灰度配置方法200的流程图。
54.在图2中,步骤s220~s270分别与方法100中的步骤s110~s160相对应。此外,在步骤s220之前,还可以包括步骤s210,将配置数据集加载到存储区,配置数据集至少包括第一配置数据和第二配置数据。
55.在一些实施例中,应用的发布方预先将配置数据集加载到存储区中,配置数据集至少包括第一配置数据和第二配置数据。第一配置数据可以指示未设置为灰度测试对象的客户端及其相关联的配置策略,第二配置数据可以指示被设置为灰度测试对象的客户端及其相关联的配置策略。
56.此外,应用的发布方将第一配置数据及其相对应的第一关键字配置为第一键值对key-value,并且将第二配置数据及其相对应的第二关键字配置为第二键值对keysmall-value。
57.进一步地,应用的发布方在存储区中存储预设列表,其中包括对被配置为灰度测试对象的指示。指示可以是客户端标识、用户标识、客户端网络地址等。
58.缓存代理接收到来自客户端的第一请求,并根据包括在第一请求中的第一关键字中的预设检查项是否满足配置更新条件,来更新第一关键字。
59.例如,在预设检查项满足配置更新条件的情况下,将第二关键字发送给缓存代理,以利用第二关键字keysmall来更新第一关键字。更新可以是将第二关键字直接下发给缓存代理,以替换该客户端的第一关键字,也可以是在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
60.应当理解的是,也可以将预设列表加载到缓存代理中,缓存代理在接收到来自客户端的第一请求之后,在本地进行第一关键字中的预设检查项是否满足配置更新条件的确定。在预设检查项满足配置更新条件的情况下,通过预定规则更新第一关键字,以得到第二关键字。例如在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
61.随后,缓存代理根据第二关键字keysmall,通过第二键值对keysmall-value查找相应的值(value),以获取第二配置数据。而在预设检查项不满足配置更新条件的情况下,不更新第一关键字,缓存代理根据第一关键字key,通过第一键值对key-value查找相应的值(value),以获取第一配置数据。
62.通过在存储区中加载配置数据集,可以区分灰度测试对象和非灰度测试对象,并为灰度测试对象下发相应的关键字keysmall,由此实现灰度测试中由部分发布到全面发布的过程。
63.图3是根据本公开实施例的数据流图300。
64.如图3所示,客户端310包括3101…
310n,其中一个客户端,例如3101向缓存代理330发送第一请求320。缓存代理330也可以包括多个,例如3301…
330m,其中一个缓存代理,例如3301响应于接收到第一请求320,将携带在第一请求320中的第一关键字320k中的预设检查项340转发给存储区350。可以理解的是,多个客户端可以并行地向缓存代理发送第一请求,每个第一请求包含各自的预设检查项,缓存代理也可以并行地将各个预设检查项转发到存储区350。
65.存储区350利用其中的预设列表360,确定预设检查项340是否与预设列表360中的相应检查项匹配。
66.在确定预设检查项340与预设列表360中的相应检查项匹配的情况下,利用第二关键字keysmall 370ks来更新第一关键字320k。
67.例如,可以将第二关键字keysmall 370ks发送给缓存代理330。在备选实施例中,也可以将预设列表360加载到缓存代理330中,由缓存代理330依据预定规则更新第一关键字320k,例如在第一关键字320k后添加指示符,以指示该客户端属于灰度测试对象。
68.缓存代理330利用第二关键字keysmall 370ks,从存储区350中获取与第二关键字keysmall 370ks相对应的第二配置数据370v,并将第二配置数据370v转发给相应的客户端。
69.应当理解的是,存储区350也可以在确定预设检查项340与预设列表360中的相应检查项匹配之后,利用第二关键字keysmall 370ks来更新第一关键字320k,并且直接将与第二关键字keysmall 370ks相对应的第二配置数据370v发送给缓存代理330,而无需向缓存代理330发送第二关键字keysmall 370ks。
70.进一步地,在确定预设检查项340与预设列表360中的相应检查项不匹配的情况下,根据第一关键字320k,从存储区中获取与第一关键字320k相对应的第一配置数据320v。作为示例,存储区350可以向缓存代理330发送预设检查项不匹配的指示,缓存代理330在接收到该指示之后,根据第一关键字320k,从存储区中获取与第一关键字320k相对应的第一配置数据320v。备选地,存储区350也可以在确定预设检查项340与预设列表
71.360中的相应检查项不匹配之后,直接将与第一关键字320k相对应的第一
72.配置数据320v发送给缓存代理330。缓存代理330随后将第一配置数据
73.320v转发给相应的客户端。
74.通过在客户端与存储区之间增加缓存代理,由缓存代理进行客户端是否属于灰度测试对象、读取相应关键字、并将与相应关键字相对应的配置数据转发给客户端的操作,客户端仅需要向缓存代理发送其第一关键字,而无需确定其是否属于灰度测试对象,避免了对客户端的代码的侵入性改变。
75.图4是根据本公开实施例的基于代理的灰度配置装置400的示意图。
76.如图4所示,基于代理的灰度配置装置400包括确定模块410、更新模块420、获取模块430和转发模块440。
77.确定模块410响应于接收到来自客户端的第一请求,确定第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件。
78.在一些实施例中,在客户端与存储区之间增加缓存代理。缓存代理可以是代理网
关、微服务、虚拟机等。客户端向缓存代理发送第一请求,第一请求中携带有第一关键字。
79.第一关键字包括客户端标识、用户标识、客户端网络地址中的至少一项。例如,第一关键字是由客户端标识、用户标识和客户端网络地址组成的一串字符串。
80.将第一关键字中的一项设置为预设检查项。例如,在希望某些客户端,如某个版本以上的智能终端为灰度测试对象的情况下,可以将客户端标识设置为预设检查项。或者,在希望某些地区的客户端为灰度测试对象的情况下,可以将客户端网络地址设置为预设检查项。此外,假设被推送新版本应用的用户不更新该新版本应用,则新版本应用长时间未被用户使用,无法实现灰度测试的需求,因此希望较活跃用户成为灰度测试对象,可以将用户标识设置为预设检查项。
81.更新模块420在确定第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新第一关键字。
82.在一些实施例中,应用的发布方在存储区中设置一个预设列表,预设列表中包含相应的检查项。缓存代理在接收到来自客户端的第一请求之后,确定其中的预设检查项是否与预设列表中的相应检查项匹配,在预设检查项与预设列表中的相应检查项匹配的情况下,确定预设检查项满足配置更新条件。
83.作为示例,将客户端网络地址设置为预设检查项,并将被配置为灰度测试对象的客户端网络地址添加到预设列表中。缓存代理在接收到来自客户端的第一请求之后,确定第一请求中的客户端网络地址是否与存储区的预设列表中的客户端网络地址匹配,在二者匹配的情况下,确定该客户端网络地址满足配置更新条件。
84.应当理解的是,也可以将该预设列表加载到缓存代理中,缓存代理在接收到来自客户端的第一请求之后,在本地进行第一关键字中的预设检查项是否满足配置更新条件的确定。
85.在确定第一关键字中的预设检查项满足配置更新条件的情况下,可以确定该客户端属于灰度测试对象,并且利用第二关键字来更新第一关键字。
86.应用的发布方还可以在存储区中预设第二关键字-第二配置数据对,即第二键值对keysmall-value。在第一关键字中的预设检查项满足配置更新条件的情况下,确定该客户端属于灰度测试对象,利用第二键值对中的keysmall,即第二关键字,来更新第一关键字。
87.更新可以是将第二关键字直接下发给缓存代理,以替换该客户端的第一关键字,也可以是在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
88.应当理解的是,在预设列表已经加载到缓存代理中的情况下,可以在缓存代理处执行第一关键字的更新,例如在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
89.获取模块430根据第二关键字,从存储区中获取与第二关键字相对应的第二配置数据。
90.在一些实施例中,缓存代理利用key-value,即键值对方式,从存储区获取与第二关键字相对应的第二配置数据。第二配置数据例如可以是新版本的应用。
91.key-value是键值对数据库(例如远程字典服务器redis)中常用的数据读取方式,利用key(键)获取对应的value(值)。例如,存储区中可以预置{“keysmall”:“v3”,“key”:“v2”}等等的键值对,其中keysmall位第二关键字,利用keysmall获取第二配置数据,即应用的版本号v3。
92.作为示例,存储区可以包括内存缓存、redis缓存以及数据库等。在从存储区中获取配置数据时,可以首先在内存缓存中查找配置数据。在内存缓存中未找到配置数据的情况下,则根据第二关键字在redis缓存中查找配置数据。在redis缓存中未找到配置数据的情况下,则根据第二关键字在数据库中查找配置数据。
93.一般地,内存缓存的查找速度最快,redis缓存的查找速度其次,数据库的查找速度最慢,因而设置以上查找顺序。但是应当理解,也可以根据实际配置数据存储的特点设置其他的查找顺序。
94.转发模块440将所获取的第二配置数据转发给客户端。
95.在一些实施例中,缓存代理利用第二关键字keysmall,从存储区获取与第二关键字keysmall相对应的第二配置数据,然后,将所获取的第二配置数据转发给客户端。
96.备选地,确定模块410还可以在确定第一关键字中的预设检查项不满足配置更新条件的情况下,由获取模块430根据第一关键字,从存储区中获取与第一关键字相对应的第一配置数据。
97.进一步地,转发模块440将所获取的第一配置数据转发给客户端。
98.例如,已经在存储区中预置了{“keysmall”:“v3”,“key”:“v2”}等键值对,其中key为第一关键字,利用key获取第一配置数据,即应用的版本号v2。具有第一关键字key的该客户端不属于灰度测试对象,向其发布当前版本的应用。
99.应当理解的是,第二配置数据可以是相对于第一配置数据的更新数据,而第一配置数据可以是相对于客户端已有版本应用的更新数据。例如,当客户端已有版本应用为v2时,利用第一关键字key获取到的应用版本号也为v2,则第一配置数据可以仅包括版本号的指示符,而无需其他数据。
100.通过在客户端与存储区之间增加缓存代理,将业务逻辑中判断是否满足配置更新条件(即是否属于灰度测试对象)以及读取关键字(第一关键字或第二关键字)的过程下沉到缓存代理中,可以实现对客户端的代码无侵入性,从而降低了实现的代码成本。
101.备选地,基于代理的灰度配置装置400还可以包括加载模块450,将配置数据集加载到存储区,配置数据集至少包括第一配置数据和第二配置数据。
102.在一些实施例中,应用的发布方预先将配置数据集加载到存储区中,配置数据集至少包括第一配置数据和第二配置数据。第一配置数据可以指示未设置为灰度测试对象的客户端及其相关联的配置策略,第二配置数据可以指示被设置为灰度测试对象的客户端及其相关联的配置策略。
103.此外,应用的发布方将第一配置数据及其相对应的第一关键字配置为第一键值对key-value,并且将第二配置数据及其相对应的第二关键字配置为第二键值对keysmall-value。
104.进一步地,应用的发布方在存储区中存储预设列表,其中包括对被配置为灰度测试对象的指示。指示可以是客户端标识、用户标识、客户端网络地址等。
105.缓存代理接收到来自客户端的第一请求,并根据包括在第一请求中的第一关键字中的预设检查项是否满足配置更新条件,来更新第一关键字。
106.例如,在预设检查项满足配置更新条件的情况下,将第二关键字发送给缓存代理,以利用第二关键字keysmall来更新第一关键字。更新可以是将第二关键字直接下发给缓存代理,以替换该客户端的第一关键字,也可以是在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
107.应当理解的是,也可以将预设列表加载到缓存代理中,缓存代理在接收到来自客户端的第一请求之后,在本地进行第一关键字中的预设检查项是否满足配置更新条件的确定。在预设检查项满足配置更新条件的情况下,通过预定规则更新第一关键字,以得到第二关键字。例如在第一关键字后添加指示符,以指示该客户端属于灰度测试对象。
108.随后,缓存代理根据第二关键字keysmall,通过第二键值对keysmall-value查找相应的值(value),以获取第二配置数据。而在预设检查项不满足配置更新条件的情况下,不更新第一关键字,缓存代理根据第一关键字key,通过第一键值对key-value查找相应的值(value),以获取第一配置数据。
109.通过在存储区中加载配置数据集,可以区分灰度测试对象和非灰度测试对象,并为灰度测试对象下发相应的关键字keysmall,由此实现灰度测试中由部分发布到全面发布的过程。
110.图5示出了可以用来实施本公开的实施例的示例电子设备500的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
111.如图5所示,设备500包括计算单元501,其可以根据存储在只读存储器(rom)502中的计算机程序或者从存储单元508加载到随机访问存储器(ram)503中的计算机程序,来执行各种适当的动作和处理。在ram 503中,还可存储设备500操作所需的各种程序和数据。计算单元501、rom 502以及ram 503通过总线504彼此相连。输入/输出(i/o)接口505也连接至总线504。
112.设备500中的多个部件连接至i/o接口505,包括:输入单元506,例如键盘、鼠标等;输出单元507,例如各种类型的显示器、扬声器等;存储单元508,例如磁盘、光盘等;以及通信单元509,例如网卡、调制解调器、无线通信收发机等。通信单元509允许设备500通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
113.计算单元501可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元501的一些示例包括但不限于中央处理单元(cpu)、图形处理单元(gpu)、各种专用的人工智能(ai)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(dsp)、以及任何适当的处理器、控制器、微控制器等。计算单元501执行上文所描述的各个方法和处理,例如方法100或200。例如,在一些实施例中,上述方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元508。在一些实施例中,计算机程序的部分或者全部可以经由rom 502和/或通信单元509而被载入和/或安装到设备500上。当计算机程序加载到ram503并由计算单元501执行时,可以执行上文描述的方法的一个或多个步骤。备选地,在其他实施例中,计算单元501可以通过其他任何适当的方式(例如,借助于固件)而被
配置为执行方法。
114.本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、场可编程门阵列(fpga)、专用集成电路(asic)、专用标准产品(assp)、芯片上系统的系统(soc)、负载可编程逻辑设备(cpld)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
115.用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
116.在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦除可编程只读存储器(eprom或快闪存储器)、光纤、便捷式紧凑盘只读存储器(cd-rom)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
117.为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,crt(阴极射线管)或者lcd(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
118.可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(lan)、广域网(wan)和互联网。
119.计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与vps服务("
virtual private server",或简称"vps")中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式系统的服务器,或者是结合了区块链的服务器。
120.应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
121.上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。

技术特征:
1.一种基于代理的灰度配置方法,包括:响应于接收到来自客户端的第一请求,确定所述第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件;在确定所述第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新所述第一关键字;根据所述第二关键字,从存储区中获取与所述第二关键字相对应的第二配置数据;以及将所获取的第二配置数据转发给所述客户端。2.根据权利要求1所述的方法,还包括:在确定所述第一关键字中的预设检查项不满足配置更新条件的情况下,根据所述第一关键字,从所设存储区中获取与所述第一关键字相对应的第一配置数据。3.根据权利要求2所述的方法,还包括:将配置数据集加载到所述存储区,所述配置数据集至少包括所述第一配置数据和所述第二配置数据。4.根据权利要求1所述的方法,其中,所述确定所述第一关键字中的预设检查项是否满足配置更新条件包括:确定所述预设检查项是否与预设列表中的检查项匹配;在所述预设检查项与预设列表中的检查项匹配的情况下,确定所述预设检查项满足配置更新条件。5.根据权利要求4所述的方法,其中,所述在确定所述第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新所述第一关键字包括:将所述第二关键字发送给所述代理。6.根据权利要求1所述的方法,其中,所述第一关键字包括客户端标识、用户标识、客户端网络地址中的至少一项。7.一种基于代理的灰度配置装置,包括:确定模块,响应于接收到来自客户端的第一请求,确定所述第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件;更新模块,在确定所述第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新所述第一关键字;获取模块,根据所述第二关键字,从存储区中获取与所述第二关键字相对应的第二配置数据;以及转发模块,将所获取的第二配置数据转发给所述客户端。8.根据权利要求7所述的装置,其中:在所述确定模块确定所述第一关键字中的预设检查项不满足配置更新条件的情况下,所述获取模块根据所述第一关键字,从所设存储区中获取与所述第一关键字相对应的第一配置数据。9.根据权利要求8所述的装置,还包括:加载模块,将配置数据集加载到所述存储区,所述配置数据集至少包括所述第一配置数据和所述第二配置数据。
10.根据权利要求7所述的装置,其中,所述确定模块响应于接收到来自客户端的第一请求,确定所述第一关键字中的预设检查项是否满足配置更新条件包括:确定所述预设检查项是否与预设列表中的检查项匹配;在所述预设检查项与预设列表中的检查项匹配的情况下,确定所述预设检查项满足配置更新条件。11.根据权利要求10所述的装置,其中,所述更新模块在确定所述第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新所述第一关键字包括:将所述第二关键字发送给所述代理。12.根据权利要求7所述的装置,其中,所述第一关键字包括客户端标识、用户标识、客户端网络地址中的至少一项。13.一种电子设备,包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1~6中任一项所述的方法。14.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据权利要求1~6中任一项所述的方法。15.一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据权利要求1~6中任一项所述的方法。

技术总结
本公开提供了一种基于代理的灰度配置方法、装置、电子设备和介质,具体涉及计算机应用技术领域,尤其涉及灰度测试技术领域。基于代理的灰度配置方法包括:响应于接收到来自客户端的第一请求,确定第一请求中包括的第一关键字中的预设检查项是否满足配置更新条件;在确定第一关键字中的预设检查项满足配置更新条件的情况下,利用第二关键字来更新第一关键字;根据第二关键字,从存储区中获取与第二关键字相对应的第二配置数据;以及将所获取的第二配置数据转发给客户端。二配置数据转发给客户端。二配置数据转发给客户端。


技术研发人员:李鸿斌
受保护的技术使用者:北京百度网讯科技有限公司
技术研发日:2021.12.01
技术公布日:2022/3/8

最新回复(0)