详解Redis的慢查询日志_Redis

来源:脚本之家  责任编辑:小易  

www.zgxue.com防采集请勿采集本网。

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

Redis客户端一条命令分为如下四部分执行:

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

一、慢查询的配置参数: 慢查询的预设阀值 slowlog-log-slower-than

slowlog-log-slower-than参数就是预设阀值,单位是微秒,默认值是10000,如果一条命令的执行时间超过10000微妙,那么它将被记录在慢查询日志中。

如果slowlog-log-slower-than的值是0,则会记录所有命令。

如果slowlog-log-slower-than的值小于0,则任何命令都不会记录日志。 慢查询日志的长度slowlog-max-len

slowlog-max-len只是说明了慢查询日志最多存储多少条。Redis使用一个列表来存储慢查询日志,showlog-max-len就是列表的最大长度。当慢查询日志已经到达列表的最大长度时,又有慢查询日志要进入列表,则最早插入列表的日志将会被移出列表,新日志被插入列表的末尾。

二、慢查询日志的组成

慢查询日志由以下四个属性组成:

标识ID,发生时间戳,命令耗时,执行命令和参数

三、慢查询日志的访问和管理

获取慢查询日志slowlog get [n]

命令:slowlog get [N]

选型:N,可选,代表获取的日志条数

例如:showlog get 5

四、慢查询日志最佳实践 slowlog-max-len的设置建议

线上环境建议调大慢查询日志的列表,记录慢查询日志时Redis会对长命令做截断操作,并不会占用大量内存。增大慢查询列表可以减缓慢查询被剔除出列表的可能性。例如线上可以设置为1000以上。 slowlog-log-lower-than的设置建议

需要根据redis的并发量调整该值。由于redis采用单线程响应名利,对于高流量的场景,如果执行命令的时间在1毫秒以上,那么redis最多可支撑OPS(每秒操作次数)不到1000,因此高OPS场景的REDIS建议设置为1毫秒。 慢查询只记录命令执行时间,并不包括命令排队时间和网络传输时间。

因此客户端命令的执行时间要大于redis服务器实际执行命令的时间。因为命令执行排队极致,慢查询会导致命令级联阻塞,因此当客户端出现请求超时,需要检查该时间点是否有对应的慢查询,从而分析是否因为慢查询导致的命令级联阻塞 慢查询日志是一个先进先出队列

慢查询较多的情况下,可能会丢失部分慢查询命令,可以定期执行slow get命令将慢查询日志持久化到其他存储中。然后制作可视化界面查询。

以上就是详解Redis的慢查询日志的详细内容,更多关于Redis 慢查询日志的资料请关注真格学网其它相关文章! 您可能感兴趣的文章:Redis分析慢查询操作的实例教程浅析JavaWeb项目架构之Redis分布式日志队列java获取redis日志信息与动态监控信息的方法如何高效使用Redis作为LRU缓存Linux安装Redis实现过程及报错解决方案spring boot+redis 监听过期Key的操作方法Redis面试必会的题目在Docker中使用Redis的步骤详解SpringBoot2.3整合redis缓存自定义序列化的实现Redis 执行性能测试Redis缓存常用4种策略原理详解Redis缓存穿透出现原因及解决方案

支持定期导出2113内存的Snapshot 与 记录写操作日5261志的4102Append Only File两种模式1653。Replication:Master-Slave模式,Master可连接多个只读Slave,暂无专门的Geographic Replication支持。Fail-Over:Redis-Sentinel节点负责监控Master节点,在master失效时提升slave,独立的仲裁节点模式有效防止脑裂。Sharding:开发中的Redis-Cluser内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • linux安装配置及使用redis
  • 详解redis数据结构之sds
  • redis集群的相关详解
  • centos 6.5 64位下安装redis3.0.2的具体步骤
  • gem install redis报错的解决方案
  • redis入门教程_动力节点java学院整理
  • redis教程(十二):服务器管理命令总结
  • 利用redis实现sql伸缩的方法简介
  • python脚本实现redis未授权批量提权
  • 分割超大redis数据库例子
  • 如何记录和查询Redis慢执行日志
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页redis分析慢查询操作的实例教程浅析javaweb项目架构之redis分布式日志队列java获取redis日志信息与动态监控信息的方法如何高效使用redis作为lru缓存linux安装redis实现过程及报错解决方案spring boot+redis 监听过期key的操作方法redis面试必会的题目在docker中使用redis的步骤详解springboot2.3整合redis缓存自定义序列化的实现redis 执行性能测试redis缓存常用4种策略原理详解redis缓存穿透出现原因及解决方案linux安装配置及使用redis详解redis数据结构之sdsredis集群的相关详解centos 6.5 64位下安装redis3.0.2的具体步骤gem install redis报错的解决方案redis入门教程_动力节点java学院整理redis教程(十二):服务器管理命令总结利用redis实现sql伸缩的方法简介python脚本实现redis未授权批量提权分割超大redis数据库例子超强、超详细redis数据库入门教程redis常用命令、常见错误、配置技redis操作命令总结redis中5种数据结构的使用场景介64位windows下安装redis教程redis中使用redis-dump导出、导入redis中统计各种数据大小的方法redis常用命令小结让redis在你的系统中发挥更大作用centos 6.6下redis安装配置记录redis中scan命令的踩坑实录linux下redis的安装与使用图文教程redis中scan命令的基本使用教程基于redis实现分布式锁以及任务队列redis配置文件代码讲解redis数据库中实现分布式锁的方法详解利用redis + lua解决抢红包高并发的问一次关于redis内存诡异增长的排查过程实战redis主从复制原理的深入讲解如何高效使用redis作为lru缓存
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved