搜索

首页  >  问答  >  正文

Redis 缓存和数据库之间的数据校验该怎么做?

数据库是 MySQL,Redis 主要用来读缓存,现需要检测数据和缓存之间的一致性,确保从缓存读取的数据是最新的。该怎么确保这一点呢?

怪我咯怪我咯2798 天前746

全部回复(3)我来回复

  • 怪我咯

    怪我咯2017-04-22 08:58:29

    1,实例化模型的时候,如查询的时候,可以将表的记录总数,最后修改时间等信息保存到模型的一个方法中
    2,查询数据时,将查询条件与表的信息,合并计算一个缓存key,并写入缓存
    3,获取缓存时,将查询条件与表的信息,合并计算一个缓存key,查询缓存,如果表的数据有修改,则缓存无法命中,则获取最新的结果并保存为新的key

    在实际开发中,用的是MVC框架,在模型的CUD操作中,会自动删除与该模型关联的所有缓存key,从而保证数据的一致性。
    这对框架的使用规范要求比较高,需要按模型缓存规范去注册缓存。

    目前比较典型的应用,就是CRUD以后,列表的缓存数据如何更新。

    回复
    0
  • 怪我咯

    怪我咯2017-04-22 08:58:29

    查缓存,没有就将数据库里的数据dump到缓存。
    有数据更新的话,如果对数据一致性不是很高的,那么给缓存里的数据一个ttl就行了;如果对数据一致性要求很高的话,更新数据的时候把缓存清一下。

    回复
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-22 08:58:29

    可以为每个key增加一个字段,表示版本信息。更新数据的更新版本号,查询redis的时候用key+版本号。

    回复
    0
  • 取消回复