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

标签 java caching

我想知道缓存管理的最终解决方案是什么。 假设我有一台服务器和连接到它的无限数量的客户端。 客户端不断向服务器发送搜索请求(我们将客户端的搜索请求称为“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/

相关文章:

c# - LINQ to SQL 缓存问题

caching - Webpack:重新捆绑后 Object(...) 不是函数

java - 递归扫描 SolrJ 文件夹中的文档以建立索引

java - 在 IntelliJ 中使用 Java 8 构建 Scala(2.7.0) maven 项目时出现错误 "error while loading Consumer"

android - ENOTEMPTY : directory not empty, rmdir '/tmp/react-native-packager-cache-02b2ace9b81fa119b172fdfd36d3a3b4e4156b70/cache'

ruby-on-rails - 开发中的 Rails.cache.fetch 缓存

javascript - 如何使用 Angularjs ionic 缓存图像?

java - 我如何知道我的代码在执行时间方面是否高效?

java - 如何在java中转换为CRTP?

java - 当两者都位于路由器后面时,客户端-服务器通信(无端口转发)