Redis slowlog使用和实现

 更新时间:2026年02月06日 10:55:57   作者:卓航  
slowlog是redis server记录查询命令执行时间的日志模块, 本文就来介绍一下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,追加到

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使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 一文搞懂Redis中String数据类型

    一文搞懂Redis中String数据类型

    string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。今天通过本文给大家介绍下Redis中String数据类型,感兴趣的朋友一起看看吧
    2022-04-04
  • Redis集群增加节点与删除节点的方法详解

    Redis集群增加节点与删除节点的方法详解

    这篇文章主要给大家介绍了关于Redis集群增加节点与删除节点的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • redis查询keys报错的实现

    redis查询keys报错的实现

    在Redis中使用KEYS命令来查询所有符合特定模式的键名是一个常见需求,本文主要介绍了redis查询keys报错的实现,具有一定的参考价值,感兴趣的可以了解一下
    2025-04-04
  • Satoken+Redis实现短信登录、注册、鉴权功能

    Satoken+Redis实现短信登录、注册、鉴权功能

    这篇文章主要介绍了Satoken+Redis实现短信登录、注册、鉴权功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • redis实现的四种常见限流策略

    redis实现的四种常见限流策略

    因为在网站运行期间可能会因为突然的访问量导致业务异常、也有可能遭受别人恶意攻,所以我们对网站要进行限流,本文主要介绍了redis四种常见限流策略,感兴趣的可以了解一下
    2021-06-06
  • Redis中的AOF原理及分析

    Redis中的AOF原理及分析

    Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率
    2025-09-09
  • K8S redis 部署的项目实践

    K8S redis 部署的项目实践

    本文主要介绍了K8S redis 部署的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-05-05
  • Redisson 框架中的分布式锁实现方法

    Redisson 框架中的分布式锁实现方法

    这篇文章主要介绍了Redisson 框架中的分布式锁,实现分布式锁通常有三种方式:数据库、Redis 和 Zookeeper,我们比较常用的是通过 Redis 和 Zookeeper 实现分布式锁,需要的朋友可以参考下
    2024-03-03
  • Web-ssrfme:redis 未授权访问攻击的问题解决

    Web-ssrfme:redis 未授权访问攻击的问题解决

    本文主要介绍了Web-ssrfme:redis 未授权访问攻击的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-04-04
  • Redis的5种数据类型与常用命令讲解

    Redis的5种数据类型与常用命令讲解

    今天小编就为大家分享一篇关于Redis的5种数据类型与常用命令讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03

最新评论