Redis slowlog使用和实现

说明

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,追加到

scss 复制代码
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列表中

scss 复制代码
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));
}
相关推荐
indexsunny3 小时前
互联网大厂Java面试实战:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·微服务·kafka·spring security·电商
摇滚侠9 小时前
阿里云安装的 Redis 在什么位置,如何找到 Redis 的安装位置
redis·阿里云·云计算
啦啦啦_99999 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
forestsea11 小时前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
佛祖让我来巡山12 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
啦啦啦_999913 小时前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学14 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
fengxin_rou14 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
是阿楷啊15 小时前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试
笨蛋不要掉眼泪15 小时前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap