数据库和缓存一致性的问题
2015-07-18 23:17
435 查看
【云时代的技术博客】【http://cloudate.net/?p=379】
2015/01/13 | DB,Memcache,并发和多线程 | 罗伯特
有一个key/value存储在数据库中,但是缓存在memcache中,对这个key/value有高并发的查询和更新操作,怎么保证数据库和缓存的一致性呢?
问题: 查询时有不一致的情况,如下,
当前最新数据应该是Thread3更新的B, 但是缓存里面是A,出现了不一致的现象,即使在更新缓存的时候使用CAS,还是会出现后者覆盖前者,还是有不一致的现象。
问题: 更新数据库的时候直接提交,那么缓存里数据是B,数据库里面是A,如下,
暂时没有想出来方案3有任何问题,欢迎大家拍砖。
2015/01/13 | DB,Memcache,并发和多线程 | 罗伯特
有一个key/value存储在数据库中,但是缓存在memcache中,对这个key/value有高并发的查询和更新操作,怎么保证数据库和缓存的一致性呢?
方案1 – 更新数据库时失效缓存
when updateDb(key) invalideCache(key) when query(key) updateCache(key)
问题: 查询时有不一致的情况,如下,
Step1: Thread1 getDb(key) = A Step2: Thread3 updateDb(key) = B Step3: Thread2 getDb(key) = B Step4: Thread2 updateCache(key) = B Step5: Thread1 updateCache(key) = A
当前最新数据应该是Thread3更新的B, 但是缓存里面是A,出现了不一致的现象,即使在更新缓存的时候使用CAS,还是会出现后者覆盖前者,还是有不一致的现象。
方案2 – 更新数据库时更新缓存
Step1: cas get cache Step2: update db Setp3: cas set cache
问题: 更新数据库的时候直接提交,那么缓存里数据是B,数据库里面是A,如下,
Thread1 cas get cache with uniqueNum = 1 Thread2 cas get cache with uniqueNum = 1 Thread2 update DB with new value B Thread2 cas set cache B with uniqueNum = 1 Thread1 update DB with new value A Thread1 cas set cache A with uniqueNum = 1, fail
方案3 – 利用数据库的事物/乐观锁和缓存的CAS
数据库在更新缓存成功后进行提交,如果CAS更新缓存失败,那么滚回数据库的提交。Thread1 cas get cache with uniqueNum = 1 Thread1 update DB with new value A Thread1 cas set cache A with uniqueNum = 1 Thread1 commit update DB
Thread2 cas get cache with uniqueNum = 1 Thread2 update DB with new value B Thread2 cas set cache B with uniqueNum = 1 Thread2 commit update DB
暂时没有想出来方案3有任何问题,欢迎大家拍砖。
相关文章推荐
- 数据库还原和日志删除的SQL脚本
- Hibernate中配置数据库方言的作用
- C#操作数据库中的数据常用方法
- MySQL-index
- Sqlite数据库创建、删除、降级笔记
- 一些MongoDB集群维护使用方法
- 数据库性能优化
- mongodb的安装(window)及java连接测试
- SparkSQL(Spark-1.4.0)实战系列(三)——SparkSQL应用案例
- MongoDB集群架构及搭建
- 数据库基本特性
- Oracle安装配置—64位Win7安装配置64位Oracle
- MyBatis知多少(11)企业数据库
- MySQL 数据类型
- oracle练习题
- SQL连接
- Navicat Premium11.0.16 for mac 破解
- 为什么 as sysdba着陆方法oracle数据库,为什么刚刚输入username和password我们都可以登录?
- sql server创建外键,子母表,级联删除。
- redis 3.0.1 在CentOS上的安装