如果先 fireEvent ,我的担忧是如果数据库操作失败,fireEvent 中的通知已经发出怎么办?
如果先操作数据库,那 fireEvent 之后岂不是又要更新一次数据库?
1
felix9ia OP 感觉只能将数据库操作,放到状态机更新成功的方法里,成功了再发通知。 这样就确保了两者的“原子性”?
|
2
ilucio 2025 年 4 月 17 日
简单点:先写数据库然后再发通知
搞复杂点:数据库时顺便记录下消息发送状态,然后在发送消息,同时更新消息状态,再加上消息异常重试机制,这样就能保障最终一致性了 |