Redis(三十九):认识慢查询日志(1)


config set slowlog-log-slowere-than <微秒> //设置定义慢查询的时间

config set slowlog-max-len <数量> //设置定义慢查询最多记录数量

slowlog get //查询慢查询日志

在这里插入图片描述

这里首先将定义事件改为0,将数量显示为3条

在这里插入图片描述

由于我服务器搭了集群,所以这里显示的都是集群命令的信息,可以看到,他都被限制为3条,如果后面再重新发现了出现慢查询,那么最前面的一条将会被删除,后面的往前面移,腾出空位给新出现的慢查询日志

慢查询记录的保存


慢查询记录是保存在服务器状态里面的

在服务器状态中包含了几个和慢查询日志功能有关的属性

struct redisServer(

//…

//下一条慢查询日志的ID

long long slowlog_entry_id;

//保存了所有慢查询日志的链表

list *slowlog;

//服务器配置slowlog-log-slower-than选项的值

long long slowlog_log_slower_than;

//服务器配置slowlog-max-len选项的值

unsigned long slowlog_max_len;

//…

)redisServer;

slowlog_entry_id

slowlog_entry_id就是日志id,初始值为0,每当创建一条新的慢查询事务日志时,这个属性的值就会用作新日志id值,之后程序会对他进行加一

slowlog

slowlog是一个链表,保存了服务器中的所有慢查询日志,而链表中的每一个结点都是一个slowlogEntry结构,每个slowlogEntry结构代表一条慢查询日志

typedef struct slowlogEntry(

//唯一标识符

long long id;

//命令执行的时间,为Unix时间戳

time_t time;

//执行命令消耗的时间,以微秒为单位

long long duration;

//命令与命令参数

robj **argv;

//命令与命令参数的数量

int arac;

)slowlogEntry;

该结构如下所示

在这里插入图片描述

argv是一个字符串数组,之前已经说过

看看完整的slowlog

在这里插入图片描述

slowlog采用的是头插法(新的慢查询日志在前面),所以slower-max-len参数对应的就是链表的长度

慢查询日志的阅览和删除


阅览

阅览使用的命令为

slowlog get

伪代码如下

def slowlog_get(number=None):

#用户没有给定Number参数

#那么就代表打印服务器包含的全部慢查询日志

if number is None:

#SLOWLOG_LEN()对应的就是slowlog-max-len选项、

number = SLOWLOG_LEN();

#遍历服务器中的慢查询日志

for log in redisServer.slowLog:

if number <= 0:

#记录打印的数量,如果为0,代表打印数量足够了

break;

else:

#打印的数量减一

number -= 1;

#打印日志

printLog(log);

end For

end slowlog_get;

SLOWLOG_LEN函数其实返回的就是slowog-max-len选项的值,也就是slowlog链表最大的长度

删除

清除慢查询日志可以使用下面命令

slowlog reset

其实就是遍历slowlog链表,然后进行逐个释放即可

def SLOWLOG_RESET():

#遍历服务器中的所有慢查询日志

for log in redisServer.slowlog:

#删除日志

deleteLog(log);

end For

end SLOWLOG_RESET;

添加新日志


在每一次执行命令的之前和之后,程序都会记录微秒格式的当前UNIX时间戳,这两个时间戳之间的差就是服务器执行命令所耗费的时长,服务器会把这个时长作为参数之一传给slowlogPushEntryIfNeeded函数,也就是说,当执行完命令后,会调用slowlogPushEntryIfNeeded函数来判断当前命令是否需要添加到慢查询日志(如果需要的话,这个函数也会进行调用方法添加慢查询日志)

slowlogPushEntryIfNeeded检查的步骤如下

  1. 先判断slowlog-log-slower-than是否大于等于0,如果不是,就代表没有开启慢查询功能,如果是,代表开启了慢查询功能,紧接着后面的判断

  2. 检查命令的执行时长是否超过slowlog-log-slower-than选项,如果超过,就要为该命令新建一个slowlogEntry对象,然后新添到slowlog链表里面,采用的是头插法

  3. 之后再检查慢查询日志的长度是否超过slowlog-max-len选项设置的长度,如果超过,就要将slowLog链表中最后的slowEntry给删掉(最后的就是最久的),采用的是尾删法

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
mg-1YzuWjHE-1714949636559)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 12
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值