持久化:
RDB快照。bgsave命令。创建子线程将数据以二进制的方式写入dump.rdb文件。
AOF文件追加。每次执行命令的时候。往这个文件中写入执行的命令。有三个策略一个是always。完全持久化,everysec 每秒一次。 no看操作系统的一般是30秒。
混合持久化模式:先进行rdb把现有的数据压缩近dump.rdb文件。然后AOF把之后的每个命令追加到文件中。
内存淘汰:
LRU:长时间不使用的淘汰 LFU:访问次数少的淘汰 TTL:设置了过期时间的先淘汰
随机淘汰:随便选这淘汰。redis的淘汰机制是有过期时间的LRU,LFU,TTL,随机淘汰。没有过期时间的LRU,LFU,TTL,随机淘汰
过期删除:惰性删除:再次使用时删除。 定时删除:创建定时器然后去删除。每隔一段时间删除过期。
redis和mysql数据一致:
1:先更新mysql,在更新redis。如果更新redis失败就会出现不一致。
2:先删除redis然后再更新mysql,查询时会先查询mysql然后更新到redis。并发情况下会有问题。在删除redis之后更新mysql之前如果有其他线程进入就又会把旧的mysql数据读入redis中。
3:延时双删除:先删除redis,再更新mysql,延时几百毫秒。再删除一遍redis。这样就保证再次读取的时候会重新读取mysql中的数据。保证一致性。
为什么要延时:
删redis,更新数据库,延时500毫秒(目的是等待其他线程更新redis,因为此时更新的redis不一定是最新的。),删redis.