如何保持redis和DB的数据一致性

Posted 骑着蜗牛看海丫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何保持redis和DB的数据一致性相关的知识,希望对你有一定的参考价值。

其实还是得结合业务来思考,我这里给几个思路:

比如你拿个数据要写库,你先根据主键查一下,如果这数据都有了,你就别插入了,update 一下好吧。
比如你是写 Redis,那没问题了,反正每次都是 set,天然幂等性。
比如你不是上面两个场景,那做的稍微复杂一点,你需要让生产者发送每条数据的时候,里面加一个全局唯一的 id,类似订单 id 之类的东西,然后你这里消费到了之后,先根据这个 id 去比如 Redis 里查一下,之前消费过吗?如果没有消费过,你就处理,然后这个 id 写 Redis。如果消费过了,那你就别处理了,保证别重复处理相同的消息即可。
比如基于数据库的唯一键来保证重复数据不会重复插入多条。因为有唯一键约束了,重复数据插入只会报错,不会导致数据库中出现脏数据。

以上是关于如何保持redis和DB的数据一致性的主要内容,如果未能解决你的问题,请参考以下文章

如何保持MySQL和Redis的一致性?

如何保持MySQL和Redis的一致性?

Redis 如何与数据库事务保持一致

面试官问:Redis的操作如何与数据库事务保持一致

《果然新鲜》电商项目(26)- Redis如何与数据库状态保持一致?

mysql 如何解决数据一致性