素材牛VIP会员
数据库读写分离与支付回调的操作
 wa***ao  分类:SQL代码  人气:974  回帖:3  发布于6年前 收藏

我在想数据库做读(A)写(B)分离,如果遇到支付回调,中间肯定是会有事务,需要多次查询(A)和写入(B),操作多个不同主机的库(A,B),怎么保持数据完整性

比如支付回调过来,先验证,在开启事务,去A里查,写B,在查A,在写B,事务不会出问题?

用的数据库读写分离,回调支付的时候肯定是多读与多写,怎么保证在一个事务里可以将事务操作成功

 标签:mysqlphp

讨论这个帖子(3)垃圾回帖将一律封号处理……

Lv5 码农
zz***25 其它 6年前#1

首先要明确,开启事务是针对一个数据库的,也就是针对主数据库的,开启事务后你不能去从数据库查询(也不能去从数据库查询,因为查询的加锁操作是写入操作),所以总的来说,整个事务操作都应该是针对主数据库的,不存在你说的去A查再到B写的问题。

Lv1 新人
风***扬 Web前端工程师 6年前#2

@junze 分库的问题,你的主从库数据同步是实时的么?主库和从库是按照什么样的业务场景来划分的?如何保证主从库的数据一致性问题?

Lv2 入门
he***ba JS工程师 6年前#3

楼主的业务量如果很大 可以考虑分库 安装用户的ID取余分库 然后性能问题也能解决 事物问题也能解决 我公司现在的业务就用了分库

 文明上网,理性发言!   😉 阿里云幸运券,戳我领取