Kev*_*sey 6 java project-reactor spring-webflux
我正在使用第三方库来注册 MessageListener,当发生某些事件时,它们会调用注册的侦听器 onMessage 方法
public interface MessageListener {
// third party code, it auto-scans for all MessageListeners and registers them
void onMessage(Message message);
}
public class SimpleMessageListener implements MessageListener {
public void onMessage(Message message) {
//do something non blocking
//is it possible to 'transmit' to messagePublisher
}
public Flux<Message> messagePublisher() {
// a method to which to subscribeOn
}
}
Run Code Online (Sandbox Code Playgroud)
所以我的问题是将其转变为 Flux 的最佳方法是什么
最后我希望能够做这样的事情
messagePublisher().subscribe(System.out::println);
Run Code Online (Sandbox Code Playgroud)
************** 编辑 我的第一次尝试是这样的
private List<FluxSink<Message>> handlers = new ArrayList<>();
public void onMessage(Message message) {
handlers.forEach(han -> han.next(message));
}
public Flux<Message> messagePublisher() {
return Flux.create(sink -> {
handlers.add(sink);
sink.onDispose(() -> handlers.remove(sink));
});
}
Run Code Online (Sandbox Code Playgroud)
这是可行的 - 但我觉得这不是一个很好的解决方案,让该类实现 FluxSink 并手动处理是否更好 - 目前我预计不会有很多订阅者。但有很多 MessageListener(每种类型一个)
您可以创建一个Flux实例来桥接 观察到的消息MessageListener,例如
public class SimpleMessageListener implements MessageListener {
private FluxSink<Message> handler;
private Flux<Message> flux;
public SimpleMessageListener() {
flux = Flux.create(emitter -> {
handler = emitter;
}, OverflowStrategy.DROP); // or some other overflow strategy
}
public void onMessage(Message message) {
if (handler != null) {
/*
* null check is required to avoid NPE if a message is received
* before any subscription occurs since handler is instantiated
* lazily when the first subscription is requested
*/
handler.next(message);
}
}
public Flux<Message> messagePublisher() {
return flux;
}
}
Run Code Online (Sandbox Code Playgroud)
messsagePublisher() Flux现在,所有侦听器都可以使用 Flux 的publish()方法及其返回的ConnectableFlux订阅同一实例:
// fetch message publisher
Flux<Message> messagePublisher = messageListener.messagePublisher();
// prepare ConenctableFlux
ConnectableFlux<Message> connectableFlux = messagePublisher().publish();
// register subscribers
connectableFlux.subscribe(/* aConsumer */);
connectableFlux.subscribe(/* aCoreSubscriber */);
connectableFlux.subscribe(/* aSubscriber */);
// connect the ConnectableFlux to messagePublisher
connectableFlux.connect();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2099 次 |
| 最近记录: |