前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >【赵渝强老师】Redis的慢查询日志

【赵渝强老师】Redis的慢查询日志

原创
作者头像
赵渝强老师
发布2025-01-09 16:46:40
发布2025-01-09 16:46:40
930
举报
文章被收录于专栏:NoSQL数据库NoSQL数据库

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

视频讲解如下:

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

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

一、慢查询的配置参数

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

代码语言:powershell
复制
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,则任何命令都不会记录日志。例如:
代码语言:txt
复制
127.0.0.1:6379> config set slowlog-log-slower-than 0
OK

视频讲解如下:

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

下面通过具体的操作步骤来演示如何管理和使用Redis提供的慢查询日志。

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

代码语言:powershell
复制
127.0.0.1:6379> set location Beijing
127.0.0.1:6379> hmset user001 name Tom age 24 gender Male

(2)获取慢查询日志:

代码语言:powershell
复制
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

代码语言:powershell
复制
127.0.0.1:6379> slowlog len
(integer) 11

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

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

代码语言:powershell
复制
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命令将慢查询日志持久化到其他存储中。然后制作可视化界面查询。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、慢查询的配置参数
  • 二、【实战】管理慢查询日志
  • 三、慢查询日志最佳实践
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档