Redis-缓存持久篇

本文是继上一篇Redis-安装启动篇之后。

Redis的缓存持久化分为四种情况:
  1. RDB方式:以.rdb文件的形式存储数据。
    优点:只包含一个文件,利于备份、数据转移等操作。适合处理量大的数据。
    缺点:在保存数据时会有短暂的停顿。
    数据有相对应的保存间隔,服务器异常容易丢数据,不安全。
  2. AOF方式(Append Only File):以指定的形式追加到对应文件的末尾。
    优点:采用追加方式,不会影响以前的数据,安全。
    如果在写入一半时出现问题,可以使用redis-check-aof来修复数据一致性的问题。
    缺点:文件大,同步效率低。不适合做数据备份。
  3. 无持久化:此时Redis值能作为缓存过渡数据库。
  4. 同时使用AOF和RDB:AOF和RDB同时进行配置。
Redis的缓存持久化配置:
  1. RDB配置:
    修改dbfilename(dump数据库保存的文件名)dir(保存数据库文件的目录)。
Redis-缓存持久篇_第1张图片
RDB配置.png

//save 时间 次数的说明 TODO

  1. AOF配置:
    AOF的默认文件为appendonly.aof(此aof文件会和dmp文件在同一处出现)。
    修改追加方式appendfsync(要使用哪条,前面的#号去掉,给不用的加#)。
    AOF数据追加形式:
    appendfsync:always(一直执行此方法)
    appendfsync:everysec(每秒自动同步到磁盘)
    appendfsync:no(不追加)
缓存清除策略:
  • noeviction: 不清除。返回内存限制错误。
  • allkeys-lru: 在所有key中执行LRU清除策略。
  • volatile-lru: 在已设置过期的key中执行LRU清除策略。
  • allkeys-random: 在所有key中随机清除。
  • volatile-random: 在已设置过期的key中执行随机清除。
  • volatile-ttl:清除带有过期设置的,并且只有短时间TTL(存活)的。

使用情况:
allkeys-lru:你想让经常访问的请求以幂次数的形式分布。或者不确定的情况下。
allkeys-random:你有一个连续循环访问或者你期望key均匀分布。
volatile-ttl:当你在创建缓存对象时使用了不同的存活时间并提供给redis时。

在redis-cli中输入info,可以找到以下信息:


Redis-缓存持久篇_第2张图片
info信息.png

其中,expired_keys:已经过期的key;evicted_keys:已经清除的key;
keyspace_hits:使用到的key;keyspace_misses:消失的key。
使用到的key/(使用到的key+消失的key)就是现有key的使用率,使用率在95%以上时,说明缓存机制效果好。

配置:在redis.conf中:
其中maxmemory:可以设置大小。比如15mb等。
maxmemory-policy:清除策略。默认不清除。

Redis-缓存持久篇_第3张图片
缓存清除策略.png
Redis的LRU算法:

redis的LRU算法受控于

maxmemory-samples 5

这个值越大,缓存清除不常用的就越多。但带来的负面影响是耗内存,达不到缓存的效果。

Redis的LFU算法(4.0以后推出):

LFU算法在某些时候,对于使用频繁的key将不再考虑,即便是旧的。防止频繁的key来占用算法。

  • volatile-lfu 在已设置过期的key中执行LFY清除策略。
  • allkeys-lfu 在所有的key中执行LFU清除策略。
    redis的LFU算法受控于
lfu-log-factor 10
lfu-decay-time 1

factor越高,可以达到饱和(极限)容纳的key就越多。
decay-time是计数器的衰变时间。

//缓存时间的配置 TODO

配置完成!

附录 意外宕机策略

本方法只对于指定情况
1开启AOF方式,查看aof文件,并删除最后一行不完整的数据。

你可能感兴趣的:(Redis-缓存持久篇)