redis变慢了如何解决
设置慢查询日志,加载出所有慢查询语句
- config set slowlog-log-slower-than 5000
- config set slowlog-max-len 1000
设置慢查询时间大于5秒,且只保留1000条数据。
查询出所有的慢查询
- slowlog get 5
通过查看慢日志记录,我们就可以知道在什么时间执行哪些命令比较耗时,如果你的业务经常使用O(n)以上复杂度的命令,例如sort、sunion、zunionstore,或者在执行O(n)命令时操作的数据量比较大,这些情况下Redis处理数据时就会很耗时。
如果你的服务请求量并不大,但Redis实例的CPU使用率很高,很有可能是使用了复杂度高的命令导致的。
解决方案就是,不使用这些复杂度较高的命令,并且一次不要获取太多的数据,每次尽量操作少量的数据,让Redis可以及时处理返回。
如果查询慢日志发现,并不是复杂度较高的命令导致的,例如都是SET、DELETE操作出现在慢日志记录中,那么你就要怀疑是否存在Redis写入了大key的情况。
扫描出大Key的方法
redis-cli -h $host -p $port --bigkeys -i 0.01
Redis的过期策略采用主动过期+懒惰过期两种策略:
-
主动过期:Redis内部维护一个定时任务,默认每隔100毫秒会从过期字典中随机取出20个keyÿ