我处理反应式编程的主题。我使用 WebFlux 和 R2dbc 来访问数据库。我正在为聊天应用程序开发一个小型后端。所以我有一些关于这个主题的问题,我会很高兴提出建议和改进。
这是服务等级
@Service
public class MessageService implements IMessageService {
UnicastProcessor<Message> hotProcessor = UnicastProcessor.create();
private final FluxSink<Message> fluxSink = hotProcessor.sink(FluxSink.OverflowStrategy.LATEST);
private final Flux<Message> hotFlux = hotProcessor.publish().autoConnect();
@Autowired
private MessageRepository messageRepository;
public Flux<Message> findAll() {
return this.messageRepository.findAll();
}
public Mono<Message> create(Message nachricht) {
this.fluxSink.next(nachricht);
return this.messageRepository.save(nachricht);
}
// how can I persist messages and to arrange a chat room.
public Flux<Message> finAllMessagesByChatroomId(Long id) {
return hotFlux.filter(m->m.getId().intValue() == id.intValue());
}
}
DirectProcessor 什么时候应该使用 UnicastProcessor。
更新:
一点修正
public Flux<Message> finAllMessagesByChatroomId(Long id) {
return hotFlux.filter(m->m.getRoom_id == id);
}
但是如何从数据库中获取所有消息并将其添加到fluxSink?