• [原]Redis主从复制各种环境下测试


    Redis 主从复制各种环境下测试

    测试环境:
    Linux ubuntu 3.11.0-12-generic
    2GB Mem
    1 core of Intel(R) Core(TM) i5-3470 CPU @ 3.20GHz
    Redis 2.6.13
    以下 R1 表示master, R2表示slave
    配置采用运维组标准配置,默认主从配置一样,在从节点启动后设置为slave

    R1: 127.0.0.1 6378
    R2: 127.0.0.1 6379 
    

    0. 初始情况下各节点info情况(部分有用信息):

    MASTER ->
     'connected_slaves': 1,            #可判断slave存活状况
    SLAVE  ->
     'master_host': '127.0.0.1',
     'master_last_io_seconds_ago': 5,
     'master_link_status': 'up',       #可判断master与slave存活状况
     'master_port': 6378
    

    1. 正常读写:

    In [32]: r1.set('key', 'value')
    Out[32]: True
    
    In [34]: r2.get('key')
    Out[34]: 'value'
    

    2. 主备正常连接下, 默认slave(不配置slave-read-only on)

    向slave写入后发现报错

    In [35]: r2.set('key2', 'value')
    ReadOnlyError: You can't write against a read only slave
    

    3. Master闪断:

    Crash掉主节点:

    'master_host': '127.0.0.1',
    'master_last_io_seconds_ago': -1,
    'master_link_down_since_seconds': 4,
    'master_link_status': 'down',
    'master_port': 6378
    

    重启主节点后,slave自动从从新建立连接

    'master_host': '127.0.0.1',
    'master_last_io_seconds_ago': 9,
    'master_link_status': 'up',
    'master_port': 6378,
    

    4. Crash掉主节点,slave默认(不配置slave-read-only on 情况)

    即使master挂掉,slave写入依然报错

    SLAVE ->
        'master_host': '127.0.0.1',
        'master_last_io_seconds_ago': -1,
        'master_link_down_since_seconds': 6,
        'master_link_status': 'down',
        'master_port': 6378
        
    In [37]: r2.set('key', 'value')
    ReadOnlyError: You can't write against a read only slave.
    

    设置slave为readonly,发现报错

    zb@ubuntu:~/codes/test$ redis-cli -h 127.0.0.1 -p 6379 set slave-read-only no
    (error) READONLY You can't write against a read only slave.
    

    需要关闭slave的slave特性, 将其升级为主节点

    zb@ubuntu:~/codes/test$ redis-cli -h 127.0.0.1 -p 6379 slaveof NO ONE
    OK
    zb@ubuntu:~/codes/test$ redis-cli -h 127.0.0.1 -p 6379 set slave-read-only no
    OK
    

    升级为主节点后,继续向slave写入:

    In [38]: r2.set('key', 'value')
    Out[38]: True
    

    5. 重启master, 如果将slave升级为master, 此时master与slave已经隔离, 都作为主节点存在(注意此时的主节点是没有数据的)

    In [41]: r1.get('key')
    
    In [42]: 
    

    6. 拷贝R2的dump数据到R1后重启:

    In [43]: r1.get('key')
    Out[43]: 'value'
    

    7. 从新将R2设置为R1的slave(slave默认配置):

    向slave写入:

    In [45]: r2.set('key2', 'value')
    ReadOnlyError: You can't write against a read only slave.
    

    8. 如果将slave-read-only 属性写到配置文件中:

    可以向slave写入数据,但是不会同步到master

    In [50]: r2.set('key2', 'value')
    Out[50]: True
    

    9. Crash掉R1,往R2写数据(关掉slave-read-only):

    SLAVE ->
        'master_link_status': 'down'
    
    In [75]: r2.set('key2', 'value')
    Out[75]: True
    

    重启Master(此时的master无数据):

    In [85]: r2.get('key2')
    
    In [86]: r2.get('key3')
    

    可以看到,重启了Master后,slave同步了master状态,由于master没有数据,slave的数据同时被删除

    总结(部分测试未写出来):

    • slave 配置为slave-read-only on需要升级为主节点或者写入配置文件中, 而不能在默认slave情况下直接设置
    • master与slave断开后会检测心跳, 从新建立连接.
    • 可以直接copy DUMP文件从新重启master
    • 在Master为空以后,slave同步数据会抹掉全部数据.
  • 相关阅读:
    Android编译选项eng、user、userdebug的区别
    Linux 内核编码规范
    PLM之EVT、DVT、PVT、MP
    fastboot刷机的一般方法
    Android手机拨号测试项
    使用Genymotion安装APK出现错误INSTALL_FAILED_CPU_ABI_INCOMPATIBLE的解决办法
    三星手机列表拖动时出现诡异背景色的问题
    分享android ADT百度云盘下载地址
    关于互联网思维
    分享Nginx在Windows下的管理命令(bat文件)
  • 原文地址:https://www.cnblogs.com/Bozh/p/3954379.html
Copyright © 2020-2023  润新知