zoukankan      html  css  js  c++  java
  • Redis性能调优建议

    一、 Redis部署结构优化建议

    1. Master不做AOF或RDB持久化,Slave做AOF持久化,建议同时做RDB持久化
    2. 所有Master全部增加Slave
    3. Master挂载Slave不超过2个,采用M-S-S方式挂载。若想保证高可用,即主从切换,可采用Keepalived机制.

    备注:以上是基于Redis部署结构不合理提出的建议,同时也参考了新浪微博、淘宝架构中Redis优化方案给出

    二、 Redis配置优化建议

    1.tcp-keepalive 60 
    阻止由于某个command执行过长达到timeout超时时间而被断开连接,且可以提高连接错误的检测.
    2.stop-writes-on-bgsave-error no
    当bgsave快照操作出错时停止写数据到磁盘,这样后面写操作均会失败,为了不影响后续写操作,故需将该项值改为no.
    3.rdbchecksum no
    检查RDB数据的正确性,会牺牲10%的性能,故建议关闭.
    4.auto-aof-rotate-max-size  20gb
    auto-aof-rotate-max-total 4
    auto-aof-rewrite-percentage 0 (关闭rewrite模式)
    将AOF rewrite模式改为rotate模式,即将AOF在线实时Rewrite的功能,切换到线下操作,1份AOF文件切割成多份(类似日志切割),这样提升了redis性能的同时提升内存的利用率.
    5.no-appendfsync-on-rewrite  yes
    避免新修改数据刷磁盘时出现IO阻塞

    备注:以上是基于Redis配置不合理提出的优化建议

    三、 系统内核配置优化建议

    1.开启了AOF模式,为了缓解IO阻塞
    编辑/etc/sysctl.conf ,添加如下配置:

    vm.dirty_background_ratio = 5
    vm.dirty_ratio = 10

    然后sysctl -p 使配置文件生效.

    2.开启了RDB模式,为了避免Fork失败

    编辑/etc/sysctl.conf ,改vm.overcommit_memory=1,
    然后sysctl -p 使配置文件生效

    备注:以上是基于测试结果给出的系统内核优化建议

    后续计划:

    以上是从架构角度提出的优化建议,后续会从业务角度,分析内存类型是否合理、冷热数据划分是否合理等

    备注:
    关于冷热数据划分,可使用如下Redis命令进行统计分析:

    OBJECT REFCOUNT 该命令主要用于调试(debugging),它能够返回指定key所对应value被引用的次数.

    OBJECT ENCODING 该命令返回指定key对应value所使用的内部表示(representation)(译者注:也可以理解为数据的压缩方式).

    OBJECT IDLETIME 该命令返回指定key对应的value自被存储之后空闲的时间,以秒为单位(没有读写操作的请求) ,这个值返回以10秒为单位的秒级别时间,这一点可能在以后的实现中改善

  • 相关阅读:
    2017 9 26
    NOI2002 银河英雄传说(luogu p1196)
    luogu [USACO08OCT]打井Watering Hole
    luogu P2784 化学1(chem1)- 化学合成
    2017 9 24
    2017.9.24 noip模拟赛 day2—组合数
    Java 接口——2
    Java 接口——1
    Java 泛型
    Java 随笔——8
  • 原文地址:https://www.cnblogs.com/qwop/p/6637387.html
Copyright © 2011-2022 走看看