CN106407347A - 一种缓存数据的方法和装置 - Google Patents

一种缓存数据的方法和装置 Download PDF

Info

Publication number
CN106407347A
CN106407347A CN201610804195.4A CN201610804195A CN106407347A CN 106407347 A CN106407347 A CN 106407347A CN 201610804195 A CN201610804195 A CN 201610804195A CN 106407347 A CN106407347 A CN 106407347A
Authority
CN
China
Prior art keywords
data
value
key
caching
preset time
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
CN201610804195.4A
Other languages
English (en)
Other versions
CN106407347B (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.)
Beijing Qihoo Technology Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing 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 Beijing Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201610804195.4A priority Critical patent/CN106407347B/zh
Publication of CN106407347A publication Critical patent/CN106407347A/zh
Application granted granted Critical
Publication of CN106407347B publication Critical patent/CN106407347B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24552Database cache management

Abstract

本发明公开了一种缓存数据的方法和装置。该方法包括:对于一条数据,在缓存中设置与该数据对应的两个键‑值对;第一键‑值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;第二键‑值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间,第二预设时间小于第一预设时间;当收到一数据请求时,根据该数据请求在缓存中查找;如果从缓存只查找到第一键‑值对,则将第一键‑值对中的值返回给请求方,从数据库重新读取该请求的数据来更新缓存中对应的第一键‑值对中的值,并重新设置对应的第二键‑值对以及对应的第一预设时间和第二预设时间。上述方案能保证缓存中的数据不失效,保证数据的访问速度。

Description

一种缓存数据的方法和装置
技术领域
本发明涉及计算机技术领域,具体涉及一种缓存数据的方法和装置。
背景技术
随着互联网的蓬勃发展,在很多应用场景都需要存储海量的数据。在从数据库读取数据时,由于数据库和访问量都过于庞大,会导致访问数据的时间延迟,影响读取数据的速度。通常情况下,会把访问频率较高的热数据放入缓存中,在接收到访问热数据的请求时直接从缓存中进行读取,大大增加了读取速度。
但是,缓存中的数据都存在一个失效时间,一旦超过失效时间,该数据就会自动从缓存中删除,删除后的数据再次被访问时需要从数据库中重新读取数据,因此对于一些热数据来说,其访问速度会下降,这就严重影响访问数据的速度,降低用户体验。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的缓存数据的方法和装置。
依据本发明的一个方面,提供了一种缓存数据的方法,包括:
对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对,则将第一键-值对中的值返回给请求方,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
可选地,保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
可选地,该方法进一步包括:
如果从缓存中查找到第一键-值对,也查找到第二键-值对,则将第一键-值对中的值返回给请求方,不作其他处理。
可选地,该方法进一步包括:
如果从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
可选地,所述用第一键-值对存放该数据本身,用第二键-值对标记该数据的预失效时间包括:
将第一键-值对中的值设置为该条数据本身;
将第二键-值对中的值设置为固定值或任意值。
可选地,将所述第一预设时间对应的时间值和第二预设时间对应的时间值保存到指定位置;
每次设置或重置一条数据的第一预设时间和第二预设时间,从所述指定位置读取对应的时间值并进行设置或重置。
可选地,该方法进一步包括:
根据数据的访问频率以及缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值。
根据本发明的另一方面,提供了一种缓存数据的装置,其中,该装置包括:
缓存处理单元,适于对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
请求处理单元,适于当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对时,将第一个键对应的值返回给请求方,并向缓存处理单元发送第一通知;
所述缓存处理单元,进一步适于收到第一通知时,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
可选地,保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
可选地,所述请求处理单元,进一步适于当从缓存中查找到第一键-值对,也查找到第二键-值对时,将第一键-值对中的值返回给请求方,不作其他处理。
可选地,所述请求处理单元,进一步适于当从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
可选地,所述缓存处理单元,适于将第一键-值对中的值设置为该条数据本身,将第二键-值对中的值设置为固定值或任意值。
可选地,所述第一预设时间对应的时间值和第二预设时间对应的时间值保存在指定位置;
所述缓存处理单元,适于在每次设置或重置一条数据的第一预设时间和第二预设时间,从所述指定位置读取对应的时间值并进行设置或重置。
可选地,该装置进一步包括:
参数调整单元,适于根据数据的访问频率以及缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值。
根据本发明的技术方案,在进行数据缓存时设置与该数据对应的两个键-值对,第一键-值对存放该数据本身,并设置其在缓存中的有效时间为第一预设时间,第二键-值对标记该数据的预失效时间,并将其在缓存中的有效时间为第二预设时间,第一预设时间大于第二预设时间,表示第二键-值对比第一键值对先失效。在访问数据时,如果两个键-值对均被查找到,说明该数据暂时不会失效,不做处理;如果只查找到一个键-值对,说明该数据即将失效,则将该数据返回给请求方的同时,从数据库中重新读取该数据并重新设置失效时间。可见,本发明的技术方案是随着用户访问的同时,对缓存中数据的失效时间进行检查,一旦检查到热数据即将失效,则重新从数据库中读取并设置,从而保证热数据一直存在缓存中,解决缓存中热数据失效的问题,避免请求者从数据库中访问热数据,影响访问速度的情况。综上所述,本发明能保证缓存中的数据不失效,且保证数据的访问速度,增强用户的体验。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例提供的一种缓存数据的方法流程示意图;
图2示出了根据本发明一个实施例提供的一种缓存数据的装置示意图;
图3示出了根据本发明另一个实施例提供的一种缓存数据的装置示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例提供的一种缓存数据的方法流程示意图。如图1所示,该方法包括:
步骤S110,对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间。
在本步骤中,第一键-值对中的键和第二键-值对中的键所代表的意义类似,均指该数据的关键信息,用户在请求信息时,通过数据的关键信息来进行查找,因为每个数据的关键信息都是唯一的,所以当用户针对一条数据进行访问时,只能查找到对应该数据的第一键-值对和第二键-值对中的一个或者两个。第一键-值对中的值存储的内容即为数据本身,那么用户请求数据时,返回的最终结果即第一键-值对中的值存储的内容;因为第二键-值对的作用只是标记该数据的预失效时间,那么第二键-值对中的值不需要有具体的意义。
另,本步骤中的第一预设时间和第二预设时间均为对应数据的基本属性,且第一预设时间大于第二预设时间,意味着第二键-值对比第一键-值对较早达到失效时间,率先失效,被缓存删除。比如,第一预设时间为30ms,第二预设时间为25ms。
那么,在步骤S120中,当收到一数据请求时,根据该数据请求在缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对,说明第二键-值对已经失效,且说明存放该数据本身第一键-值对也即将失效,则将第一键-值对中的值返回给请求方,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
本步骤中,如果从缓存只查找到第一键-值对,但未查找到第二键-值对,则说明该数据即将失效,需要从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间,以避免热数据在缓存中失效。步骤S110的例子中,如果从缓存查找到第一键-值对,但未查找到第二键-值对,则说明第二键-值对已经失效,该数据的存储时间处于25ms到30ms之间,该数据对应的第一键-值即将失效,因此需要从数据库重新读取该数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间30ms和第二预设时间25ms。这里的更新,一方面是对缓存中的数据进行再存储;另一方面,数据库中的数据是在实时变化的,那么在进行数据的重新读取时,将更新后的数据的值存入缓存中对应的第一键-值对中的值,也起到一个更新缓存中数据的作用。一般情况下,用户是进行当前时间的数据的访问,即使数据随后被更新,也不会受影响。
根据本发明的技术方案,在进行数据缓存时设置与该数据对应的两个键-值对,第一键-值对存放该数据本身,并设置其在缓存中的有效时间为第一预设时间,第二键-值对标记该数据的预失效时间,并将其在缓存中的有效时间为第二预设时间,第一预设时间大于第二预设时间,表示第二键-值对比第一键值对先失效。在访问数据时,如果两个键-值对均被查找到,说明该数据暂时不会失效,不做处理;如果只查找到一个键-值对,说明该数据即将失效,则将该数据返回给请求方的同时,从数据库中重新读取该数据并重新设置失效时间。可见,本发明的技术方案是随着用户访问的同时,对缓存中数据的失效时间进行检查,一旦检查到热数据即将失效,则重新从数据库中读取并设置,从而保证热数据一直存在缓存中,解决缓存中热数据失效的问题,避免请求者从数据库中访问热数据,影响访问速度的情况。
在本发明的一个实施例中,保存在缓存中的数据为热数据,首先设定一个预设值,这里所说的热数据为数据库中的被访问频率高于预设值的数据,该预设值根据缓存的大小以及热数据的量进行设定,若热数据的量比较多,那么设定一个标准较高的预设值,保证热数据进入缓存。因为缓存的存储空间有限,并不是所有的热数据都可以进入缓存,只有访问频率表较高的热数据才可以进入,这里的访问频率较高的热数据可以通过第一预设时间进行限制,设定的第一预设时间短,则限定的热数据的访问时间的间隔短,即访问频率高。
在本发明的一个实施例中,图1所示的方法进一步包括:如果从缓存中查找到第一键-值对,也查找到第二键-值对,说明该数据在下一次被访问时还不会失效,则仅将第一键-值对中的值返回给请求方,不作其他处理。
在本发明的一个实施例中,图1所示的方法进一步包括:如果从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。因为本发明的技术方案可以保证热数据在缓存中,不存在失效问题,所以如果从缓存中未查找到第一键-值对,则说明请求的数据是非热数据,则直接从数据库中获取该数据请求所请求的数据返回给请求方。
在本发明的一个实施例中,步骤S110中,用第一键-值对存放该数据本身,用第二键-值对标记该数据的预失效时间包括:将第一键-值对中的值设置为该条数据本身;将第二键-值对中的值设置为固定值或任意值,这里的固定值或任意值可以为“null”,也可以随意设定,但不具有任何意义,请求者进行数据请求时,得到的返回数据为第一键-值对中的值,第二键-值对只是为了配合程序进行数据失效时间的检测。例如,访问某一文具供应商的数据库,其访问频率最高的商品为铅笔和钢笔,那么将铅笔和钢笔对应的库存量数据放入缓存,设置数据时,对应铅笔的数据,则设置两个键-值对,分别为铅笔-200;铅笔EX-“null”;对应钢笔的数据,则设置两个键-值对,分别为钢笔-300;钢笔EX-“0”。
为每次进行数据的设置或者重置的方便,在本发明的一个实施例中,将第一预设时间对应的时间值和第二预设时间对应的时间值保存到指定位置;每次设置或重置一条数据的第一预设时间和第二预设时间时,从指定位置读取对应的时间值并进行设置或重置。
进一步地,因为缓存的储存空间有限,为了访问效率缓存中应当存储最热的数据,即访问频率最高的数据。但是热数据不是一成不变的。比如,缓存中只能存储1000条数据,在初始时,为了将最热的1000条数据放入缓存中,根据该最热的1000条数据中的最低访问频率设定第一预设时间为30ms;但是随着访问量的改变,访问频率盖与所述最低访问频率的数据远远超出1000条,例如有2000条。此时还将第一预设时间设置为30ms,缓存已经不能将改变后所有的热数据都存储其中,且新增加的较热的数据可能也进不到缓存,即不能保证当前最热的1000条数据在缓存中。对此,在本发明的一个实施例中,为了保证最热的数据能进入缓存,一方面可以重新设定预设值,以重新定义热数据;另一方面,随着热数据的访问频率和缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值;每次设置或重置一条数据的第一预设时间和第二预设时间,从指定位置读取对应的时间值并进行设置或重置,如果该数据的访问频率符合重置后的第一预设时间,那么此数据为访问频率较高的热数据,会一直存储在缓存中,如果该数据的访问频率不符合重置后的第一预设时间,则说明该数据虽为热数据,但是访问频率没有其他数据的高,则在该数据不会一直存储在缓存里。
图2示出了根据本发明一个实施例提供的一种缓存数据的装置示意图。如图2所示,该缓存数据的装置200包括:
缓存处理单元210,适于对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
请求处理单元220,适于当收到一数据请求时,根据该数据请求在缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对时,将第一个键对应的值返回给请求方,并向缓存处理单元发送第一通知;
所述缓存处理单元210,进一步适于收到第一通知时,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
在本发明的一个实施例中,保存在缓存中的数据为热数据,热数据为数据库中的被访问频率高于预设值的数据。
在本发明的一个实施例中,请求处理单元220,进一步适于当从缓存中查找到第一键-值对,也查找到第二键-值对时,将第一键-值对中的值返回给请求方,不作其他处理。
在本发明的一个实施例中,请求处理单元220,进一步适于当从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
在本发明的一个实施例中,缓存处理单元210,适于将第一键-值对中的值设置为该条数据本身,将第二键-值对中的值设置为固定值或任意值。
在本发明的一个实施例中,第一预设时间对应的时间值和第二预设时间对应的时间值保存在指定位置。
则缓存处理单元210,适于在每次设置或重置一条数据的第一预设时间和第二预设时间,从指定位置读取对应的时间值并进行设置或重置。
图3示出了根据本发明另一个实施例提供的一种缓存数据的装置示意图。该缓存数据的装置300包括:缓存处理单元310、请求处理单元320和参数调整单元230。其中,缓存处理单元310、请求处理单元320和图2所示装置的缓存处理单元210、请求处理单元220具有对应相同的功能,相同的部分在此不再赘述。
参数调整单元230,适于根据数据的访问频率以及缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值。
需要说明的是,图2和图3所示装置的各实施例与图1所示方法的各实施例对应相同,上文已有详细说明,在此不再赘述。
根据本发明的技术方案,在进行数据缓存时设置与该数据对应的两个键-值对,第一键-值对存放该数据本身,并设置其在缓存中的有效时间为第一预设时间,第二键-值对标记该数据的预失效时间,并将其在缓存中的有效时间为第二预设时间,第一预设时间大于第二预设时间,表示第二键-值对比第一键值对先失效。在访问数据时,如果两个键-值对均被查找到,说明该数据暂时不会失效,不做处理;如果只查找到一个键-值对,说明该数据即将失效,则将该数据返回给请求方的同时,从数据库中重新读取该数据并重新设置失效时间。可见,本发明的技术方案是随着用户访问的同时,对缓存中数据的失效时间进行检查,一旦检查到热数据即将失效,则重新从数据库中读取并设置,从而保证热数据一直存在缓存中,解决缓存中热数据失效的问题,避免请求者从数据库中访问热数据,影响访问速度的情况。综上所述,本发明能保证缓存中的数据不失效,保证数据的访问速度,增强用户的体验。
需要说明的是:
在此提供的算法和显示不与任何特定计算机、虚拟装置或者其它设备固有相关。各种通用装置也可以与基于在此的示教一起使用。根据上面的描述,构造这类装置所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的缓存数据的装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
本发明提供了A1、一种缓存数据的方法,包括:
对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对,则将第一键-值对中的值返回给请求方,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
A2、如A1所述的方法,其中,
保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
A3、如A1所述的方法,其中,该方法进一步包括:
如果从缓存中查找到第一键-值对,也查找到第二键-值对,则将第一键-值对中的值返回给请求方,不作其他处理。
A4、如A1所述的方法,其中,该方法进一步包括:
如果从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
A5、如A1所述的方法,其中,所述用第一键-值对存放该数据本身,用第二键-值对标记该数据的预失效时间包括:
将第一键-值对中的值设置为该条数据本身;
将第二键-值对中的值设置为固定值或任意值。
A6、如A1-A5中任一项所述的方法,其中,
将所述第一预设时间对应的时间值和第二预设时间对应的时间值保存到指定位置;
每次设置或重置一条数据的第一预设时间和第二预设时间,从所述指定位置读取对应的时间值并进行设置或重置。
A7、如A6所述的方法,其中,该方法进一步包括:
根据数据的访问频率以及缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值。
本发明还提供了B8、一种缓存数据的装置,其中,该装置包括:
缓存处理单元,适于对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
请求处理单元,适于当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对时,将第一个键对应的值返回给请求方,并向缓存处理单元发送第一通知;
所述缓存处理单元,进一步适于收到第一通知时,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
B9、如B8所述的装置,其中,
保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
B10、如B8所述的装置,其中,
所述请求处理单元,进一步适于当从缓存中查找到第一键-值对,也查找到第二键-值对时,将第一键-值对中的值返回给请求方,不作其他处理。
B11、如B8所述的装置,其中,
所述请求处理单元,进一步适于当从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
B12、如B8所述的装置,其中,
所述缓存处理单元,适于将第一键-值对中的值设置为该条数据本身,将第二键-值对中的值设置为固定值或任意值。
B13、如B8-B12中任一项所述的装置,其中,所述第一预设时间对应的时间值和第二预设时间对应的时间值保存在指定位置;
所述缓存处理单元,适于在每次设置或重置一条数据的第一预设时间和第二预设时间,从所述指定位置读取对应的时间值并进行设置或重置。
B14、如B13所述的装置,其中,该装置进一步包括:
参数调整单元,适于根据数据的访问频率以及缓存的大小,调整第一预设时间对应的时间值和第二预设时间对应的时间值。

Claims (10)

1.一种缓存数据的方法,包括:
对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对,则将第一键-值对中的值返回给请求方,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
2.如权利要求1所述的方法,其中,
保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
3.如权利要求1所述的方法,其中,该方法进一步包括:
如果从缓存中查找到第一键-值对,也查找到第二键-值对,则将第一键-值对中的值返回给请求方,不作其他处理。
4.如权利要求1所述的方法,其中,该方法进一步包括:
如果从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
5.如权利要求1所述的方法,其中,所述用第一键-值对存放该数据本身,用第二键-值对标记该数据的预失效时间包括:
将第一键-值对中的值设置为该条数据本身;
将第二键-值对中的值设置为固定值或任意值。
6.一种缓存数据的装置,其中,该装置包括:
缓存处理单元,适于对于一条数据,在缓存中设置与该数据对应的两个键-值对;其中,用第一键-值对存放该数据本身,设置其在缓存中的有效时间为第一预设时间;用第二键-值对标记该数据的预失效时间,设置其在缓存中的有效时间为第二预设时间;第二预设时间小于第一预设时间;
请求处理单元,适于当收到一数据请求时,根据该数据请求在所述缓存中查找与请求的数据对应的两个键-值对;如果从缓存查找到第一键-值对,但未查找到第二键-值对时,将第一个键对应的值返回给请求方,并向缓存处理单元发送第一通知;
所述缓存处理单元,进一步适于收到第一通知时,从数据库重新读取该请求的数据来更新缓存中对应的第一键-值对中的值,并重新设置对应的第二键-值对以及对应的第一预设时间和第二预设时间。
7.如权利要求6所述的装置,其中,
保存在所述缓存中的数据为热数据,所述热数据为数据库中的被访问频率高于预设值的数据。
8.如权利要求6所述的装置,其中,
所述请求处理单元,进一步适于当从缓存中查找到第一键-值对,也查找到第二键-值对时,将第一键-值对中的值返回给请求方,不作其他处理。
9.如权利要求6所述的装置,其中,
所述请求处理单元,进一步适于当从缓存未查找到第一键-值对,则从数据库中获取该数据请求所请求的数据返回给请求方。
10.如权利要求6所述的装置,其中,
所述缓存处理单元,适于将第一键-值对中的值设置为该条数据本身,将第二键-值对中的值设置为固定值或任意值。
CN201610804195.4A 2016-09-05 2016-09-05 一种缓存数据的方法和装置 Active CN106407347B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201610804195.4A CN106407347B (zh) 2016-09-05 2016-09-05 一种缓存数据的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610804195.4A CN106407347B (zh) 2016-09-05 2016-09-05 一种缓存数据的方法和装置

Publications (2)

Publication Number Publication Date
CN106407347A true CN106407347A (zh) 2017-02-15
CN106407347B CN106407347B (zh) 2019-08-06

Family

ID=57998514

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610804195.4A Active CN106407347B (zh) 2016-09-05 2016-09-05 一种缓存数据的方法和装置

Country Status (1)

Country Link
CN (1) CN106407347B (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107291920A (zh) * 2017-06-28 2017-10-24 南京途牛科技有限公司 一种机票查询缓存方法
CN110837513A (zh) * 2019-11-07 2020-02-25 腾讯科技(深圳)有限公司 一种缓存更新方法、装置、服务器及存储介质
WO2022041812A1 (zh) * 2020-08-28 2022-03-03 平安科技(深圳)有限公司 一种数据处理方法、相关设备及计算机可读存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103401950A (zh) * 2013-08-21 2013-11-20 网宿科技股份有限公司 缓存异步刷新方法、缓存服务器处理请求方法和系统
CN104391862A (zh) * 2014-10-23 2015-03-04 北京锐安科技有限公司 一种缓存数据更新方法及装置
CN104657401A (zh) * 2014-10-21 2015-05-27 北京齐尔布莱特科技有限公司 一种web缓存的更新方法
CN105095282A (zh) * 2014-05-14 2015-11-25 腾讯科技(深圳)有限公司 一种缓存数据更新方法、装置及系统
CN105608115A (zh) * 2015-12-11 2016-05-25 北京奇虎科技有限公司 数据获取方法与装置
CN105630819A (zh) * 2014-11-03 2016-06-01 阿里巴巴集团控股有限公司 一种缓存数据的刷新方法和装置

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103401950A (zh) * 2013-08-21 2013-11-20 网宿科技股份有限公司 缓存异步刷新方法、缓存服务器处理请求方法和系统
CN105095282A (zh) * 2014-05-14 2015-11-25 腾讯科技(深圳)有限公司 一种缓存数据更新方法、装置及系统
CN104657401A (zh) * 2014-10-21 2015-05-27 北京齐尔布莱特科技有限公司 一种web缓存的更新方法
CN104391862A (zh) * 2014-10-23 2015-03-04 北京锐安科技有限公司 一种缓存数据更新方法及装置
CN105630819A (zh) * 2014-11-03 2016-06-01 阿里巴巴集团控股有限公司 一种缓存数据的刷新方法和装置
CN105608115A (zh) * 2015-12-11 2016-05-25 北京奇虎科技有限公司 数据获取方法与装置

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107291920A (zh) * 2017-06-28 2017-10-24 南京途牛科技有限公司 一种机票查询缓存方法
CN107291920B (zh) * 2017-06-28 2021-02-02 南京途牛科技有限公司 一种机票查询缓存方法
CN110837513A (zh) * 2019-11-07 2020-02-25 腾讯科技(深圳)有限公司 一种缓存更新方法、装置、服务器及存储介质
CN110837513B (zh) * 2019-11-07 2023-05-12 腾讯科技(深圳)有限公司 一种缓存更新方法、装置、服务器及存储介质
WO2022041812A1 (zh) * 2020-08-28 2022-03-03 平安科技(深圳)有限公司 一种数据处理方法、相关设备及计算机可读存储介质

Also Published As

Publication number Publication date
CN106407347B (zh) 2019-08-06

Similar Documents

Publication Publication Date Title
CN107273522B (zh) 面向多应用的数据存储系统和数据调用方法
US9576006B2 (en) Method and system for storing data in a database
US20180239800A1 (en) Data query method and apparatus
CN104809179B (zh) 访问哈希表的装置和方法
CN108255958A (zh) 数据查询方法、装置和存储介质
US10838963B2 (en) Optimized access for hierarchical low cardinality value synopsis in analytical databases
US20140052726A1 (en) Hardware implementation of the aggregation/group by operation: hash-table method
US10585915B2 (en) Database sharding
KR102575913B1 (ko) 비대칭 세트 결합된 캐시
US10078649B2 (en) Pre-caching of relational database management system based on data retrieval patterns
CN105677580A (zh) 访问缓存的方法和装置
CN104216724B (zh) 一种网络应用程序接口升级的方法及系统
US10282437B2 (en) Partial indexes for partitioned tables
CN103607312A (zh) 用于服务器系统的数据请求处理方法及系统
US11409722B2 (en) Database live reindex
CN106407347A (zh) 一种缓存数据的方法和装置
CN112148217B (zh) 全闪存储系统的重删元数据的缓存方法、装置及介质
CN107341114A (zh) 一种目录管理的方法、节点控制器和系统
CN104598652B (zh) 一种数据库查询方法及装置
CN109408539B (zh) 数据操作方法、装置、服务器和存储介质
US10599572B2 (en) Method and device for optimization of data caching
CN104166649A (zh) 一种用于搜索引擎的缓存方法和设备
CN106503260A (zh) 一种提高数据库的有效存储空间的方法和装置
CN102819570B (zh) 一种数据访问方法、装置及系统
CN102682068A (zh) 一种搜索用户名的方法及系统

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20220715

Address after: Room 801, 8th floor, No. 104, floors 1-19, building 2, yard 6, Jiuxianqiao Road, Chaoyang District, Beijing 100015

Patentee after: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Patentee before: Qizhi software (Beijing) Co.,Ltd.