gpt4 book ai didi

java - 使用分布式 JVM 缓存同步计算和结果

转载 作者:行者123 更新时间:2023-12-03 13:11:49 24 4
gpt4 key购买 nike

我想缓存一个昂贵的操作,并且不希望其他线程在不同的 JVM 中在给定时间执行相同的操作。我们保证在同一时间为同一计算获得至少 5 个近乎实时的请求,并且对简化这些请求没有任何控制。

我能想到的解决方案:

  1. These other threads could wait to acquire lock (Hazelcast) but if there are more threads the last one to acquire lock could spend a lot of time waiting to acquire the lock.

Is there was a way for these other threads to simply "wait for lock to be released" and NOT to acquire the lock as they are simply reading from cache?

  1. Use polling. First a blocking threadId=cache.putIfAbsent(key) returns which thread will process and others will keep polling another cache entry by threadId to get the result. This is a waste of polling, is there a way to "wait for a read from cache"?

  2. An actual distributed "Shared Reentrant Read Write Lock" seems to be the solution but Apache Curator library does not seem light weight. And I am looking for a simple async P2P distributed cache approach.



或者我如何使用 HazelCast 达到同样的效果?
总的来说,首先阻塞和避免计算(在我们的例子中是 CPU 和 IO 限制)不是比让所有线程计算并说使用数据库/缓存失败额外写入并返回第一个计算结果更好的方法吗?

最佳答案

不久前做了以下事情,首先有一个已经使用 Hazelcast 发布的解决方案:https://github.com/ThoughtWire/hazelcast-locks .

该库替代了分布式“共享可重入读写锁”,允许在写入时锁定,但在读取时不允许锁定,因此我们保证这只发生一次。我们面临的唯一问题是锁定释放通知的等待时间比我们预期的要长。除此之外,您必须在特定时间后以某种方式显式清理昂贵的锁,因为它们与特定的键相关联。

我们最终在请求到达 tomcat 容器之前在转发代理中实现了一个自定义逻辑,该容器基本上根据 key 将请求路由到特定服务器,并且我们基于相同的 key 在共享并发映射条目上设置了本地 JVM 锁工作。此外,清理逻辑要简单得多。

关于java - 使用分布式 JVM 缓存同步计算和结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29766666/

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