Redis慢日志详细概述

Redis 慢查询日志概述

客户端从发送命令到获取返回结果经过了以下几个步骤:

  1. 客户端发送命令
  2. 该命令进入 Redis 队列排队等待执行
  3. Redis 开始执行命令 - Redis 命令执行完成
  4. 命令执行结果返回给客户端
    Redis 慢查询日志统计的时间,只包含第三步的 Redis 命令从开始执行到执行完成的时间。

慢查询日志的两个配置项

slowlog-log-slower-than
Redis 慢查询日志的时间阈值,单位微妙。

  1. 值为正数,执行时间大于该值设置的微秒时才记录到慢日志中。默认 10000 微秒。
  2. 值为负数,禁用慢查询日志。
  3. 值为 0,所有命令都记录到慢日志中
    slowlog-max-len
    慢查询日志长度,最小值为零。默认 128
    当记录新命令并且当前慢日志已达到最大长度时,最旧的一条记录将被删除。

可以通过编辑 redis.conf 或者使用 CONFIG GET/SET 命令来进行配置

127.0.0.1:6379> config get slowlog-log-slower-than

  1. “slowlog-log-slower-than”
  2. “10000”
    127.0.0.1:6379> config get slowlog-max-len
  3. “slowlog-max-len”
  4. “128”
    
    127.0.0.1:6379> config set slowlog-log-slower-than 0
    OK
    127.0.0.1:6379> config set slowlog-max-len 10
    OK

读取慢日志记录

慢查询日志是记录在内存中的,记录速度非常快。

可以使用 SLOWLOG GET N 命令来读取慢日志,查询最近的 N 条记录。

该命令默认请求条数为 10 ,即 SLOWLOG GET 等价于 SLOWLOG GET 10

参数为 -1 时会获取整个慢日志信息。

日志输出格式

127.0.0.1:6379> slowlog get 2

    1. (integer) 13
    2. (integer) 1629523068
    3. (integer) 6
      1. “get”
      2. “a”
    4. “127.0.0.1:43942”
    5. “lnrcoder”
      
      
      1)每条日志唯一标识符

2)命令执行时的时间戳

3)命令执行消耗的时间,单位微秒

4)执行的命令数组

5)客户端地址和端口 (仅 4.0 以上版本支持)

6)客户端名称 (仅 4.0 以上版本支持,默认名称为空,需要通过 client setname 命令进行设置)

查询慢日志记录长度

使用 SLOWLOG LEN 可以获取慢日志记录的长度。

127.0.0.1:6379> slowlog len
(integer) 2

重置慢日志

使用 SLOWLOG RESET 命令用来重置慢日志。使用该命令进行日志重置后,信息将永远丢失。

127.0.0.1:6379> slowlog len
(integer) 10
127.0.0.1:6379> slowlog reset
OK
127.0.0.1:6379> slowlog len
(integer) 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

great-sun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值