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

  • 添加新日志

  • 重点

在Redis配置文件中,有两个选项是跟慢查询日志有关的

在这里插入图片描述

分别为

  • slowlog-log-slower-than

  • slowlog-max-len

配置选项


slowlog-log-slower-than

这个选项指定执行时间超过多少微秒的命令请求会被记录到慢查询日志上,相当于定义了命令执行的时间超过多少时,就会定义为慢查询

slowlog-max-len

这个选项指定服务器最多保存多少条慢查询日志

相关命令


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():

最后

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

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

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

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

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

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值