关于Redis的慢查询日志功能详解

 更新时间:2023年07月13日 10:35:08   作者:是馄饨呀  
Redis慢查询是Redis提供的一项性能优化功能,它可以记录某个查询语句的执行时间、命令参数、执行次数等信息,从而帮助运维人员快速定位某个查询语句的性能问题,需要的朋友可以参考下

慢查询记录

我们都知道像mysql等持久化数据库会有慢查询日志,其实Redis中也有慢查询日志的功能。慢查询就是系统在执行命令的前后计算每条命令的执行时间,如果超过我们预设的时间,就把记录记下来。

一般发送一条 Redis 命令会有以下这 4 个步骤:

在这里插入图片描述

然而Redis慢查询只记录第3个步骤,所以我们一般在生产环境中的等待时间,会远远大于慢查询日志记录的时间。

慢查询两个配置参数

Redis中有两个配置参数用来记录慢查询

  • 预设阀值,配置为slowlog-log-slower-than(就是命令超过多长时间需要记录一下,默认是10 000微秒。

在这里插入图片描述

  • 慢查询记录,这个默认是记录在redis中的一个列表里。通过slowlog-max-len,来设置列表的最大长度。

如果 slowlog-log-slower-than=0会记录所有的命令,slowlog-log-slower-than<0不会记录任何命令。

如果下一条命令超过了最大长度,比如我们设置的队列长度为5,又来了一条慢查询,那么会将队列最先进入的慢查询移出,将最新的一条放入队列,增大慢查询设置长度可以减缓慢查询被剔除的可能,比如线上可以设置为1000以上。

修改配置参数

通过以下配置修改

config set slowlog-log-slower-than 2000
config set slowlog-max-len 1000
config rewrite

如果要将Redis将配置持久化到本地配置文件,需要执行config rewrite命令。

慢查询日志

(1)获取慢查询日志

slowlog get [n] # n代表查询数量,如果不写,则为查询全部
127.0.0.1:6379> slowlog get
1) 1) (integer) 3
   2) (integer) 1678264789
   3) (integer) 8
   4) 1) "get"
      2) "a"

可以看到有4个属性,分别是慢查询日志的标识id、发生时间戳、命令耗时、执行命令和参数。

(2)获取慢查询日志列表当前的长度

slowlog len
127.0.0.1:6379> slowlog len
(integer) 6

(3) 慢查询日志重置

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

到此这篇关于关于Redis的慢查询日志功能详解的文章就介绍到这了,更多相关Redis的慢查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入了解Redis的性能

    深入了解Redis的性能

    这篇文章主要介绍了Redis的性能,作者通过Visual Studio上的C#程序对其进行了分析,需要的朋友可以参考下
    2015-06-06
  • Python的Flask框架使用Redis做数据缓存的配置方法

    Python的Flask框架使用Redis做数据缓存的配置方法

    Redis数据库依赖于主存,在关系型数据库以外再配套Redis管理缓存数据将对性能会有很大的提升,这里我们就来看一下Python的Flask框架使用Redis做数据缓存的配置方法
    2016-06-06
  • Redis实现延迟任务的常见方案详解

    Redis实现延迟任务的常见方案详解

    延迟任务(Delayed Task)是指在未来的某个时间点,执行相应的任务,本文为大家整理了Redis实现延迟任务的几个常见方案,希望对大家有所帮助
    2024-04-04
  • 配置Redis序列化方式不生效问题及解决

    配置Redis序列化方式不生效问题及解决

    这篇文章主要介绍了配置Redis序列化方式不生效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Redis官方可视化工具RedisInsight的安装使用详细教程(功能强大)

    Redis官方可视化工具RedisInsight的安装使用详细教程(功能强大)

    RedisInsight是Redis官方出品的可视化管理工具,可用于设计、开发、优化你的Redis应用。支持深色和浅色两种主题,界面非常炫酷,接下来通过本文给大家介绍Redis官方可视化工具RedisInsight的安装使用过程,需要的朋友可以参考下
    2022-04-04
  • Redis 哈希Hash底层数据结构详解

    Redis 哈希Hash底层数据结构详解

    这篇文章主要介绍了Redis 哈希Hash底层数据结构详解的相关资料,需要的朋友可以参考下
    2022-08-08
  • Redis击穿穿透雪崩产生原因分析及解决思路面试

    Redis击穿穿透雪崩产生原因分析及解决思路面试

    这篇文章主要为大家介绍了Redis击穿穿透雪崩产生原因及解决思路的面试问题答案参考,有需要的朋友可以借鉴参考下,希望能够有所帮助祝大家多多进步
    2022-03-03
  • redis中bind配置的详细步骤

    redis中bind配置的详细步骤

    本文主要介绍了redis中bind配置的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • Redis高并发情况下并发扣减库存项目实战

    Redis高并发情况下并发扣减库存项目实战

    本文主要介绍了Redis高并发情况下并发扣减库存项目实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Redis数据库的安装和配置教程详解

    Redis数据库的安装和配置教程详解

    这篇文章主要介绍了Redis数据库的安装和配置 ,主要包括Linux环境安装Redis和windows环境安装Redis,redis客户端安装方法,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2022-05-05

最新评论