redis持久化时导致系统负载陡增陡降

    最近一段时间在将公司内部的cache层抽离,使用redis来做缓存。将集群搭建后跑起来发现系统负载出现陡增陡降的现象。而机器的运行的各项指数也较为正常。后来发现redis配置使用了部分默认配置。 auto-aof-rewrite-percentage 选项为100%。aof基准大小是486mb。这样一次持久化就会很长的周期大约2小时。导致负载上升。

    其次有一个重要的选项,如何将aof的数据写到磁盘上。appendfsync 系统默认为everysec。目的是为了在可靠性和性能间取得平衡,而由于我们是将redis作为cache使用,能够容许在redis挂掉时丢掉一部分数据。则将该选项设置为no,以期待最高的性能。

    未改变前机器负载

    redis持久化时导致系统负载陡增陡降_第1张图片

    改变后机器负载:

    redis持久化时导致系统负载陡增陡降_第2张图片


----------

后续上了对查询时间较为敏感的业务后,发现不断地rewrite aof 时会在rewrite的瞬间造成查询时间变长。

于是索性关掉redis的aof自动rewrite功能。将rewrite用定时任务来做。

这样最大的损失也仅仅是redis挂掉后重启时间久点而已。而redis从集群搭建到现在还没有出现个挂掉的情况。

后来前端的查询就较为稳定了。当然不可避免的仍然是在rewrite时的查询时延。



你可能感兴趣的:(redis持久化时导致系统负载陡增陡降)