美文网首页
【Redis学习笔记】04 Redis 键过期以及故障案例

【Redis学习笔记】04 Redis 键过期以及故障案例

作者: 夏胖运维 | 来源:发表于2022-03-10 16:11 被阅读0次

    1. 给键设置过期时间

    key 设置过期时间:EXPIRE key seconds,时间单位为秒

    127.0.0.1:6379> EXPIRE k8 10
    (integer) 0
    127.0.0.1:6379> EXPIRE k1 10
    (integer) 1
    

    状态码:
    0:表示这个 key 不存在
    1:表示这个 key 存在,并设置过期时间成功

    我们设置 k1 的过期时间为 10 秒后,等待 10 秒,再次查看 k1,会发现 k1 不存在了

    127.0.0.1:6379> GET k1
    (nil)
    

    我们得出:Redis key 设置的过期时间到了之后,会自动将 key 删除

    key 的过期时间可以在创建的时候就设置

    127.0.0.1:6379> SET k1 v1 EX 10
    OK
    

    2. 查看key是否过期

    查看 key 的过期时间:TTL key

    127.0.0.1:6379> TTL k2
    (integer) -1
    127.0.0.1:6379> SET k1 v1
    OK
    127.0.0.1:6379> EXPIRE k1 10
    (integer) 1
    127.0.0.1:6379> TTL k1
    (integer) 8
    127.0.0.1:6379> TTL k1
    (integer) 7
    127.0.0.1:6379> TTL k1
    (integer) 5
    127.0.0.1:6379> TTL k1
    (integer) 4
    127.0.0.1:6379> TTL k1
    (integer) 3
    127.0.0.1:6379> TTL k1
    (integer) 2
    127.0.0.1:6379> TTL k1
    (integer) -2
    

    状态码:
    -1:表示这个 key 存在,但是并没有设置过期时间(永不过期)
    -2:表示这个 key 不存在
    N:表示这个 key 存在,并且还有 N 秒过期

    注意:当 key 还在过期时间中,再创建一个一模一样的 key,会覆盖掉处于过期时间的 key,这时,这个key 就变成了永不过期的key

    127.0.0.1:6379> SET k1 v1
    OK
    127.0.0.1:6379> EXPIRE k1 50
    (integer) 1
    127.0.0.1:6379> TTL k1
    (integer) 41
    127.0.0.1:6379> SET k1 v1
    OK
    127.0.0.1:6379> TTL k1
    (integer) -1
    

    3. key 过期故障案例

    3.1. 问题描述

    双十一优惠活动,某电商平台的开发人员创建了一个已经存在过期时间为 1 天的优惠卷 key,这时就会把正在过期的 key 直接覆盖掉,从而变成永不过期的 key,当过期时间一过,发现优惠卷还是可以使用的,造成的损失不计其数,这就是由于新的 key 把旧的 key 覆盖了,过期时间也就变成了永不过期。

    3.2. 模拟破坏key的过期

    # 1. 创建优惠卷 key
    127.0.0.1:6379> SET coupons 50
    OK
    
    # 2. 查看 key 的过期时间
    127.0.0.1:6379> TTL coupons
    (integer) -1
    
    # 3. 设置 key 的过期时间为 120 秒
    127.0.0.1:6379> EXPIRE coupons 120
    (integer) 1
    
    # 4. 观察 key 的过期时间
    127.0.0.1:6379> TTL coupons
    (integer) 116
    127.0.0.1:6379> TTL coupons
    (integer) 115
    127.0.0.1:6379> TTL coupons
    (integer) 114
    127.0.0.1:6379> TTL coupons
    (integer) 102
    
    # 5. 设置开发人员突然创建了一个一模一样的 key,导致有过期时间的 key 被覆盖掉,从而变成了永不过期的 key
    127.0.0.1:6379> SET coupons 50
    OK
    127.0.0.1:6379> TTL coupons
    (integer) -1
    

    3.3. 避免 key 过期故障的方法(预防)

    1. 跟开发人员提前确认有哪些 key 存在过期时间,将这些 key 进行监控
      a. 通过 zabbix 自定义监控项,监控 redis-cli ttl key 输出的结果
      b. 只要是设置过期时间 key,查询当前过期时间返回值为 -1 的就告警,这表示这个key已经是永不过期了
    2. 规范操作,避免背锅

    4. 取消过期时间

    方法一:重新创建一个一模一样的 key

    SET k1 v1
    

    方法二:使用 PERSIST 命令(推荐)

    127.0.0.1:6379> SET k1 v1 EX 50
    OK
    127.0.0.1:6379> TTL k1
    (integer) 46
    127.0.0.1:6379> PERSIST k1
    (integer) 1
    127.0.0.1:6379> TTL k1
    (integer) -1
    

    相关文章

      网友评论

          本文标题:【Redis学习笔记】04 Redis 键过期以及故障案例

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