Redis的slowlog

Redis的slowlog用于记录执行时间超过一定阈值的命令,以帮助优化性能。它以微秒为单位,默认10ms以上的命令会被记录。配置包括`slowlog-log-slower-than`来设定阈值,以及`slowlog-max-len`来限制记录数量。通过`slowlog len`、`slowlog get`和`slowlog reset`等命令进行管理。在实际应用中,可以定期获取并分析slowlog以提升Redis性能。
摘要由CSDN通过智能技术生成

slowlog的概念

slowlog指的是慢查询日志。redis的主线程是单线程的,会将所有命令按照请求时间的先后存放到队列中,当某一时刻接收到的命令足够多,来不及处理时,如果队列中某一条命令执行时间(相对来说)非常久,意味着redis主线程会阻塞一段时间,于是就会出现性能问题。redis会将执行时间超过某个值(默认为10ms)的命令记录下来,我们可以通过分析优化记录中的命令,达到提高redis的性能的效果。值得注意的是slowlog只保存在内存中,效率非常高,并不会影响到redis的性能。

slowlog相关配置

相关配置项:

slowlog-log-slower-than:执行时间的限制值,redis命令执行时间比这个值大,会被记录在slowlog中。值为负数,表示禁用;值为0,强制记录所有命令。单位是微秒。线上环境可以根据实际情况修改该值。

slowlog-max-len:被记录命令的个数,默认为128,其本身没有限制,但是因为slowlog保存在内存中,所以这个值越大,消耗内存越多。当命令个数超过这个值,又有新的命令被记录时,最先记录下的命令会被挤出slowlog(先进先出队列)。线上环境可以根据实际情况修改该值。

【Redis的配置文件】第1340行

 

修改配置方式

1)、动态配置,在redis服务启动后ÿ

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值