Slow Log 慢查询日志

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 什么是 SLOW LOG1. Slow log 是 Redis 用来记录查询执行时间的日志系统。2. 查询执行时间指的是不包括像客户端响应(talking)、发送回复等 IO 操作,而单单是执行一个查询命令所耗费的时间。3. slow log 保存在内存里面,读写速度非常快,因此你可以放心地使用它,不必担心因为开启 slow log 而损害 Redis 的速度。


什么是 SLOW LOG



1. Slow log 是 Redis 用来记录查询执行时间的日志系统。

2. 查询执行时间指的是不包括像客户端响应(talking)、发送回复等 IO 操作,而单单是执行一个查询命令所耗费的时间。

3. slow log 保存在内存里面,读写速度非常快,因此你可以放心地使用它,不必担心因为开启 slow log 而损害 Redis 的速度。


SLOW LOG 慢查询配置项



1. slowlog-log-slower-than (慢查询的阈值(单位:微秒))

  • 特点
  1. 当执行查询命令消耗时间大于设置的阈值时,会将该条命令记录到慢查询日志
  2. slowlog-log-slower-than=0,记录所有命令
  3. slowlog-log-slower-than<0,不记录任何命令
  4. 默认值为 10000 (10毫秒,1秒 = 1,000毫秒 = 1,000,000微秒)


2. slowlog-max-len (慢查询日志最大条数)

  • 特点
  1. 先进先出的队列 (即当慢查询日志达到最大条数后,会销毁最早记录的日志条目)
  2. 固定长度
  3. 保存在内存内 (重启redis会清空慢查询日志)
  4. 默认值为 128


3. 配置方法

  1. 修改配置文件 redis.conf ,重启redis
  2. 使用命令动态配置
  • CONFIG SET slowlog-log-slower-than 100
  • CONFIG SET slowlog-max-len 1024
  1. 查看慢查询配置
  • CONFIG GET slowlog-*
127.0.0.1:6379> CONFIG GET slowlog-*
1) "slowlog-log-slower-than"
2) "100"
3) "slowlog-max-len"
4) "1024"


查看慢查询日志



1. SLOWLOG GET [n]

  • 获取最新的n条慢查询记录
  • 若不加 n ,则获取全部慢查询记录
127.0.0.1:6379> SLOWLOG GET 3
1) 1) (integer) 14                # 唯一性(unique)的日志标识符
   2) (integer) 1522808219        # 被记录命令的执行时间点,以 UNIX 时间戳格式表示
   3) (integer) 16                # 查询执行时间,以微秒为单位
   4) 1) "keys"                   # 执行的命令,以数组的形式排列
      2) "*"                      # 这里完整的命令是 "keys *"
2) 1) (integer) 13
   2) (integer) 1522808215
   3) (integer) 7
   4) 1) "set"
      2) "name"
      3) "baicai"
3) 1) (integer) 12
   2) (integer) 1522808198
   3) (integer) 101
   4) 1) "set"
      2) "age"
      3) "25"


2. SLOWLOG LEN

  • 查看当前日志的数量
127.0.0.1:6379> SLOWLOG LEN
(integer) 16


3. SLOWLOG RESET

  • 清空日志
127.0.0.1:6379> SLOWLOG RESET
OK
127.0.0.1:6379> SLOWLOG LEN
(integer) 0


慢查询运维经验



1. slowlog-log-slower-than 不要设置过大,默认为 10 ms,通常可设置为 1ms。

2. slowlog-max-len 不要设置过小,通常可设置在1000左右。


3. 理解命令的生命周期

  • 一次查询的生命周期

image.png


4. 定期持久化慢查询日志

  • 因为慢查询日志是保存在内存内,重启redis就会清空慢查询日志,若要保留历史的慢查询日志,可定期将慢查询日志存储到mysql等数据库中。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
4天前
|
关系型数据库 MySQL 数据库
mysql数据库bin-log日志管理
mysql数据库bin-log日志管理
|
4天前
|
存储 关系型数据库 数据库
关系型数据库文件方式存储LOG FILE(日志文件)
【5月更文挑战第11天】关系型数据库文件方式存储LOG FILE(日志文件)
16 1
|
5天前
|
运维 监控 安全
Java一分钟之-Log4j与日志记录的重要性
【5月更文挑战第16天】Log4j是Java常用的日志框架,用于灵活地记录程序状态和调试问题。通过设置日志级别和过滤器,可避免日志输出混乱。为防止日志文件过大,可配置滚动策略。关注日志安全性,如Log4j 2.x的CVE-2021-44228漏洞,及时更新至安全版本。合理使用日志能提升故障排查和系统监控效率。
27 0
|
6天前
|
C++
JNI Log 日志输出
JNI Log 日志输出
21 1
|
6天前
|
存储 运维 大数据
聊聊日志硬扫描,阿里 Log Scan 的设计与实践
泛日志(Log/Trace/Metric)是大数据的重要组成,伴随着每一年业务峰值的新脉冲,日志数据量在快速增长。同时,业务数字化运营、软件可观测性等浪潮又在对日志的存储、计算提出更高的要求。
|
SQL 数据采集 监控
基于日志服务数据加工分析Java异常日志
采集并脱敏了整个5月份的项目异常日志,准备使用日志服务数据加工做数据清洗以及分析。本案例是基于使用阿里云相关产品(OSS,RDS,SLS等)的SDK展开自身业务。需要对异常日志做解析,将原始日志中时间、错误码、错误信息、状态码、产品信息、请求方法、出错行号提取出来。然后根据提取出来的不同产品信息做多目标分发处理。对清洗后的数据做异常日志数据分析。
729 0
基于日志服务数据加工分析Java异常日志
|
6天前
|
安全 Linux 网络安全
/var/log/secure日志详解
Linux系统的 `/var/log/secure` 文件记录安全相关消息,包括身份验证和授权尝试。它涵盖用户登录(成功或失败)、`sudo` 使用、账户锁定解锁及其他安全事件和PAM错误。例如,SSH登录成功会显示&quot;Accepted password&quot;,失败则显示&quot;Failed password&quot;。查看此文件可使用 `tail -f /var/log/secure`,但通常只有root用户有权访问。
182 4
|
6天前
|
XML Java Maven
Springboot整合与使用log4j2日志框架【详解版】
该文介绍了如何在Spring Boot中切换默认的LogBack日志系统至Log4j2。首先,需要在Maven依赖中排除`spring-boot-starter-logging`并引入`spring-boot-starter-log4j2`。其次,创建`log4j2-spring.xml`配置文件放在`src/main/resources`下,配置包括控制台和文件的日志输出、日志格式和文件切分策略。此外,可通过在不同环境的`application.yml`中指定不同的log4j2配置文件。最后,文章提到通过示例代码解释了日志格式中的各种占位符含义。
|
6天前
|
运维 监控 Go
Golang深入浅出之-Go语言中的日志记录:log与logrus库
【4月更文挑战第27天】本文比较了Go语言中标准库`log`与第三方库`logrus`的日志功能。`log`简单但不支持日志级别配置和多样化格式,而`logrus`提供更丰富的功能,如日志级别控制、自定义格式和钩子。文章指出了使用`logrus`时可能遇到的问题,如全局logger滥用、日志级别设置不当和过度依赖字段,并给出了避免错误的建议,强调理解日志级别、合理利用结构化日志、模块化日志管理和定期审查日志配置的重要性。通过这些实践,开发者能提高应用监控和故障排查能力。
89 1
|
6天前
|
弹性计算 运维 Shell

热门文章

最新文章