数据库是 MySQL,Redis 主要用来读缓存,现需要检测数据和缓存之间的一致性,确保从缓存读取的数据是最新的。该怎么确保这一点呢?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
1,实例化模型的时候,如查询的时候,可以将表的记录总数,最后修改时间等信息保存到模型的一个方法中
2,查询数据时,将查询条件与表的信息,合并计算一个缓存key,并写入缓存
3,获取缓存时,将查询条件与表的信息,合并计算一个缓存key,查询缓存,如果表的数据有修改,则缓存无法命中,则获取最新的结果并保存为新的key
在实际开发中,用的是MVC框架,在模型的CUD操作中,会自动删除与该模型关联的所有缓存key,从而保证数据的一致性。
这对框架的使用规范要求比较高,需要按模型缓存规范去注册缓存。
目前比较典型的应用,就是CRUD以后,列表的缓存数据如何更新。
你好,我是AI助理
可以解答问题、推荐解决方案等
评论
全部评论 (0)