当前位置: 代码网 > it编程>数据库>Redis > Redis slowlog使用和实现

Redis slowlog使用和实现

2026年02月06日 Redis 我要评论
说明slowlog是redis server记录查询命令执行时间的日志模块,查询执行时间指一个查询命令所耗费的时间,不包括客户端响应,发送回复等io操作。slowlog保存在redis内存中,读写速度

说明

slowlog是redis server记录查询命令执行时间的日志模块,

查询执行时间指一个查询命令所耗费的时间,不包括客户端响应,发送回复等io操作。

slowlog保存在redis内存中,读写速度比较快,

配置

slow log主要由两个参数控制,

slowlog-log-slower-than指对执行时间大于多少微秒(microsecond)的查询进行记录。

slowlog-max-len指slowlog保存多少条日志,超过指定长度的日志,需要删除最早的日志.

配置由两种方法:

  1. 修改配置文件中slowlog-log-slower-than、slowlog-max-len参数
  2. 使用config set命令动态修改slowlog-log-slower-than、slowlog-max-len参数值

命令

slow len:获取当前slow log中长度

slow reset:重置slow log

slow get [count]:返回slow log中指定数量的log信息,默认为10,log信息包括:id, timestamp, time in microseconds, arguments array, client ip and port, client name。

实现

slowlog采用list数据结构,如果执行时间大于slowlog-log-slower-than,追加到

void call(client *c, int flags) {

    //如果当前在 aof 加载上下文,不要写 slowlog / latency / info stats
    int update_command_stats = !isaofloadingcontext();

    //......
    if (update_command_stats && !(c->flags & client_blocked))
        slowlogpushcurrentcommand(c, real_cmd, c->duration);
    //......
    
}

void slowlogpushcurrentcommand(client *c, struct rediscommand *cmd, ustime_t duration) {
    //是否需要纪录slowlog
    if (cmd->flags & cmd_skip_slowlog)
        return;
    robj **argv = c->original_argv ? c->original_argv : c->argv;
    int argc = c->original_argv ? c->original_argc : c->argc;
    slowlogpushentryifneeded(c,argv,argc,duration);
}

slowlogpushentryifneeded函数把命令参数和执行时间写入到server.slowlog列表中

void slowlogpushentryifneeded(client *c, robj **argv, int argc, long long duration) {
    //判断slowlog_log_slower_than配置是否小于0,是否记录日志
    if (server.slowlog_log_slower_than < 0) return; /* slowlog disabled */
    //如果执行时间大于slowlog_log_slower_than时间 追加到slow log list头部中
    if (duration >= server.slowlog_log_slower_than)
        listaddnodehead(server.slowlog,
                        slowlogcreateentry(c,argv,argc,duration));
    //判断slow log list长度是否大于slowlog_max_len,
    //如果大于slowlog_max_len 删除list尾部元素
    /* remove old entries if needed. */
    while (listlength(server.slowlog) > server.slowlog_max_len)
        listdelnode(server.slowlog,listlast(server.slowlog));
}

到此这篇关于redis slowlog使用和实现的文章就介绍到这了,更多相关redis slowlog使用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com