把关系型数据库中的数据存储到Redis中,并且,后续需要查询数据时,将优先从Redis中查询(如果Redis中没有,则从关系型数据库中查询,或,如果Redis中没有,直接返回没有数据的结果),这种做法就叫“缓存”数据。
当使用Redis缓存数据后,将存在数据一致性的问题!其典型表现就是:如果关系型数据库中的数据发生了变化,但是,Redis中的数据没有及时一并调整,就会导致Redis中的数据与关系型数据库中的数据并不一致!
对于数据一致性问题,首先,要学会区分,你需要的到底是实时一致性,还是最终一致性。
并且,虽然Redis适合缓存大量的数据,但是,如果某些数据的访问频率非常低,其实,也没有必要缓存到Redis中(需要查询时,直接从关系型数据库中查询即可),否则,任何数据都缓存到Redis中,则任何数据都需要处理数据一致性问题。
所以,适合使用Redis缓存的数据应该是:
- 访问频率较高,甚至很高
- 对数据一致性要求并不严格
- 数据被修改的频率非常低
关于数据一致问题的解决方案大致有:
- 实时同步:修改关系型数据库中的数据时,也一并修改Redis中缓存的数据
- 手动同步:修改关系型数据库中的数据时,不会修改Redis中缓存的数据,仅当管理人员手动操作后,才会将关系型数据库的数据同步到Redis中
- 定时同步:修改关系型数据库中的数据时,不会修改Redis中缓存的数据,但每间隔一段时间,或到了某个特定的时间点,就会自动将关系型数据库的数据同步到Redis中