========== redis 持久化 ============
1、RDB 速度块 会占用内容 默认方案
RDB是Redis默认持久化机制。RDB相当于快照,保存的是一种状态
优点:
保存速度、还原速度极快
适用于灾难备份
缺点:
小内存的机器不符合使用。RDB机制符合要求就会快照。
2、AOP 存操作命令 占用硬盘 存大量无用命令
如果Redis意外down掉,RDB方式会丢失最后一次快照后的所有修改。如果要求应用不能丢失任何修改,可以采用AOF持久化方式。
AOF:Append-Only File:Redis会将没一个收到写命令都追加到文件中(默认是appendonly.aof)。当Redis重启时会通过重新执行文件中的写命令重建整个数据库的内容。
产生的问题:
有些命令是多余的。
=========== redis与mysql一致性 ===========
一、实时同步
对强一致要求比较高的,应采用实时同步方案,
即查询缓存查询不到再从DB查询,保存到缓存;
更新缓存时,先更新数据库,
再将缓存的设置过期
(建议不要去更新缓存内容,直接设置缓存过期)。
二、缓存穿透
缓存穿透是指查询一个- - 定不存在的数据,由于缓存是不命中时需要
从数据库查询,查不到数据则不写入缓存,这将导致这个不存在的数
据每次请求都要到数据库去查询,造成缓存穿透。
解决办法:
持久层查询不到就缓存空结果,查询时先判断缓存中是
否exists(key) ,如果有直接返回空,没有则查询后返回,
注意insert时需清除查询的key,否则即便DB中有值也查询不到(当然也可以
设置空缓存的过期时间)