首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java:跨多个服务器同步线程

Java:跨多个服务器同步线程
EN

Stack Overflow用户
提问于 2009-04-03 21:18:52
回答 3查看 5.3K关注 0票数 5

我有一个问题,我需要为Windows上的Java服务跨多个不同的服务器同步多个线程的处理。

在这个应用程序中,我有多个使用者线程从同一个JMS队列中提取消息。消息以3个或4个为一组进入,我需要确保每个组中的消息都是完全串行处理的。我需要某种同步机制来确保如果thread1拉出一条消息,然后thread2从该组中拉出下一条消息,thread2等待thread1完成处理,然后开始处理它的消息。

对线程的分布式同步机制有什么建议吗?任何类型的解决方案都是好的(JMS解决方案、分布式缓存等)

注意:我们使用的JMS提供者是ActiveMQ。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-04-03 21:23:57

ActiveMQ支持message groups,从字面上看,这正是您所需要的。

票数 8
EN

Stack Overflow用户

发布于 2009-04-05 19:44:59

您可能需要考虑使用Hazelcast分布式锁。超级轻量级,简单,开源。

代码语言:javascript
复制
java.util.concurrent.locks.Lock lock = Hazelcast.getLock ("mymonitor");
lock.lock ();
try {
// do your stuff
}finally {
   lock.unlock();
}

致以敬意,

-talip

Hazelcast -开源分布式队列、映射、集合、列表、锁定

票数 8
EN

Stack Overflow用户

发布于 2009-04-03 21:27:19

邮件头中是否有类似于组ID的内容?如果是这样的话,使用者可以创建一个Selector来按顺序处理该组。

将组分配给特定的使用者可以通过散列组标识符来完成,或者它们可以使用某种共识协议(如Paxos或虚拟同步)主动地相互协调(消息通过单独的队列发送)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/715754

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档