文章详情页
redis与mysql一致性问题
浏览:243日期:2022-06-21 15:48:16
问题描述
应用在电商购物库存场景1、用户下单后 redis对库存id做增加(件数)2、用户付款成功后 redis对库存id做减少(件数),同时减少mysql里的库存
问题是:流程中出现问题,mysql可以做数据回滚,但redis不可以除了记录日志分析外,有较好办法可以解决这个问题么
问题解答
回答1:你指得MySQL回滚是事务的回滚吗?
既然流程出问题了,那代码应该能捕获到出问题了,手动回滚redis即可。或者等流程事务成立提交后,再修改redis。
回答2:还是事物问题。不要把mysql操作当做一件事,redis操作当做另一件事。要把数据增删改当做一件事。不论是mysql还是redis,只要有一个添加删除出错了,就回滚事务。redis请使用pipeline。
回答3:换个思路吧,从产品角度你就应该允许redis的数据是不同步的,就算redis可以持久化,在内存还没有刷到硬盘之前服务器挂了就有丢数据的可能性,你只要保证下单的时候SKU库存是从Mysql检测的即可,就算他绕过了redis,也能保证最终结果是正确的
回答4:mysql做底层逻辑保证,redis建议只做缓存,redis数据定期或者不存在的时候 去和mysql同步。
相关文章:
1. java - 安卓调用c++lib2. javascript - vue 2.0 @click.self 不触发3. 修改数据库表单中的某个相同的字段4. javascript - webpack构建工具重构代码的流程是怎么样的?5. javascript - 如何根据package.json来自动安装包6. java - 使用 RedisTemplate 操作数据7. javascript - 如何使用Canvas改变素材的颜色?8. IOS app应用软件的id号怎么查询?比如百度贴吧的app-id=4779278139. javascript - 问下npm package json中的devDependencies 与dependencies的?10. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?
排行榜

网公网安备