头图

Redis慢查询日志帮助开发和运维人员定位系统存在的慢操作。慢查询日志就是系统在命令执行前后计算每条命令的执行时间,当超过预设阀值,就将这条命令的相关信息(慢查询ID,发生时间戳,耗时,命令的详细信息)记录下来。Redis客户端的一条命令可以分为四个部分执行,如下图所示。
image.png

视频讲解如下:
https://www.bilibili.com/video/BV1hbpeehEwj/?aid=113099659019...

一条Redis的慢查询日志由以下四个属性组成:标识ID,发生时间戳,命令耗时,执行命令和参数。

提示:需要注意的是,慢查询日志只是统计执行命令的时间,所以慢查询并不代表客户端没有超时问题。

一、慢查询的配置参数

Redis提供的慢查询配置参数如下:

127.0.0.1:6379> CONFIG GET slowlog*
1) "slowlog-max-len"
2) "128"
3) "slowlog-log-slower-than"
4) "10000"

其中:

  • slowlog-max-len
    Redis使用一个列表来存储慢查询日志,showlog-max-len就是列表的最大长度(默认值是128)。当慢查询日志已经到达列表的最大长度时,又有慢查询日志要进入列表,则最早插入列表的日志将会被移出列表,新日志被插入列表的末尾。
  • slowlog-log-slower-than
    Redis预设的慢查询时间阀值(默认值是10000微秒)。如果一条命令的执行时间超过10000微妙,那么它将被记录在慢查询日志中。如果slowlog-log-slower-than的值是0,则会记录所有命令。如果slowlog-log-slower-than的值小于0,则任何命令都不会记录日志。例如:
    127.0.0.1:6379> config set slowlog-log-slower-than 0
    OK

二、【实战】管理慢查询日志

下面通过具体的操作步骤来演示如何管理和使用Redis提供的慢查询日志。视频讲解如下:
https://www.bilibili.com/video/BV1zGpeeGEKZ/?aid=113100112005...

(1)向Redis中插入一条数据

127.0.0.1:6379> set location Beijing
127.0.0.1:6379> hmset user001 name Tom age 24 gender Male

(2)获取慢查询日志:

slowlog get [n]
​
# 其中N代表获取的日志条数。如果不提供N的值,将获取所有的慢查询日志记录。
# 下面的语句将获取最近的3条慢查询日志。

127.0.0.1:6379> slowlog get 3
1) 1) (integer) 9                慢查询标识ID
2) (integer) 1650100709            慢查询发生时间戳
3) (integer) 7                    命令耗时
4) 1) "hmset"                    执行命令和参数
2) "user001"
3) "name"
4) "Tom"
5) "age"
6) "24"
7) "gender"
8) "Male"
5) "127.0.0.1:48218"
6) ""
2) 1) (integer) 8                慢查询标识ID
2) (integer) 1650100706            慢查询发生时间戳
3) (integer) 6                    命令耗时
4) 1) "set"                        执行命令和参数
2) "location"
3) "Beijing"
5) "127.0.0.1:48218"
6) ""
3) 1) (integer) 7                慢查询标识ID
2) (integer) 1650100698            慢查询发生时间戳
3) (integer) 11                    命令耗时
4) 1) "slowlog"                    执行命令和参数
2) "get"
3) "3"
5) "127.0.0.1:48218"
6) ""

(3)获取慢查询日志列表的当前长度:slowlog len

127.0.0.1:6379> slowlog len
(integer) 11

# 提示:当前Redis慢查询日志队列中存在11条记录。

(4)重置慢查询日志:slowlog reset

127.0.0.1:6379> slowlog reset
OK
127.0.0.1:6379> slowlog len
(integer) 1

# 提示:该操作实际是对列表做清理操作

三、慢查询日志最佳实践

Redis提供的慢查询日志对应诊断Redis数据库实例在运行过程中发生的性能问题是非常有帮助的。因此在实际环境中使用Redis的慢查询日志时有以下几点建议。

  • slowlog-max-len的设置建议
    线上环境建议调大慢查询日志的列表,记录慢查询日志时Redis会对长命令做截断操作,并不会占用大量内存。增大慢查询列表可以减缓慢查询被剔除出列表的可能性。例如线上可以设置为1000以上。
  • slowlog-log-lower-than的设置建议
    需要根据Redis的并发量调整该值。由于Redis采用单线程响应名利,对于高流量的场景,如果执行命令的时间在1毫秒以上,那么Redis最多可支撑OPS(每秒操作次数)不到1000,因此高OPS场景的Redis建议设置为1毫秒。
  • 慢查询只记录命令执行时间,并不包括命令排队时间和网络传输时间。
    因此客户端命令的执行时间要大于Redis服务器实际执行命令的时间。因为命令执行排队极致,慢查询会导致命令级联阻塞,因此当客户端出现请求超时,需要检查该时间点是否有对应的慢查询,从而分析是否因为慢查询导致的命令级联阻塞
  • 慢查询日志是一个先进先出队列
    慢查询较多的情况下,可能会丢失部分慢查询命令,可以定期执行slow get命令将慢查询日志持久化到其他存储中。然后制作可视化界面查询。

赵渝强老师
33 声望11 粉丝

20年以上的IT行业从业经历,清华大学计算机软件工程专业毕业,京东大学大数据学院院长,Oracle中国有限公司高级技术顾问;曾在BEA、甲骨文、摩托罗拉等世界500强公司担任高级软件架构师或咨询顾问等要职,精通大...