消息事务

2018-05-21 20:07:55 +08:00
 helloworld12

消息事务的转账操作分为两个阶段,在一阶段执行的操作是:“ A 账户扣除 100 元钱”和发送“ B 账户加钱”消息至消息队列,这两个操作要么都成功,要么都失败。

但是,这一阶段,也是要原子操作的,怎么保证呢(这一阶段,再分解出一个 2PC )?

1463 次点击
所在节点    问与答
5 条回复
zhantss
2018-05-22 00:59:42 +08:00
最终一致即可,可以多次重发,保证至少一次就行
实现下防重机制,比如消息上加状态
helloworld12
2018-05-22 08:57:23 +08:00
@zhantss 最终一致是指,发到消息队列以后,从消息队列消费的吧。

但是,扣钱和发送到消息队列,应该也是要强一致的
xiaottt
2018-05-22 09:02:40 +08:00
对账补偿就可以了
zhantss
2018-05-22 11:47:10 +08:00
@helloworld12
A 扣钱加点
B 加钱节点
1.[A 扣钱,发消息(失败重发)( B 不订阅第一步消息)] -> 2.[A commit,确认消息(失败重发)( B 订阅)] -> 3.[B 加钱,本地入账记录消息,commit,反馈消息(失败重发)( A 订阅)] -> 4.[A 删除消息]

1 挂掉,没什么好说的
2 挂掉,A 恢复确认消息,状态不对,继续确认重发
3 挂掉,本地入账之后挂掉,同上状态不对,继续反馈重发,入账前挂掉一个事务,恢复后读消息继续
4 挂掉,恢复或继续删除

多次重发的消息,在 B 上有入账,对账后丢掉就行,在 A 上多次反馈无所谓,删除就是收个尾
helloworld12
2018-05-22 13:59:17 +08:00
@zhantss 嗯,想了下,用消息的好处就是 [业务] 的不确定性(可能时间很长,可能容易失败。。。),被修改为确定的 [发送消息] 操作

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/456624

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX