美文网首页
Redis-缓存持久篇

Redis-缓存持久篇

作者: 靈08_1024 | 来源:发表于2017-07-12 07:22 被阅读132次

本文是继上一篇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(保存数据库文件的目录)。
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,可以找到以下信息:


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:清除策略。默认不清除。

缓存清除策略.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-缓存持久篇

    本文是继上一篇Redis-安装启动篇之后。 Redis的缓存持久化分为四种情况: RDB方式:以.rdb文件的形式...

  • 使用过Redis,我竟然还不知道Rdb

    使用过Redis,那就先说说使用过那些场景吧 字符串缓存 //举例$redis->set();$redis->ge...

  • Redis-持久化

    Redis-持久化 一、RDB持久化 为了解决服务器进程退出导致数据丢失,Redis提过了RDB持久化功能,可以将...

  • webpack 持久化缓存

    前言 什么是持久化缓存,为什么做持久化缓存? webpack 如何做持久化缓存? 持久化缓存 首先我们需要去解释一...

  • redis-mysql缓存不一致,双写

    redis-缓存不一致,双写 但是在更新缓存方面,对于更新完数据库,是更新缓存呢,还是删除缓存。又或者是先删除缓存...

  • Redis-缓存

    一、Redis 1、概述 Redis是速度非常快的非关系型内存键值数据库,可以存储键和物种不同类型的值之间的映射。...

  • redis-持久化

    ### 0 命令 #### 常用命令 [参考](https://blog.csdn.net/IT_faquir/a...

  • redis-持久化

    1、概述 redis支持两种持久化方式,rdb和aof。rdb是数据库某一时刻的快照,aof是Append Onl...

  • redis-持久化

    持久化 本文提供对 Redis 持久化(persistence)的技术性描述,适合所有的 Redis 用户来阅读。...

  • Redis-持久化

    持久化 1.快照(一次全量备份)(默认的持久化策略) 2.AOF日志(连续的增量备份) 3.Redis4.0混合持...

网友评论

      本文标题:Redis-缓存持久篇

      本文链接:https://www.haomeiwen.com/subject/sbmvhxtx.html