发明内容
鉴于以上内容,有必要提供一种缓存共用方法、装置、服务器及存储介质,不仅能够提高了缓存服务器的利用率,还能够避免不同环境共用同个服务器产生的干扰问题。
一方面,本发明提出一种缓存共用方法,应用于服务器中,所述缓存共用方法包括:
当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统;
从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境;
获取所述目标系统的系统标识,并获取所述当前环境的环境标识;
拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;
对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求;
响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
根据本发明优选实施例,所述获取与所述服务器连接的所有测试系统包括:
获取配置连接表,并获取所述服务器的服务器识别码;
从所述配置连接表中获取与所述服务器识别码对应的所有系统编码;
根据所述所有系统编码确定所述所有测试系统。
根据本发明优选实施例,所述从所述所有测试系统中确定发出所述缓存操作请求的目标系统包括:
解析所述缓存操作请求的报文头,得到所述报文头携带的地址信息;
从配置标签库中获取预设标签,所述预设标签用于指示所述缓存操作请求的发出地址;
从所述地址信息中获取与所述预设标签对应的信息作为所述缓存操作请求的发出地址,并获取所述所有测试系统的系统地址;
将所述发出地址与所述系统地址进行匹配,并将与所述发出地址匹配成功的系统地址对应的测试系统确定为所述目标系统。
根据本发明优选实施例,所述确定所述目标系统的当前环境包括:
获取当前时间,并根据所述发出地址获取所述目标系统的系统进度表,所述系统进度表中包括多个列表,每个列表对应一个更新时间;
从所述系统进度表中获取所述更新时间距离所述当前时间最近的列表作为当前列表;
根据所述当前列表指示的信息确定所述目标系统的当前环境。
根据本发明优选实施例,所述拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识包括:
确定所述系统标识的第一长度,并确定所述环境标识的第二长度;
计算所述第一长度与所述第二长度的总和,得到长度总和;
检测所述长度总和是否大于预设阈值;
当所述长度总和大于所述预设阈值时,将所述预设阈值除以配置值,得到目标值,按照倒序的顺序从所述系统标识中截取长度为所述目标值的字符作为第一标识,并按照倒序的顺序从所述环境标识中截取长度为所述目标值的字符作为第二标识,拼接所述第一标识及所述第二标识,得到所述目标标识;或者
当所述长度总和小于或者等于所述预设阈值时,对所述系统标识及所述环境标识进行拼接,得到所述目标标识。
根据本发明优选实施例,所述对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求包括:
融合所述缓存操作请求及所述目标标识,得到封装信息,并获取封装模板;
将所述封装信息写入所述封装模板,得到所述封装请求。
根据本发明优选实施例,所述响应所述封装请求,得到响应结果包括:
从预设线程池中获取所有闲置线程,并确定所述所有闲置线程的处理效率;
将所述处理效率最高的闲置线程确定为目标线程,并利用所述目标线程解析所述封装请求,得到所述封装请求携带的处理请求;
执行所述处理请求,得到所述响应结果。
另一方面,本发明还提出一种缓存共用装置,运行于服务器中,所述缓存共用装置包括:
获取单元,用于当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统;
确定单元,用于从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境;
所述获取单元,还用于获取所述目标系统的系统标识,并获取所述当前环境的环境标识;
拼接单元,用于拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;
封装单元,用于对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求;
响应单元,用于响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
另一方面,本发明还提出一种服务器,所述服务器包括:
存储器,存储计算机可读指令;及
处理器,执行所述存储器中存储的计算机可读指令以实现所述缓存共用方法。
另一方面,本发明还提出一种计算机可读存储介质,所述计算机可读存储介质中存储有计算机可读指令,所述计算机可读指令被服务器中的处理器执行以实现所述缓存共用方法。
由以上技术方案可以看出,本发明能够当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统,通过确定出所述所有测试系统,能够缩小所述目标系统的确定范围,从而提高所述目标系统的确定速率,从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境,获取所述目标系统的系统标识,并获取所述当前环境的环境标识;拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;能够生成唯一标识所述当前环境的目标标识,便于所述当前环境能够更好地访问缓存服务器,对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求,利用所述目标标识封装所述缓存操作请求,能够便于所述缓存服务器区分出所述缓存操作请求的触发环境,响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中,将所述响应结果存储至具有唯一性的目标标识中,能够避免不同环境共用同个缓存服务器造成的干扰问题。本发明通过生成的目标标识,能够准确区分出所述缓存操作请求的触发系统及触发环境,进而在执行缓存操作时能够避免不同环境共用同个服务器产生的干扰问题,此外,由于多个测试系统的不同环境共用同个缓存服务器,提高了缓存服务器的利用率。
具体实施方式
为了使本发明的目的、技术方案和优点更加清楚,下面结合附图和具体实施例对本发明进行详细描述。
如图1所示,是本发明缓存共用方法的较佳实施例的流程图。根据不同的需求,该流程图中步骤的顺序可以改变,某些步骤可以省略。
所述缓存共用方法应用于一个或者多个服务器中,所述服务器是一种能够按照事先设定或存储的计算机可读指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable Gate Array,FPGA)、数字处理器(Digital SignalProcessor,DSP)、嵌入式设备等。
所述服务器可以是任何一种可与用户进行人机交互的电子产品,例如,个人计算机、平板电脑、智能手机、个人数字助理(Personal Digital Assistant,PDA)、游戏机、交互式网络电视(Internet Protocol Television,IPTV)、智能穿戴式设备等。
所述服务器可以包括网络设备和/或用户设备。其中,所述网络设备包括,但不限于单个网络服务器、多个网络服务器组成的服务器组或基于云计算(Cloud Computing)的由大量主机或网络服务器构成的云。
所述服务器所处的网络包括,但不限于:互联网、广域网、城域网、局域网、虚拟专用网络(Virtual Private Network,VPN)等。
S10,当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统。
在本发明的至少一个实施例中,所述缓存操作请求可以由用户触发,也可以由所述所有测试系统中任意测试系统触发。
所述缓存操作请求携带的信息可以包括缓存操作,例如,设置缓存、删除缓存、获取缓存等。
所述所有测试系统是指处于开发期的系统。
参见图2,图2是本发明获取所有测试系统的一实施例的流程图。在本发明的至少一个实施例中,所述服务器获取与所述服务器连接的所有测试系统包括:
S100,获取配置连接表,并获取所述服务器的服务器识别码。
其中,所述配置连接表中存储多个识别码与多个编码的映射关系,例如,huancuan1:xitonga,xitongb,xitongc。
S101,从所述配置连接表中获取与所述服务器识别码对应的所有系统编码。
每个系统编码对应一个测试系统。
S102,根据所述所有系统编码确定所述所有测试系统。
通过上述实施方式,由于所述配置连接表中存储多个识别码与多个编码的映射关系,因此,通过获取到的所述服务器识别码能够快速确定出所述所有测试系统。
S11,从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境。
在本发明的至少一个实施例中,所述目标系统可以是所述所有测试系统中任意一个测试系统。
所述当前环境可以包括,但不限于:开发环境、测试环境等。
参见图3,图3是本发明确定目标系统的一实施例的流程图。在本发明的至少一个实施例中,所述服务器从所述所有测试系统中确定发出所述缓存操作请求的目标系统包括:
S110,解析所述缓存操作请求的报文头,得到所述报文头携带的地址信息。
例如:所述地址信息可以包括:address-122.13.0.0。
S111,从配置标签库中获取预设标签,所述预设标签用于指示所述缓存操作请求的发出地址。
其中,所述配置标签库中存储多个预先定义好的预设标签。
所述发出地址与所述系统地址都可以是IP地址。
S112,从所述地址信息中获取与所述预设标签对应的信息作为所述缓存操作请求的发出地址,并获取所述所有测试系统的系统地址。
承接上述例子,所述预设标签为address,与所述预设标签对应的信息可以为122.13.0.0。
S113,将所述发出地址与所述系统地址进行匹配,并将与所述发出地址匹配成功的系统地址对应的测试系统确定为所述目标系统。
通过上述实施方式,由于无需解析整个所述缓存操作请求,因此,能够提高所述缓存操作请求的解析效率,进而通过所述预设标签与所述发出地址的映射关系,能够准确确定出所述缓存操作请求的发出地址,进而将所述发出地址与所述所有测试系统的系统地址进行匹配,能够缩小所述目标系统的确定范围,从而提高所述目标系统的确定速率。
在本发明的至少一个实施例中,所述服务器确定所述目标系统的当前环境包括:
获取当前时间,并根据所述发出地址获取所述目标系统的系统进度表,所述系统进度表中包括多个列表,每个列表对应一个更新时间;
从所述系统进度表中获取所述更新时间距离所述当前时间最近的列表作为当前列表;
根据所述当前列表指示的信息确定所述目标系统的当前环境。
其中,所述系统进度表中的多个列表记载的信息包括开发所述目标系统所产生的信息。
通过上述实施方式,能够根据所述当前时间快速确定出所述系统进度表中的当前列表,进而根据所述当前列表指示的信息能够准确确定出所述当前环境。
S12,获取所述目标系统的系统标识,并获取所述当前环境的环境标识。
在本发明的至少一个实施例中,所述系统标识是指能够唯一标识所述目标系统的标签。例如,所述系统标识可以是systemA。
所述环境标识是指能够唯一标识所述当前环境的标签。例如,所述环境标识可以是stg1。
S13,拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识。
需要强调的是,为进一步保证上述目标标识的私密和安全性,上述目标标识还可以存储于一区块链的节点中。
在本发明的至少一个实施例中,所述目标标识是根据所述系统标识及所述环境标识生成的,所述目标标识用于指示所述目标系统及所述当前环境的标识,所述目标标识的长度小于或者等于预设阈值。
参见图4,图4是本发明确定当前环境的目标标识的一实施例的流程图。在本发明的至少一个实施例中,所述服务器拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识包括:
S130,确定所述系统标识的第一长度,并确定所述环境标识的第二长度。
其中,所述第一长度用于指示所述系统标识的字节长度,所述第二长度用于指示所述环境标识的字节长度。
S131,计算所述第一长度与所述第二长度的总和,得到长度总和。
所述长度总和用于指示所述系统标识与所述环境标识的字节长度总和。
S132,检测所述长度总和是否大于预设阈值。
其中,所述预设阈值是根据应用场景设置的数值。
S133,当所述长度总和大于所述预设阈值时,将所述预设阈值除以配置值,得到目标值,按照倒序的顺序从所述系统标识中截取长度为所述目标值的字符作为第一标识,并按照倒序的顺序从所述环境标识中截取长度为所述目标值的字符作为第二标识,拼接所述第一标识及所述第二标识,得到所述目标标识。
所述配置值是根据所述系统标识及所述环境标识的标识数量确定的,由此可见,所述配置值一般取值为2。
例如:所述系统标识为systemA,所述环境标识为stg1,由此可见,所述系统标识的第一长度为7,所述环境标识的第二长度为4,所述系统标识与所述环境标识的长度总和为11,当所述预设阈值为8时,由于所述长度总和11大于所述预设阈值7,获取到所述配置值为2,经计算,得到所述目标值为4,按照倒序的顺序从所述systemA中截取长度为4的字符,得到所述第一标识为temA,按照倒序的顺序从所述stg1中截取长度为4的字符,得到所述第二标识为stg1,拼接得到所述目标标识为temAstg1。
S134,当所述长度总和小于或者等于所述预设阈值时,对所述系统标识及所述环境标识进行拼接,得到所述目标标识。
承接上述例子:当所述预设阈值为12时,由于所述长度总和11小于所述预设阈值12,因此,拼接得到所述目标标识为systemAstg1。
通过上述实施方式,能够生成唯一标识所述当前环境的目标标识,便于所述当前环境能够更好地访问缓存服务器。
S14,对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求。
在本发明的至少一个实施例中,所述封装请求中包括所述缓存操作请求及所述目标标识,因此,所述封装请求具有能够区分出所述缓存操作请求的触发系统及触发环境的特性。
在本发明的至少一个实施例中,所述服务器对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求包括:
融合所述缓存操作请求及所述目标标识,得到封装信息,并获取封装模板;
将所述封装信息写入所述封装模板,得到所述封装请求。
通过上述实施方式,由于所述封装模板是预先生成的,因此,能够快速生成所述封装请求。
在本发明的至少一个实施例中,本发明利用所述目标标识封装所述缓存操作请求,能够便于所述缓存服务器区分出所述缓存操作请求的触发环境。
S15,响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
在本发明的至少一个实施例中,所述响应结果是指对所述缓存操作请求的响应。
所述目标标识与所述键值形成键值对。
在本发明的至少一个实施例中,所述服务器响应所述封装请求,得到响应结果包括:
从预设线程池中获取所有闲置线程,并确定所述所有闲置线程的处理效率;
将所述处理效率最高的闲置线程确定为目标线程,并利用所述目标线程解析所述封装请求,得到所述封装请求携带的处理请求;
执行所述处理请求,得到所述响应结果。
通过上述实施方式,利用处理效率最高的闲置线程解析所述封装请求,能够提高所述封装请求的解析效率,进而提高所述响应结果的确定效率。
在本发明的至少一个实施例中,本发明将所述响应结果存储至具有唯一性的目标标识中,能够避免不同环境共用同个缓存服务器造成的干扰问题。
在本发明的至少一个实施例中,在将所述响应结果存储至与所述目标标识对应的键值中后,所述方法还包括:
根据所述键值生成提示信息,并确定所述缓存操作请求的请求等级;
根据所述请求等级确定所述提示信息的发送方式,并以所述发送方式发送所述提示信息。
通过上述实施方式,利用所述键值生成所述提示信息,提高所述提示信息的生成效率,并通过与所述请求等级对应的发送方式发送所述提示信息,确保能够以合适的方式发送所述提示信息。
由以上技术方案可以看出,本发明能够当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统,通过确定出所述所有测试系统,能够缩小所述目标系统的确定范围,从而提高所述目标系统的确定速率,从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境,获取所述目标系统的系统标识,并获取所述当前环境的环境标识;拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;能够生成唯一标识所述当前环境的目标标识,便于所述当前环境能够更好地访问缓存服务器,对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求,利用所述目标标识封装所述缓存操作请求,能够便于所述缓存服务器区分出所述缓存操作请求的触发环境,响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中,将所述响应结果存储至具有唯一性的目标标识中,能够避免不同环境共用同个缓存服务器造成的干扰问题。本发明通过生成的目标标识,能够准确区分出所述缓存操作请求的触发系统及触发环境,进而在执行缓存操作时能够避免不同环境共用同个服务器产生的干扰问题,此外,由于多个测试系统的不同环境共用同个缓存服务器,提高了缓存服务器的利用率。
如图5所示,是本发明缓存共用装置的较佳实施例的功能模块图。所述缓存共用装置11包括获取单元110、确定单元111、拼接单元112、封装单元113、响应单元114及发送单元115。本发明所称的模块/单元是指一种能够被处理器13所获取,并且能够完成固定功能的一系列计算机可读指令段,其存储在存储器12中。在本实施例中,关于各模块/单元的功能将在后续的实施例中详述。
当接收到缓存操作请求时,获取单元110获取与所述服务器连接的所有测试系统。
在本发明的至少一个实施例中,所述缓存操作请求可以由用户触发,也可以由所述所有测试系统中任意测试系统触发。
所述缓存操作请求携带的信息可以包括缓存操作,例如,设置缓存、删除缓存、获取缓存等。
所述所有测试系统是指处于开发期的系统。
在本发明的至少一个实施例中,所述获取单元110获取与所述服务器连接的所有测试系统包括:
获取配置连接表,并获取所述服务器的服务器识别码。
其中,所述配置连接表中存储多个识别码与多个编码的映射关系,例如,huancuan1:xitonga,xitongb,xitongc。
从所述配置连接表中获取与所述服务器识别码对应的所有系统编码。
每个系统编码对应一个测试系统。
根据所述所有系统编码确定所述所有测试系统。
通过上述实施方式,由于所述配置连接表中存储多个识别码与多个编码的映射关系,因此,通过获取到的所述服务器识别码能够快速确定出所述所有测试系统。
确定单元111从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境。
在本发明的至少一个实施例中,所述目标系统可以是所述所有测试系统中任意一个测试系统。
所述当前环境可以包括,但不限于:开发环境、测试环境等。
在本发明的至少一个实施例中,所述确定单元111从所述所有测试系统中确定发出所述缓存操作请求的目标系统包括:
解析所述缓存操作请求的报文头,得到所述报文头携带的地址信息。
例如:所述地址信息可以包括:address-122.13.0.0。
从配置标签库中获取预设标签,所述预设标签用于指示所述缓存操作请求的发出地址。
其中,所述配置标签库中存储多个预先定义好的预设标签。
所述发出地址与所述系统地址都可以是IP地址。
从所述地址信息中获取与所述预设标签对应的信息作为所述缓存操作请求的发出地址,并获取所述所有测试系统的系统地址。
承接上述例子,所述预设标签为address,与所述预设标签对应的信息可以为122.13.0.0。
将所述发出地址与所述系统地址进行匹配,并将与所述发出地址匹配成功的系统地址对应的测试系统确定为所述目标系统。
通过上述实施方式,由于无需解析整个所述缓存操作请求,因此,能够提高所述缓存操作请求的解析效率,进而通过所述预设标签与所述发出地址的映射关系,能够准确确定出所述缓存操作请求的发出地址,进而将所述发出地址与所述所有测试系统的系统地址进行匹配,能够缩小所述目标系统的确定范围,从而提高所述目标系统的确定速率。
在本发明的至少一个实施例中,所述确定单元111确定所述目标系统的当前环境包括:
获取当前时间,并根据所述发出地址获取所述目标系统的系统进度表,所述系统进度表中包括多个列表,每个列表对应一个更新时间;
从所述系统进度表中获取所述更新时间距离所述当前时间最近的列表作为当前列表;
根据所述当前列表指示的信息确定所述目标系统的当前环境。
其中,所述系统进度表中的多个列表记载的信息包括开发所述目标系统所产生的信息。
通过上述实施方式,能够根据所述当前时间快速确定出所述系统进度表中的当前列表,进而根据所述当前列表指示的信息能够准确确定出所述当前环境。
所述获取单元110获取所述目标系统的系统标识,并获取所述当前环境的环境标识。
在本发明的至少一个实施例中,所述系统标识是指能够唯一标识所述目标系统的标签。例如,所述系统标识可以是systemA。
所述环境标识是指能够唯一标识所述当前环境的标签。例如,所述环境标识可以是stg1。
拼接单元112拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识。
需要强调的是,为进一步保证上述目标标识的私密和安全性,上述目标标识还可以存储于一区块链的节点中。
在本发明的至少一个实施例中,所述目标标识是根据所述系统标识及所述环境标识生成的,所述目标标识用于指示所述目标系统及所述当前环境的标识,所述目标标识的长度小于或者等于预设阈值。
在本发明的至少一个实施例中,所述拼接单元112拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识包括:
确定所述系统标识的第一长度,并确定所述环境标识的第二长度。
其中,所述第一长度用于指示所述系统标识的字节长度,所述第二长度用于指示所述环境标识的字节长度。
计算所述第一长度与所述第二长度的总和,得到长度总和。
所述长度总和用于指示所述系统标识与所述环境标识的字节长度总和。
检测所述长度总和是否大于预设阈值。
其中,所述预设阈值是根据应用场景设置的数值。
当所述长度总和大于所述预设阈值时,将所述预设阈值除以配置值,得到目标值,按照倒序的顺序从所述系统标识中截取长度为所述目标值的字符作为第一标识,并按照倒序的顺序从所述环境标识中截取长度为所述目标值的字符作为第二标识,拼接所述第一标识及所述第二标识,得到所述目标标识。
所述配置值是根据所述系统标识及所述环境标识的标识数量确定的,由此可见,所述配置值一般取值为2。
例如:所述系统标识为systemA,所述环境标识为stg1,由此可见,所述系统标识的第一长度为7,所述环境标识的第二长度为4,所述系统标识与所述环境标识的长度总和为11,当所述预设阈值为8时,由于所述长度总和11大于所述预设阈值7,获取到所述配置值为2,经计算,得到所述目标值为4,按照倒序的顺序从所述systemA中截取长度为4的字符,得到所述第一标识为temA,按照倒序的顺序从所述stg1中截取长度为4的字符,得到所述第二标识为stg1,拼接得到所述目标标识为temAstg1。
当所述长度总和小于或者等于所述预设阈值时,对所述系统标识及所述环境标识进行拼接,得到所述目标标识。
承接上述例子:当所述预设阈值为12时,由于所述长度总和11小于所述预设阈值12,因此,拼接得到所述目标标识为systemAstg1。
通过上述实施方式,能够生成唯一标识所述当前环境的目标标识,便于所述当前环境能够更好地访问缓存服务器。
封装单元113对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求。
在本发明的至少一个实施例中,所述封装请求中包括所述缓存操作请求及所述目标标识,因此,所述封装请求具有能够区分出所述缓存操作请求的触发系统及触发环境的特性。
在本发明的至少一个实施例中,所述封装单元113对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求包括:
融合所述缓存操作请求及所述目标标识,得到封装信息,并获取封装模板;
将所述封装信息写入所述封装模板,得到所述封装请求。
通过上述实施方式,由于所述封装模板是预先生成的,因此,能够快速生成所述封装请求。
在本发明的至少一个实施例中,本发明利用所述目标标识封装所述缓存操作请求,能够便于所述缓存服务器区分出所述缓存操作请求的触发环境。
响应单元114响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
在本发明的至少一个实施例中,所述响应结果是指对所述缓存操作请求的响应。
所述目标标识与所述键值形成键值对。
在本发明的至少一个实施例中,所述响应单元114响应所述封装请求,得到响应结果包括:
从预设线程池中获取所有闲置线程,并确定所述所有闲置线程的处理效率;
将所述处理效率最高的闲置线程确定为目标线程,并利用所述目标线程解析所述封装请求,得到所述封装请求携带的处理请求;
执行所述处理请求,得到所述响应结果。
通过上述实施方式,利用处理效率最高的闲置线程解析所述封装请求,能够提高所述封装请求的解析效率,进而提高所述响应结果的确定效率。
在本发明的至少一个实施例中,本发明将所述响应结果存储至具有唯一性的目标标识中,能够避免不同环境共用同个缓存服务器造成的干扰问题。
在本发明的至少一个实施例中,在将所述响应结果存储至与所述目标标识对应的键值中后,所述确定单元111根据所述键值生成提示信息,并确定所述缓存操作请求的请求等级;
发送单元115根据所述请求等级确定所述提示信息的发送方式,并以所述发送方式发送所述提示信息。
通过上述实施方式,利用所述键值生成所述提示信息,提高所述提示信息的生成效率,并通过与所述请求等级对应的发送方式发送所述提示信息,确保能够以合适的方式发送所述提示信息。
由以上技术方案可以看出,本发明能够当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统,通过确定出所述所有测试系统,能够缩小所述目标系统的确定范围,从而提高所述目标系统的确定速率,从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境,获取所述目标系统的系统标识,并获取所述当前环境的环境标识;拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;能够生成唯一标识所述当前环境的目标标识,便于所述当前环境能够更好地访问缓存服务器,对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求,利用所述目标标识封装所述缓存操作请求,能够便于所述缓存服务器区分出所述缓存操作请求的触发环境,响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中,将所述响应结果存储至具有唯一性的目标标识中,能够避免不同环境共用同个缓存服务器造成的干扰问题。本发明通过生成的目标标识,能够准确区分出所述缓存操作请求的触发系统及触发环境,进而在执行缓存操作时能够避免不同环境共用同个服务器产生的干扰问题,此外,由于多个测试系统的不同环境共用同个缓存服务器,提高了缓存服务器的利用率。
如图6所示,是本发明实现缓存共用方法的较佳实施例的服务器的结构示意图。
在本发明的一个实施例中,所述服务器1包括,但不限于,存储器12、处理器13,以及存储在所述存储器12中并可在所述处理器13上运行的计算机可读指令,例如缓存共用程序。
本领域技术人员可以理解,所述示意图仅仅是服务器1的示例,并不构成对服务器1的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述服务器1还可以包括输入输出设备、网络接入设备、总线等。
所述处理器13可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等,所述处理器13是所述服务器1的运算核心和控制中心,利用各种接口和线路连接整个服务器1的各个部分,及执行所述服务器1的操作系统以及安装的各类应用程序、程序代码等。
示例性的,所述计算机可读指令可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器12中,并由所述处理器13执行,以完成本发明。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机可读指令段,该计算机可读指令段用于描述所述计算机可读指令在所述服务器1中的执行过程。例如,所述计算机可读指令可以被分割成获取单元110、确定单元111、拼接单元112、封装单元113、响应单元114及发送单元115。
所述存储器12可用于存储所述计算机可读指令和/或模块,所述处理器13通过运行或执行存储在所述存储器12内的计算机可读指令和/或模块,以及调用存储在存储器12内的数据,实现所述服务器1的各种功能。所述存储器12可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据服务器的使用所创建的数据等。存储器12可以包括非易失性和易失性存储器,例如:硬盘、内存、插接式硬盘,智能存储卡(Smart MediaCard,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)、至少一个磁盘存储器件、闪存器件、或其他存储器件。
所述存储器12可以是服务器1的外部存储器和/或内部存储器。进一步地,所述存储器12可以是具有实物形式的存储器,如内存条、TF卡(Trans-flash Card)等等。
所述服务器1集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述实施例方法中的全部或部分流程,也可以通过计算机可读指令来指令相关的硬件来完成,所述的计算机可读指令可存储于一计算机可读存储介质中,该计算机可读指令在被处理器执行时,可实现上述各个方法实施例的步骤。
其中,所述计算机可读指令包括计算机可读指令代码,所述计算机可读指令代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机可读指令代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)。
本发明所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
结合图1,所述服务器1中的所述存储器12存储计算机可读指令实现一种缓存共用方法,所述处理器13可执行所述计算机可读指令从而实现:
当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统;
从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境;
获取所述目标系统的系统标识,并获取所述当前环境的环境标识;
拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;
对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求;
响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
具体地,所述处理器13对上述计算机可读指令的具体实现方法可参考图1对应实施例中相关步骤的描述,在此不赘述。
在本发明所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述计算机可读存储介质上存储有计算机可读指令,其中,所述计算机可读指令被处理器13执行时用以实现以下步骤:
当接收到缓存操作请求时,获取与所述服务器连接的所有测试系统;
从所述所有测试系统中确定发出所述缓存操作请求的目标系统,并确定所述目标系统的当前环境;
获取所述目标系统的系统标识,并获取所述当前环境的环境标识;
拼接所述系统标识及所述环境标识,得到所述当前环境的目标标识;
对所述缓存操作请求及所述目标标识进行封装,得到所述当前环境的封装请求;
响应所述封装请求,得到响应结果,并将所述响应结果存储至与所述目标标识对应的键值中。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能模块的形式实现。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图标记视为限制所涉及的权利要求。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。本发明中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第一、第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。