CN111241134B - 一种数据处理方法及装置 - Google Patents
一种数据处理方法及装置 Download PDFInfo
- Publication number
- CN111241134B CN111241134B CN201911418862.5A CN201911418862A CN111241134B CN 111241134 B CN111241134 B CN 111241134B CN 201911418862 A CN201911418862 A CN 201911418862A CN 111241134 B CN111241134 B CN 111241134B
- Authority
- CN
- China
- Prior art keywords
- data
- identifier
- database
- data identifier
- acquisition request
- 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.)
- Active
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2455—Query execution
- G06F16/24552—Database cache management
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请示出了一种数据处理方法及装置。接收携带数据标识的数据获取请求,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,若不存在,判断该数据标识是否被加锁,若被加锁,判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据,若缓存有,基于第二数据响应该数据获取请求。通过本申请,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况,可以避免大量的数据获取请求应用服务器上在积压,由于没有大量的数据获取请求应用服务器上在积压,因此,应用服务器后续可以继续正常接收另外的数据处理请求,以及,可以降低应用服务器以及数据库宕机的可能性。
Description
技术领域
本申请涉及计算机技术领域,特别是涉及一种数据处理方法及装置。
背景技术
随着技术的飞速发展,网络上的应用服务器越来越多,应用服务器可以为用户提供数据服务。
用户可以访问应用服务器以获取数据,应用服务器与数据库通信连接,数据库用于存储数据,待用户需要获取数据时,应用服务器可以从数据库中获取数据并向用户响应。进一步地,应用服务器可以使用分布式缓存服务器缓存数据库中的数据,这样,应用服务器可以从分布式缓存服务器中获取数据并向用户响应,应用服务器从分布式缓存服务器中获取数据的速度高于应用服务器从数据库中获取数据的速度,因此,应用服务器从分布式缓存服务器中获取数据可以提高获取数据的效率。
其中,有时候需要对数据进行更新,通常情况下,在更新数据时,可以先删除分布式缓存服务器中存储的旧数据,再使用新数据替换数据库中存储的旧数据,如此完成对数据更新。然而,在这种情况下,需要保障分布式缓存服务器中的数据与数据库中的数据一致。
为了保障分布式缓存服务器中的数据与数据库中的数据一致,如果应用服务器接收到数据获取请求,可以先从分布式缓存服务器中获取数据,如果未能从分布式缓存服务器中获取到数据,则说明此时处于使用新数据替换数据库中的旧数据的过程,也即,在删除分布式缓存服务器中的旧数据之后数据库更新数据的流程还没完成,也就没在分布式缓存服务器中存储新数据,如此,可以暂停执行“从数据库中获取数据的操作”。等待数据库的更新流程完成之后,再执行从数据库中获取数据的操作。
然而,在等待的这段时间内,如果应用服务器集中接收到大量的用于获取上述数据的数据获取请求,则由于这段时间内数据库更新数据的流程还没完成,则所有数据获取请求对应的“从数据库中获取数据的操作”均需要暂停,如此,在应用服务器上会积压大量的数据处理请求,进而可能导致应用服务器后续无法正常接收到其他数据处理请求。
以及,如果在应用服务器上积压的数据处理请求的数量非常大,则会增加应用服务器以及数据库宕机的可能性。
并且,如果在应用服务器上积压的数据处理请求的数量非常大,则在数据库更新数据的流程完成之后,应用服务器虽然可以继续执行“从数据库中获取数据的操作”,但往往无法在短时间内响应完毕所有的用于获取上述数据的数据处理请求,这样会导致大量的数据处理请求响应超时。
发明内容
为解决上述技术问题,本申请示出了一种数据处理方法及装置。
第一方面,本申请示出了一种数据处理方法,应用于应用服务器中,所述方法包括:
接收数据获取请求,所述数据获取请求携带数据标识,所述数据获取请求用于获取所述数据标识所对应的数据;
在分布式缓存服务器中查找是否存在所述数据标识所对应的第一数据;
如果所述分布式缓存服务器中不存在所述第一数据,则判断所述数据标识是否被加锁;
如果所述数据标识被加锁,判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据;
如果所述本地缓存中缓存有所述第二数据,基于所述本地缓存中的第二数据响应所述数据获取请求。
在一个可选的实现方式中,所述方法还包括:
如果所述本地缓存中未缓存所述第二数据,从数据库中获取所述数据标识所对应的第三数据;
将所述第三数据缓存在所述本地缓存中;
基于所述本地缓存中的第三数据响应所述数据获取请求。
在一个可选的实现方式中,所述方法还包括:
如果所述分布式缓存服务器中存在所述第一数据,则基于所述分布式缓存服务器中的第一数据响应所述数据获取请求。
在一个可选的实现方式中,所述方法还包括:
如果所述数据标识未被加锁,则从数据库中获取所述数据标识所对应的第四数据;
基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述方法还包括:
如果所述数据标识被加锁,则在所述数据获取请求的响应限定时长内定时判断所述数据标识是否被解锁;
如果在所述响应限定时长内所述数据标识未被解锁,则再执行所述判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据的步骤。
在一个可选的实现方式中,所述方法还包括:
如果在所述响应限定时长内所述数据标识被解锁,则从所述数据库中获取所述数据标识所对应的第四数据;
基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述方法还包括:
在所述分布式缓存服务器中缓存所述第四数据。
在一个可选的实现方式中,所述方法还包括:
接收数据更新请求,所述更新请求携带第四数据以及所述数据标识;
对所述数据标识加锁;
删除分布式缓存服务器中缓存的所述数据标识所对应的第一数据;
使用所述第四数据替换在数据库中存储的所述数据标识所对应的第三数据;
对所述数据标识解锁。
第二方面,本申请示出了一种数据处理装置,应用于应用服务器中,所述装置包括:
第一接收模块,用于接收数据获取请求,所述数据获取请求携带数据标识,所述数据获取请求用于获取所述数据标识所对应的数据;
查找模块,用于在分布式缓存服务器中查找是否存在所述数据标识所对应的第一数据;
第一判断模块,用于如果所述分布式缓存服务器中不存在所述第一数据,则判断所述数据标识是否被加锁;
第二判断模块,用于如果所述数据标识被加锁,判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据;
第一响应模块,用于如果所述本地缓存中缓存有所述第二数据,基于所述本地缓存中的第二数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第二获取模块,用于如果所述本地缓存中未缓存所述第二数据,从数据库中获取所述数据标识所对应的第三数据;
第一缓存模块,用于将所述第三数据缓存在所述本地缓存中;
第二响应模块,用于基于所述本地缓存中的第三数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三响应模块,用于如果所述分布式缓存服务器中存在所述第一数据,则基于所述分布式缓存服务器中的第一数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三获取模块,用于如果所述数据标识未被加锁,则从数据库中获取所述数据标识所对应的第四数据;
第四响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三判断模块,用于如果所述数据标识被加锁,则在所述数据获取请求的响应限定时长内定时判断所述数据标识是否被解锁;
所述第二判断模块还用于如果在所述响应限定时长内所述数据标识未被解锁,则判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据。
在一个可选的实现方式中,所述装置还包括:
第四获取模块,用于如果在所述响应限定时长内所述数据标识被解锁,则从所述数据库中获取所述数据标识所对应的第四数据;
第五响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第二缓存模块,用于在所述分布式缓存服务器中缓存所述第四数据。
在一个可选的实现方式中,所述装置还包括:
第二接收模块,用于接收数据更新请求,所述更新请求携带第四数据以及所述数据标识;
加锁模块,用于对所述数据标识加锁;
删除模块,用于删除分布式缓存服务器中缓存的所述数据标识所对应的第一数据;
替换模块,用于使用所述第四数据替换在数据库中存储的所述数据标识所对应的第三数据;
解锁模块,用于对所述数据标识解锁。
第三方面,本申请示出了一种电子设备,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如第一方面所述的数据处理方法。
第四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
第五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
本申请提供的技术方案可以包括以下有益效果:
在本申请中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,如果分布式缓存服务器中不存在第一数据,判断该数据标识是否被加锁,如果该数据标识被加锁,则说明此时正在使用该数据标识所对应的第四数据替换数据库中该数据标识所对应的第三数据,因此,此时无法基于数据库中的该数据标识所对应的第三数据响应该数据获取请求,也即,不从数据库中获取该数据标识所对应的第三数据。
由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,如果不从数据库中获取该数据标识所对应的第三数据,也就不会将该数据标识所对应的第三数据缓存在分布式缓存服务器中,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
或者说,在这个阶段中,数据库中存储有该数据标识所对应的数据,而分布式缓存服务器中并未存储该数据标识所对应的数据,在数据库以及分布式缓存服务器中只存储有一个该数据标识所对应的数据,不存在比较的问题,也就不存在二者存储的该数据标识所对应的数据不一致的问题。
待之后使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,应用服务器如果接收到的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器基于数据库中的该数据标识所对应的数据的第四数据响应其他数据获取请求,由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,应用服务器可以将该数据标识所对应的数据的第四数据缓存在分布式缓存服务器中,这样,分布式缓存服务器中存储的是第四数据,数据库中存储的是第四数据,二者存储的数据一致。
如此,如果该数据标识被加锁,则可以判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据,如果本地缓存中缓存有第二数据,基于本地缓存中的第二数据响应该数据获取请求。
这样,即使在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据的这段时间内,应用服务器集中接收到大量的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器也可以基于本地缓存中的该数据标识所对应的第二数据分别响应其他数据获取请求,避免大量的其他数据获取请求应用服务器上在积压,由于没有大量的其他数据获取请求应用服务器上在积压,因此,应用服务器后续可以继续正常接收另外的数据处理请求,以及,可以降低应用服务器以及数据库宕机的可能性。
进一步地,如果本地缓存中未缓存第二数据,在可以从数据库中获取该数据标识所对应的第三数据,将第三数据缓存在本地缓存中,基于本地缓存中的第三数据响应该数据获取请求。由于此次从数据库中获取该数据标识所对应的第三数据并未是直接基于数据库中的第三数据响应该数据获取请求,因此,可以不需要在分布式缓存服务器中缓存从数据库中获取的该数据标识所对应的第三数据,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
附图说明
图1是本申请的一种数据处理系统的结构框图.
图2是本申请的一种数据处理方法的步骤流程图。
图3是本申请的一种数据处理方法的步骤流程图。
图4是本申请的一种数据处理装置的结构框图。
图5是本申请示出的一种电子设备的框图。
图6是本申请示出的一种电子设备的框图。
具体实施方式
为使本申请的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本申请作进一步详细的说明。
参照图1,示出了本申请的一种数据处理系统的结构框图,该系统包括:应用服务器01、数据库02以及分布式缓存服务器03。
应用服务器01与数据库02之间通信连接,应用服务器01与分布式缓存服务器03之间通信连接。
数据库02用于存储数据,分布式缓存服务器03用于缓存数据。
应用服务器01可以用于根据外部设备的请求从数据库02或分布式缓存服务器03中获取数据,并向外部设备反馈获取到的数据。
其中,应用服务器01从数据库02中获取数据所需耗费的时长往往多于应用服务器01从分布式缓存服务器03中获取数据所需耗费的时长。
因此,应用服务器01事先可以将数据库02中的至少部分数据缓存至分布式缓存服务器03中,如此在获取这部分数据时,应用服务器01可以从分布式缓存服务器03中直接获取,从而提高获取效率。至少部分数据可以为获取频率较高的数据等。
其中,应用服务器01中也具有自己的本地缓存,本地缓存位于应用服务器01中。
应用服务器01从本地缓存中获取数据所需耗费的时长往往少于应用服务器01从分布式缓存服务器03中获取数据所需耗费的时长。
因此,有时候应用服务器01可以将数据库02中的至少部分数据缓存在应用服务器01的本地缓存中,如此在获取这部分数据时,应用服务器01可以从本地缓存中直接获取,从而可以进一步提高获取效率。
参照图2,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于图1所示的应用服务器01中,该方法具体可以包括如下步骤:
在步骤S101中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据;
在步骤S102中,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据;
如果分布式缓存服务器中不存在第一数据,在步骤S103中,判断该数据标识是否被加锁;
如果该数据标识被加锁,在步骤S104中,判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据;
如果本地缓存中缓存有第二数据,在步骤S105中,基于本地缓存中的第二数据响应该数据获取请求。
在本申请中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,如果分布式缓存服务器中不存在第一数据,判断该数据标识是否被加锁,如果该数据标识被加锁,则说明此时正在使用该数据标识所对应的第四数据替换数据库中该数据标识所对应的第三数据,因此,此时无法基于数据库中的该数据标识所对应的第三数据响应该数据获取请求,也即,不从数据库中获取该数据标识所对应的第三数据。
由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,如果不从数据库中获取该数据标识所对应的第三数据,也就不会将该数据标识所对应的第三数据缓存在分布式缓存服务器中,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
或者说,在这个阶段中,数据库中存储有该数据标识所对应的数据,而分布式缓存服务器中并未存储该数据标识所对应的数据,在数据库以及分布式缓存服务器中只存储有一个该数据标识所对应的数据,不存在比较的问题,也就不存在二者存储的该数据标识所对应的数据不一致的问题。
待之后使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,应用服务器如果接收到的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器基于数据库中的该数据标识所对应的数据的第四数据响应其他数据获取请求,由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,应用服务器可以将该数据标识所对应的数据的第四数据缓存在分布式缓存服务器中,这样,分布式缓存服务器中存储的是第四数据,数据库中存储的是第四数据,二者存储的数据一致。
如此,如果该数据标识被加锁,则可以判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据,如果本地缓存中缓存有第二数据,基于本地缓存中的第二数据响应该数据获取请求。
这样,即使在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据的这段时间内,应用服务器集中接收到大量的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器也可以基于本地缓存中的该数据标识所对应的第二数据分别响应其他数据获取请求,避免大量的其他数据获取请求应用服务器上在积压,由于没有大量的其他数据获取请求应用服务器上在积压,因此,应用服务器后续可以继续正常接收另外的数据处理请求,以及,可以降低应用服务器以及数据库宕机的可能性。
参照图3,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于图1所示的应用服务器01中,该方法具体可以包括如下步骤:
在步骤S201中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据;
在本申请中,当外部设备需要获取该数据标识对应的数据时,外部设备可以向应用服务器发送数据获取请求,该数据获取请求携带该数据标识,该数据获取请求用于获取该数据标识所对应的数据;然后应用服务器可以接收该数据获取请求。
在应用服务器接收到该数据获取请求时,可能正在数据库以及分布式缓存服务器中更新该数据标识所对应的数据,为了提高数据获取效率,应用服务器可以先执行步骤S202:在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,如果存在,则可以直接从分布式缓存服务器获取该数据标识所对应的第一数据。
在步骤S202中,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据;
如果分布式缓存服务器中存在第一数据,在步骤S203中,基于分布式缓存服务器中的第一数据响应该数据获取请求;
例如,应用服务器可以从分布式缓存服务器中获取第一数据,向该数据获取请求的发送方发送第一数据。
由于在数据库以及分布式缓存服务器中更新该数据标识所对应的数据时,通常是先删除分布式缓存服务器中的该数据标识所对应的旧数据,然后再删除数据库中的该数据标识所对应的旧数据,之后再在数据库中存储该数据标识所对应的新数据。
因此,如果分布式缓存服务器中存在第一数据,则说明此时未在数据库以及分布式缓存服务器中更新该数据标识所对应的数据,且分布式缓存服务器中的该数据标识所对应的第一数据也位于数据库中,因此,为了提高数据获取效率,应用服务器可以直接基于分布式缓存服务器中的第一数据响应该数据获取请求,例如可以直接从分布式缓存服务器中获取第一数据,然后可以向该数据获取请求的发送方发送第一数据。
如果分布式缓存服务器中不存在第一数据,在步骤S204中,判断该数据标识是否被加锁;
如果分布式缓存服务器中不存在第一数据,则说明此时可能存在两种情况:
第一种情况:正在进行更新该数据标识所对应的数据的流程,例如,已经从分布式缓存服务器删除了该数据标识所对应的第一数据,将要或者正在在数据库中更新该数据标识所对应的新数据,例如,将要或者正在进行在数据库中删除该数据标识所对应的第三数据以及在数据库中存储该数据标识所对应的第四数据的流程。
第二种情况:已经进行完毕更新该数据标识所对应的数据的流程,例如,已经从分布式缓存服务器删除了该数据标识所对应的第一数据,且在数据库中删除完毕该数据标识所对应的第三数据以及在数据库中存储完毕该数据标识所对应的第四数据,但应用服务器还未从数据库中获取到过该数据标识所对应的四数据,也就还未在分布式缓存服务器中存储该数据标识所对应的第四数据。
此时需要判断是哪一种情况,如果是第一种情况,则可以等待在数据库中删除完毕该数据标识所对应的第三数据以及在数据库中存储完毕该数据标识所对应的第四数据之后,再基于数据库中的该标识所对应的第四数据响应该数据获取请求。
然而,如果是第二种情况,则可以直接基于数据库中的该标识所对应的第四数据响应该数据获取请求,且可以将该数据标识所对应的第四数据缓存在分布式缓存服务器中。
其中,在本申请实施例中,当需要更新该数据标识对应的数据时,接收数据更新请求,该更新请求携带第四数据以及该数据标识;对该数据标识加锁;删除分布式缓存服务器中缓存的该数据标识所对应的第一数据;使用第四数据替换在数据库中存储的该数据标识所对应的第三数据;再对该数据标识解锁。在该数据标识被加锁的过程中,在数据库中的该数据标识所对应的第三数据还未被从数据库中删除的情况下,应用服务器不能基于数据库中的该数据标识所对应的第三数据响应数据获取请求。
如此,可以通过判断该数据标识是否被加锁来判断此时处于第一种情况还是第二种情况,如果该数据标识被加锁,则说明此时处于第一种情况,如果该数据标识未被加锁,则说明此时处于第二种情况。
其中,对数据标识加锁可以是将数据标识存储在特定的列表中,对数据标识解锁可以是将数据标识从特定的列表中删除。
如此,在判断该数据标识是否被加锁时,可以在特定的列表中查找是否存在该数据标识,如果特定的列表中存在该数据标识,则确定该数据标识被加锁,如果特定的列表中不存在该数据标识,则确定该数据标识未被加锁。
如果该数据标识未被加锁,在步骤S205中,从数据库中获取该数据标识所对应的第四数据,基于数据库中的第四数据响应该数据获取请求;
例如,从数据库中获取第四数据,向该数据获取请求的发送方发送第四数据。进一步地,可以在分布式缓存服务器中缓存第四数据。
在本申请中,如果该数据标识未被加锁,则说明此时处于第二种情况,也即,已经进行完毕更新该数据标识所对应的数据的流程,例如,已经使用第四数据替换完毕在数据库中存储的该数据标识所对应的第三数据,但应用服务器还未从数据库中获取到过该数据标识所对应的第四数据,也就还未在分布式缓存服务器中存储该数据标识所对应的第四数据。因此,应用服务器可以基于数据库中的第四数据响应该数据获取请求,例如,从数据库中获取该数据标识所对应的第四数据以及向发送方发送第四数据。
以及,还可以将第四数据缓存在分布式缓存服务器中,以使之后在应用服务器需要基于第四数据响应其他数据获取请求时,可以直接基于分布式缓存服务器中的第四数据直接响应其他数据处理请求,以提高其他数据获取请求的响应效率。
如果该数据标识被加锁,在步骤S206中,在该数据获取请求的响应限定时长内定时判断该数据标识是否被解锁;
如果该数据标识被加锁,则说明此时处于第一种情况,也即,正在进行更新该数据标识所对应的数据的流程,例如,已经从分布式缓存服务器删除了该数据标识所对应的第一数据,正在使用第四数据替换完毕在数据库中存储的该数据标识所对应的第三数据。
此时可以等待使用第四数据替换完毕在数据库中存储的该数据标识所对应的第三数据之后,该数据标识就会被解锁,如此就可以基于数据中的第四数据直接响应该数据处理请求。
然而,该数据获取请求具有响应限定时长,也即,应用服务器通常需要在在接收到外部设备发送的该数据获取请求之后的响应限定时长内响应该数据获取请求,例如,应用服务器在接收到外部设备发送的该数据获取请求之后的响应限定时长内需要向外部设备返回该数据标识所对应的数据。
否则,如果外部设备在向应用服务器发送该数据获取请求之后,等待了超过响应限定时长的时长都未得到应用服务器的响应,例如,等待了超过响应限定时长的时长都未得到应用服务器返回的该数据标识所对应的数据。
对于应用服务器而言,如果集中接收到大量的数据获取请求,则由于这段时间内数据库的更新流程还没完成,则可能导致后续无法正常接收到其他数据处理请求,以及积压的数据处理请求的数量过大会增加服务器以及数据库宕机的可能性。如果积压的数据处理请求的数量非常大,则在数据库的更新流程完成之后,应用服务器无法在短时间内存储完毕所有数据处理请求,会导致大量的数据处理请求超时未响应。
因此,为了解决上述问题,需要尽可能地在该数据获取请求的响应限定时长内响应完毕该数据获取请求,例如,需要尽可能地在该数据获取请求的响应限定时长内向外部设备反馈该数据标识所对应的数据。
由于此时正在处于使用第四数据替换在数据库中存储的该数据标识所对应的第三数据的过程中,在这个过程中,即使在数据库中还未删除该数据标识所对应的第三数据,则也无法基于数据库中的该数据标识所对应的第三数据响应该数据获取请求。
因此,为了尽可能地在该数据获取请求的响应限定时长内响应该数据获取请求,例如,向外部设备反馈该数据标识所对应的新数据,可以在该数据获取请求的响应限定时长内定时判断该数据标识是否被解锁。
如此,可以避免积压的数据处理请求的数量过大,进而避免大量的数据处理请求超时未响应。
如果在该数据获取请求的响应限定时长内该数据标识被解锁,在步骤S207中,从数据库中获取该数据标识所对应的第四数据,基于数据库中的第四数据响应该数据获取请求;
例如,从数据库中获取第四数据,向该数据获取请求的发送方发送第四数据。进一步地,可以在分布式缓存服务器中缓存第四数据。
在本申请中,如果在该数据获取请求的响应限定时长内该数据标识被解锁,则说明在该数据获取请求的响应限定时长内已经使用第四数据替换完毕在数据库中存储的该数据标识所对应的第三数据,因此,可以基于数据库中的第四数据响应该数据获取请求。
如果在该数据获取请求的响应限定时长内该数据标识未被解锁,在步骤S208中,判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据;
在本申请中,如果在该数据获取请求的响应限定时长内该数据标识未被解锁,则说明在该数据获取请求的响应限定时长内无法完成使用第四数据替换在数据库中存储的该数据标识所对应的第三数据的流程。
此时分布式缓存服务器中也没有该数据标识所对应的第一数据,如此,应用服务器无法基于分布式缓存服务器中的第一数据响应该数据获取请求,以及,由于该数据标识被加锁了,应用服务器也无法基于数据库中的第三数据响应该数据获取请求。
然而,有时候,应用服务器可能会在应用服务器的本地缓存中缓存一些数据。
且,通常情况下,往往是在数据库中更新完毕该数据标识所对应的数据之后,才可以在应用服务器的本地缓存中更新该数据标识所对应的数据。
然而,由于此时还未完成使用第四数据替换在数据库中存储的该数据标识所对应的第三数据的流程,因此,如果应用服务器的本地缓存中存储有该数据标识所对应的数据,存储的也是该数据标识所对应的旧数据,也即该数据标识所对应的第二数据。
因此,可以判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据。
如果本地缓存中缓存有第二数据,在步骤S209中,基于本地缓存中的第二数据响应该数据获取请求;
例如,获取本地缓存中的第二数据以及向发送方发送第二数据;
为了尽快处理更多的数据获取请求,以避免用于获取该数据标识所对应得到数据获取请求大量积压,进而避免影响应用服务器的稳定性,以及避免导致大量的数据获取请求响应超时,以降低增加服务器以及数据库宕机的可能性。避免大量的数据处理请求超时未响应,如果本地缓存中缓存有第二数据,则应用服务器可以获取基于本地缓存中的第二数据响应其他数据获取请求。
其中,由于此时还未完成使用第四数据替换在数据库中存储的该数据标识所对应的第三数据的流程,因此,第二数据对于外部设备而言也是新数据,使用第二数据不影响外部设备执行相应业务。
在本申请中,第一数据位于分布式缓存服务器中,第二数据位于应用服务器的本地缓存中,第三数据以及第四数据可以位于数据库中,第一数据、第二数据与第三数据相同,第四数据相对于第一数据、第二数据与第三数据更新。
如果本地缓存中未缓存第二数据,在步骤S210中,从数据库中获取该数据标识所对应的第三数据,将第三数据缓存在本地缓存中,基于本地缓存中的第三数据响应该数据获取请求。
例如,应用服务器从本地缓存中获取第三数据,以及向发送方发送第三数据。
由于此时还未完成使用第四数据替换在数据库中存储的该数据标识所对应的第三数据的流程,因此,即使此时数据库中存在该数据标识所对应的第三数据,应用服务器无法直接基于数据库中的第三数据响应该数据获取请求。
但是,虽然应用服务器无法直接基于数据库中的第三数据响应该数据获取请求,但是应用服务器在没有该数据获取请求的参与下,应用服务器可以直接访问数据库,从而可以获取到该数据标识所对应的第三数据,
为了尽快处理更多的数据获取请求,以降低增加服务器以及数据库宕机的可能性。避免大量的数据处理请求超时未响应,则应用服务器可以从将第三数据缓存在本地缓存中,基于本地缓存中的第三数据响应该数据获取请求。
之后可以将第二数据缓存在本地缓存中,以使之后在需要在根据第二数据响应其他数据获取请求时,可以直接基于本地缓存中的第二数据响应其他数据获取请求。
在本申请中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,如果分布式缓存服务器中不存在第一数据,判断该数据标识是否被加锁,如果该数据标识被加锁,则说明此时正在使用该数据标识所对应的第四数据替换数据库中该数据标识所对应的第三数据,因此,此时无法基于数据库中的该数据标识所对应的第三数据响应该数据获取请求,也即,不从数据库中获取该数据标识所对应的第三数据。
由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,如果不从数据库中获取该数据标识所对应的第三数据,也就不会将该数据标识所对应的第三数据缓存在分布式缓存服务器中,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
或者说,在这个阶段中,数据库中存储有该数据标识所对应的数据,而分布式缓存服务器中并未存储该数据标识所对应的数据,在数据库以及分布式缓存服务器中只存储有一个该数据标识所对应的数据,不存在比较的问题,也就不存在二者存储的该数据标识所对应的数据不一致的问题。
待之后使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,应用服务器如果接收到的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器基于数据库中的该数据标识所对应的数据的第四数据响应其他数据获取请求,由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,应用服务器可以将该数据标识所对应的数据的第四数据缓存在分布式缓存服务器中,这样,分布式缓存服务器中存储的是第四数据,数据库中存储的是第四数据,二者存储的数据一致。
如此,如果该数据标识被加锁,则可以判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据,如果本地缓存中缓存有第二数据,基于本地缓存中的第二数据响应该数据获取请求。
这样,即使在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据的这段时间内,应用服务器集中接收到大量的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器也可以基于本地缓存中的该数据标识所对应的第二数据分别响应其他数据获取请求,避免大量的其他数据获取请求应用服务器上在积压,由于没有大量的其他数据获取请求应用服务器上在积压,因此,应用服务器后续可以继续正常接收另外的数据处理请求,以及,可以降低应用服务器以及数据库宕机的可能性。
进一步地,如果本地缓存中未缓存第二数据,在可以从数据库中获取该数据标识所对应的第三数据,将第三数据缓存在本地缓存中,基于本地缓存中的第三数据响应该数据获取请求。由于此次从数据库中获取该数据标识所对应的第三数据并未是直接基于数据库中的第三数据响应该数据获取请求,因此,可以不需要在分布式缓存服务器中缓存从数据库中获取的该数据标识所对应的第三数据,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
参照图4,示出了本申请的一种数据处理装置的结构框图,该装置具体可以包括如下模块:
第一接收模块11,用于接收数据获取请求,所述数据获取请求携带数据标识,所述数据获取请求用于获取所述数据标识所对应的数据;
查找模块12,用于在分布式缓存服务器中查找是否存在所述数据标识所对应的第一数据;
第一判断模块13,用于如果所述分布式缓存服务器中不存在所述第一数据,则判断所述数据标识是否被加锁;
第二判断模块14,用于如果所述数据标识被加锁,判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据;
第一响应模块15,用于如果所述本地缓存中缓存有所述第二数据,基于所述本地缓存中的第二数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第二获取模块,用于如果所述本地缓存中未缓存所述第二数据,从数据库中获取所述数据标识所对应的第三数据;
第一缓存模块,用于将所述第三数据缓存在所述本地缓存中;
第二响应模块,用于基于所述本地缓存中的第三数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三响应模块,用于如果所述分布式缓存服务器中存在所述第一数据,则基于所述分布式缓存服务器中的第一数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三获取模块,用于如果所述数据标识未被加锁,则从数据库中获取所述数据标识所对应的第四数据;
第四响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第三判断模块,用于如果所述数据标识被加锁,则在所述数据获取请求的响应限定时长内定时判断所述数据标识是否被解锁;
所述第二判断模块还用于如果在所述响应限定时长内所述数据标识未被解锁,则判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据。
在一个可选的实现方式中,所述装置还包括:
第四获取模块,用于如果在所述响应限定时长内所述数据标识被解锁,则从所述数据库中获取所述数据标识所对应的第四数据;
第五响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
在一个可选的实现方式中,所述装置还包括:
第二缓存模块,用于在所述分布式缓存服务器中缓存所述第四数据。
在一个可选的实现方式中,所述装置还包括:
第二接收模块,用于接收数据更新请求,所述更新请求携带第四数据以及所述数据标识;
加锁模块,用于对所述数据标识加锁;
删除模块,用于删除分布式缓存服务器中缓存的所述数据标识所对应的第一数据;
替换模块,用于使用所述第四数据替换在数据库中存储的所述数据标识所对应的第三数据;
解锁模块,用于对所述数据标识解锁。
在本申请中,接收数据获取请求,该数据获取请求携带数据标识,该数据获取请求用于获取该数据标识所对应的数据,在分布式缓存服务器中查找是否存在该数据标识所对应的第一数据,如果分布式缓存服务器中不存在第一数据,判断该数据标识是否被加锁,如果该数据标识被加锁,则说明此时正在使用该数据标识所对应的第四数据替换数据库中该数据标识所对应的第三数据,因此,此时无法基于数据库中的该数据标识所对应的第三数据响应该数据获取请求,也即,不从数据库中获取该数据标识所对应的第三数据。
由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,如果不从数据库中获取该数据标识所对应的第三数据,也就不会将该数据标识所对应的第三数据缓存在分布式缓存服务器中,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
或者说,在这个阶段中,数据库中存储有该数据标识所对应的数据,而分布式缓存服务器中并未存储该数据标识所对应的数据,在数据库以及分布式缓存服务器中只存储有一个该数据标识所对应的数据,不存在比较的问题,也就不存在二者存储的该数据标识所对应的数据不一致的问题。
待之后使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,应用服务器如果接收到的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器基于数据库中的该数据标识所对应的数据的第四数据响应其他数据获取请求,由于基于数据库中的一个数据响应一个请求之后之后就需要在分布式缓存服务器中缓存该数据,因此,应用服务器可以将该数据标识所对应的数据的第四数据缓存在分布式缓存服务器中,这样,分布式缓存服务器中存储的是第四数据,数据库中存储的是第四数据,二者存储的数据一致。
如此,如果该数据标识被加锁,则可以判断应用服务器的本地缓存中是否缓存有该数据标识所对应的第二数据,如果本地缓存中缓存有第二数据,基于本地缓存中的第二数据响应该数据获取请求。
这样,即使在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据的这段时间内,应用服务器集中接收到大量的用于获取该数据标识所对应的数据的其他数据获取请求,应用服务器也可以基于本地缓存中的该数据标识所对应的第二数据分别响应其他数据获取请求,避免大量的其他数据获取请求应用服务器上在积压,由于没有大量的其他数据获取请求应用服务器上在积压,因此,应用服务器后续可以继续正常接收另外的数据处理请求,以及,可以降低应用服务器以及数据库宕机的可能性。
进一步地,如果本地缓存中未缓存第二数据,在可以从数据库中获取该数据标识所对应的第三数据,将第三数据缓存在本地缓存中,基于本地缓存中的第三数据响应该数据获取请求。由于此次从数据库中获取该数据标识所对应的第三数据并未是直接基于数据库中的第三数据响应该数据获取请求,因此,可以不需要在分布式缓存服务器中缓存从数据库中获取的该数据标识所对应的第三数据,从而可以避免出现在使用该数据标识所对应的第四数据替换完毕数据库中该数据标识所对应的第三数据之后,分布式缓存服务器存储的是该数据标识所对应的第三数据而数据库中存储的是该数据标识所对应的第四数据的情况,也即,可以避免出现分布式缓存服务器中存储的该数据标识所对应的数据与数据库中存储的该数据标识所对应的数据不同的情况。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图5是本申请示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图5,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图像,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播操作信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图6是本申请示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
参照图6,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本申请的实施例可提供为方法、装置、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本申请所提供的一种数据处理方法及装置,进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
Claims (16)
1.一种数据处理方法,其特征在于,应用于应用服务器中,所述方法包括:
接收数据获取请求,所述数据获取请求携带数据标识,所述数据获取请求用于获取所述数据标识所对应的数据;
在分布式缓存服务器中查找是否存在所述数据标识所对应的第一数据;
如果所述分布式缓存服务器中不存在所述第一数据,则判断所述数据标识是否被加锁;
如果所述数据标识被加锁,判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据;所述第二数据为从所述应用服务器对应的数据库中获取的所述数据标识所对应的第三数据;
如果所述本地缓存中缓存有所述第二数据,基于所述本地缓存中的第二数据响应所述数据获取请求;
如果所述数据标识未被加锁,则从所述数据库中获取所述数据标识所对应的第四数据;所述数据标识所对应的第四数据替换所述数据库中所述第三数据;
基于所述数据库中的第四数据响应所述数据获取请求。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
如果所述本地缓存中未缓存所述第二数据,从数据库中获取所述数据标识所对应的第三数据;
将所述第三数据缓存在所述本地缓存中;
基于所述本地缓存中的第三数据响应所述数据获取请求。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
如果所述分布式缓存服务器中存在所述第一数据,则基于所述分布式缓存服务器中的第一数据响应所述数据获取请求。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
如果所述数据标识被加锁,则在所述数据获取请求的响应限定时长内定时判断所述数据标识是否被解锁;
如果在所述响应限定时长内所述数据标识未被解锁,则再执行所述判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据的步骤。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
如果在所述响应限定时长内所述数据标识被解锁,则从所述数据库中获取所述数据标识所对应的第四数据;
基于所述数据库中的第四数据响应所述数据获取请求。
6.根据权利要求1或5所述的方法,其特征在于,所述方法还包括:
在所述分布式缓存服务器中缓存所述第四数据。
7.根据权利要求1所述的方法,其特征在于,所述方法还包括:
接收数据更新请求,所述更新请求携带第四数据以及所述数据标识;
对所述数据标识加锁;
删除分布式缓存服务器中缓存的所述数据标识所对应的第一数据;
使用所述第四数据替换在数据库中存储的所述数据标识所对应的第三数据;
对所述数据标识解锁。
8.一种数据处理装置,其特征在于,应用于应用服务器中,所述装置包括:
第一接收模块,用于接收数据获取请求,所述数据获取请求携带数据标识,所述数据获取请求用于获取所述数据标识所对应的数据;
查找模块,用于在分布式缓存服务器中查找是否存在所述数据标识所对应的第一数据;
第一判断模块,用于如果所述分布式缓存服务器中不存在所述第一数据,则判断所述数据标识是否被加锁;
第二判断模块,用于如果所述数据标识被加锁,判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据;所述第二数据为从所述应用服务器对应的数据库中获取的所述数据标识所对应的第三数据;
第一响应模块,用于如果所述本地缓存中缓存有所述第二数据,基于所述本地缓存中的第二数据响应所述数据获取请求;
第三获取模块,用于如果所述数据标识未被加锁,则从数据库中获取所述数据标识所对应的第四数据;所述数据标识所对应的第四数据替换所述数据库中所述第三数据;
第四响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第二获取模块,用于如果所述本地缓存中未缓存所述第二数据,从数据库中获取所述数据标识所对应的第三数据;
第一缓存模块,用于将所述第三数据缓存在所述本地缓存中;
第二响应模块,用于基于所述本地缓存中的第三数据响应所述数据获取请求。
10.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第三响应模块,用于如果所述分布式缓存服务器中存在所述第一数据,则基于所述分布式缓存服务器中的第一数据响应所述数据获取请求。
11.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第三判断模块,用于如果所述数据标识被加锁,则在所述数据获取请求的响应限定时长内定时判断所述数据标识是否被解锁;
所述第二判断模块还用于如果在所述响应限定时长内所述数据标识未被解锁,则判断所述应用服务器的本地缓存中是否缓存有所述数据标识所对应的第二数据。
12.根据权利要求11所述的装置,其特征在于,所述装置还包括:
第四获取模块,用于如果在所述响应限定时长内所述数据标识被解锁,则从所述数据库中获取所述数据标识所对应的第四数据;
第五响应模块,用于基于所述数据库中的第四数据响应所述数据获取请求。
13.根据权利要求8或12所述的装置,其特征在于,所述装置还包括:
第二缓存模块,用于在所述分布式缓存服务器中缓存所述第四数据。
14.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第二接收模块,用于接收数据更新请求,所述更新请求携带第四数据以及所述数据标识;
加锁模块,用于对所述数据标识加锁;
删除模块,用于删除分布式缓存服务器中缓存的所述数据标识所对应的第一数据;
替换模块,用于使用所述第四数据替换在数据库中存储的所述数据标识所对应的第三数据;
解锁模块,用于对所述数据标识解锁。
15.一种电子设备,其特征在于,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如权利要求1-7任一项所述的数据处理方法。
16.一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1-7任一项所述的数据处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911418862.5A CN111241134B (zh) | 2019-12-31 | 2019-12-31 | 一种数据处理方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911418862.5A CN111241134B (zh) | 2019-12-31 | 2019-12-31 | 一种数据处理方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111241134A CN111241134A (zh) | 2020-06-05 |
CN111241134B true CN111241134B (zh) | 2023-08-08 |
Family
ID=70879658
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911418862.5A Active CN111241134B (zh) | 2019-12-31 | 2019-12-31 | 一种数据处理方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111241134B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114048234A (zh) * | 2021-10-19 | 2022-02-15 | 车主邦(北京)科技有限公司 | 一种数据处理方法、装置、电子设备及存储介质 |
CN115913646B (zh) * | 2022-10-21 | 2024-06-04 | 网易(杭州)网络有限公司 | 黑名单对象的拦截方法、装置、电子设备和存储介质 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104376096A (zh) * | 2014-11-24 | 2015-02-25 | 北京京东尚科信息技术有限公司 | 基于缓冲区的异步更新的方法 |
CN104794162A (zh) * | 2015-03-25 | 2015-07-22 | 中国人民大学 | 实时数据存储与查询方法 |
CN105138587A (zh) * | 2015-07-31 | 2015-12-09 | 小米科技有限责任公司 | 数据访问方法、装置和系统 |
KR20170090594A (ko) * | 2016-01-29 | 2017-08-08 | 한국전자통신연구원 | 분산 파일 시스템을 채용한 스토리지 시스템에서 클라이언트 장치와 함께 파일의 분산 잠금을 관리하도록 구성되는 데이터 서버 장치 |
CN107315761A (zh) * | 2017-04-17 | 2017-11-03 | 阿里巴巴集团控股有限公司 | 一种数据更新方法、数据查询方法及装置 |
CN108132958A (zh) * | 2016-12-01 | 2018-06-08 | 阿里巴巴集团控股有限公司 | 一种多级缓存数据存储、查询、调度以及处理方法及装置 |
CN108683695A (zh) * | 2018-03-23 | 2018-10-19 | 阿里巴巴集团控股有限公司 | 热点访问处理方法、缓存访问代理设备及分布式缓存系统 |
CN110597739A (zh) * | 2019-06-03 | 2019-12-20 | 上海云盾信息技术有限公司 | 一种配置的管理方法、系统及设备 |
-
2019
- 2019-12-31 CN CN201911418862.5A patent/CN111241134B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104376096A (zh) * | 2014-11-24 | 2015-02-25 | 北京京东尚科信息技术有限公司 | 基于缓冲区的异步更新的方法 |
CN104794162A (zh) * | 2015-03-25 | 2015-07-22 | 中国人民大学 | 实时数据存储与查询方法 |
CN105138587A (zh) * | 2015-07-31 | 2015-12-09 | 小米科技有限责任公司 | 数据访问方法、装置和系统 |
KR20170090594A (ko) * | 2016-01-29 | 2017-08-08 | 한국전자통신연구원 | 분산 파일 시스템을 채용한 스토리지 시스템에서 클라이언트 장치와 함께 파일의 분산 잠금을 관리하도록 구성되는 데이터 서버 장치 |
CN108132958A (zh) * | 2016-12-01 | 2018-06-08 | 阿里巴巴集团控股有限公司 | 一种多级缓存数据存储、查询、调度以及处理方法及装置 |
CN107315761A (zh) * | 2017-04-17 | 2017-11-03 | 阿里巴巴集团控股有限公司 | 一种数据更新方法、数据查询方法及装置 |
CN108683695A (zh) * | 2018-03-23 | 2018-10-19 | 阿里巴巴集团控股有限公司 | 热点访问处理方法、缓存访问代理设备及分布式缓存系统 |
CN110597739A (zh) * | 2019-06-03 | 2019-12-20 | 上海云盾信息技术有限公司 | 一种配置的管理方法、系统及设备 |
Also Published As
Publication number | Publication date |
---|---|
CN111241134A (zh) | 2020-06-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101933290B1 (ko) | 애플리케이션 업데이트 방법, 장치 및 시스템 | |
CN109388625B (zh) | 多分布式文件系统中处理配置文件的方法及装置 | |
CN107357613B (zh) | 应用更新方法、装置及计算机可读存储介质 | |
CN104462296B (zh) | 文件的管理方法、装置及终端 | |
RU2645282C2 (ru) | Способ и устройство для вызова по облачным визиткам | |
CN107423394A (zh) | 页面显示方法及装置 | |
CN105094904A (zh) | 安装应用程序的方法及装置 | |
CN111241134B (zh) | 一种数据处理方法及装置 | |
CN107402767B (zh) | 显示推送消息的方法和装置 | |
CN104050236B (zh) | 网站内容更新提示方法、服务器和客户端 | |
CN107463419B (zh) | 应用重启方法、装置及计算机可读存储介质 | |
CN104951522B (zh) | 一种进行搜索的方法和装置 | |
CN111221862B (zh) | 一种请求处理方法及装置 | |
CN111695064B (zh) | 一种埋点加载方法及装置 | |
CN109245992B (zh) | 请求处理方法、装置、电子设备及存储介质 | |
CN112883314B (zh) | 一种请求处理方法及装置 | |
CN106155696B (zh) | 删除信息的方法及装置 | |
CN110995767B (zh) | 一种请求处理方法及装置 | |
CN110457084B (zh) | 一种加载方法及装置 | |
CN112416545A (zh) | 一种任务处理方法及装置 | |
CN107463414B (zh) | 应用安装方法及装置 | |
CN107257384B (zh) | 服务状态监控方法及装置 | |
CN111625536B (zh) | 一种数据访问方法及装置 | |
CN112068975B (zh) | 一种信息处理方法及装置 | |
CN110990073B (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 |