redis的慢查询日志功能用于记录执行时间超过给定时长的命令请求,用户可以通过这个功能产生的日志来监视和优化查询速度。配置文件中的两个选项
1. slowlog-log-slower-than指定执行时间超过多少微妙的命令请求会被记录到日志上
2. slowlog-max-len 选项指定服务器最多保存多少条慢查询日志
在redis服务器状态中包含了这几个和慢查询日志功能有关的属性

点击(此处)折叠或打开

  1. struct redisServer{
  2.     //...
  3.     // 下一条慢查询日志的id
  4.     long loong slowlog_entry_id;
  5.     // 保存了所有慢查询日志的链表
  6.     list *slowlog;
  7.     long long slowlog_log_slower_than;
  8.     unsigned long slowlog_max_len;
  9. };
其中慢查询日志链表当中元素的结构如下

点击(此处)折叠或打开

  1. typedef struct slowlogEntry {
  2.     robj **argv;
  3.     int argc;
  4.     long long id; /* Unique entry identifier. */
  5.     long long duration; /* Time spent by the query, in microseconds. */
  6.     time_t time; /* Unix time at which the query was executed. */
  7.     sds cname; /* Client name. */
  8.     sds peerid; /* Client network address. */
  9. } slowlogEntry;
redis在执行命令前后都会记录时间戳,根据对应的选项来决定是否插入链表当中
10-26 06:45
查看更多