gpt4 book ai didi

java - 搜索引擎中的缓存管理

转载 作者:行者123 更新时间:2023-11-30 07:23:03 26 4
gpt4 key购买 nike

我想知道缓存管理的最终解决方案是什么。假设我有一台服务器和连接到它的无限数量的客户端。客户端不断向服务器发送搜索请求(我们将客户端的搜索请求称为“x”),服务器用一些“y”回答客户端。现在,为了加快我的搜索引擎速度,我想将最流行的请求(x)及其答案(y)保存在缓存中。(请注意,对于客户端发送到服务器的每个相同的 x ,它们必须获得相同的 y 很重要)。我还得到了一个数据库,其中保存了所有以前的请求(x,y,z - x 请求的次数)。

我在更新缓存时遇到了一些问题:

  1. 我如何知道我最不受欢迎的请求保留在缓存中的哪个索引中,以便在我在数据库中找到更受欢迎的查询时替换它(当然无需扫描整个缓存)。

  2. 我应该如何更新缓存? (只是扫描整个数据库?这是相当昂贵的操作)

3.我的缓存应该包含多少请求元素?

4.你认为HashMap是维护缓存的有效数据结构吗?(我正在使用java)。

5.i 正在考虑根据最后的 T(某个数字)查询来更新我的缓存,而不是在遍历数据库上的所有请求时更新它。因为也许有一些请求曾经非常流行,但现在不再流行了,如果有一个新的流行请求,根据节目的数量,它可能需要很长时间才能进入缓存(它也必须更快,因为我不必扫描整个数据库)。这是管理缓存的合法方法吗?

最佳答案

一位单例汉要求计算机为他找到完美的伴侣。

“我想要一个小而有吸引力、热爱水上运动并喜欢集体 Activity 的伴侣。”

计算机回答:“玛丽是一只企鹅”

(引自:http://www.recipeapart.com/perfect-partner/#ixzz48iEVSp1y)

如果您有无限数量的客户端,最终缓存解决方案将是让客户端转发您的数据。您可以通过互联网做到这一点。正在执行此操作的示例应用程序可用,例如有点洪流。

当您缩小了需求范围后,请查看各种开源 Java 缓存实现:

  • Apache 点燃
  • Apache Java 缓存系统
  • Apache Geode
  • inifinispan
  • 淡褐色
  • EHCache
  • 谷歌 Guava
  • 咖啡因
  • cache2k

开始使用一个。阅读手册。

阅读我的博客:cruftex.net

不同的场景需要不同的解决方案。

据我所知,这些项目都没有成功构建终极缓存。据我所知,没有用户能够通过使用所有当前的实现来拥有最终的缓存。

也许我应该将我的缓存实现命名为“终极缓存”。但那样的话,它就不会存在了。

关于java - 搜索引擎中的缓存管理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37231102/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com