轻量级消息总线库 [已关闭]
我将在不久的将来启动一个小型Java(实际上是GWT)项目,我正处于“信息收集”阶段。
问:是否有用 Java 编写的轻量级消息总线库?
我的要求也很轻量级:-)
- 异步(无需同步)
- 多播和点对点
- 没有严格的消息排序
- 消息“信封”理想情况下由消息总线“拥有”(即在生命周期管理方面)
- 本地化交付(即不是进程间或节点间)
更新:似乎GWT现在支持集成的“事件总线”。
我将在不久的将来启动一个小型Java(实际上是GWT)项目,我正处于“信息收集”阶段。
问:是否有用 Java 编写的轻量级消息总线库?
我的要求也很轻量级:-)
更新:似乎GWT现在支持集成的“事件总线”。
我知道这是一个古老的问题,但我认为一个更现代的解决方案是使用Guava的事件总线(当然我不确定它是否适用于GWT,但你的标题和标签都没有说GWT)。
我实际上有一个自定义的RabbitMQ简单消息容器,它将自动创建队列绑定,然后在收到的消息上调度到Guava EventBus。它令人难以置信的优雅,并且比例极高。
您可以轻松地使用 DI 框架注册订阅服务器。对于春季,我创建了BeanPostProcessor,它将自动向.@Subscribe
以下是Spring BeanPostProcessor:
package com.snaphop.spring;
import java.lang.reflect.Method;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.stereotype.Component;
import com.google.common.eventbus.EventBus;
import com.google.common.eventbus.Subscribe;
@Component
public class EventBusBeanPostProcessor implements BeanPostProcessor {
private EventBus eventBus;
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
if (isApplicable(bean)) {
eventBus.register(bean);
}
return bean;
}
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
return bean;
}
protected boolean isApplicable(Object bean) {
for(Method m : bean.getClass().getMethods()) {
if (m.isAnnotationPresent(Subscribe.class))
return true;
}
return false;
}
@Autowired
public void setEventBus(EventBus eventBus) {
this.eventBus = eventBus;
}
}
我敢肯定,在Guice中做类似的事情是微不足道的。