zoukankan      html  css  js  c++  java
  • Redis-cluster集群【第三篇】:redis主从

    Redis主从复制原理:

    通过把这个RDB文件或AOF文件传给slave服务器,slave服务器重新加载RDB文件,来实现复制的功能!

    复制的话:主服务器可以有多个从服务器!!!  不仅这样从服务器还可以有从服务器,可以做成星状的结构!
    复制的话也不会阻塞进程,同样fork一个子进程来做!
     
    复制的原理:
    当建立一个从服务器后,从服务器会想主服务器发送一个SYNC的命令,主服务器接收到SYNC命令之后会执行BGSAVE
    然后保存到RDB文件,然后发送到从服务器!收到RDB文件然后就载入到内存!
     
    最早不支持增量,到2.8之后就支持增量了!

    Redis主从配置:

    配置非常简单:
    我要把:192.168.0.201  6380 作为192.168.0.201 6379的从就一条命令
    92.168.0.201:6380> slaveof 192.168.0.201 6379
    OK
    
    然后使用INFO查看下:
    # Replication
    role:slave
    master_host:192.168.0.201
    master_port:6379
    master_link_status:up
    master_last_io_seconds_ago:7
    master_sync_in_progress:0
    slave_repl_offset:85
    slave_priority:100
    slave_read_only:1
    connected_slaves:0
    master_repl_offset:0
    repl_backlog_active:0
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:0
    repl_backlog_histlen:0
    
    然后在到主的上面看下:
    15:38 [root@server.tianshuai.com]$ redis-cli -h 192.168.0.201 -p 6379
    192.168.0.201:6379> INFO
    
    
    # Replication
    role:master
    connected_slaves:1
    slave0:ip=192.168.0.201,port=6380,state=online,offset=183,lag=1    #
    master_repl_offset:183
    repl_backlog_active:1
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:2
    repl_backlog_histlen:182
    
    
    从2.61 的时候!从是仅读的
    192.168.0.201:6380> SET key1 2
    (error) READONLY You can't write against a read only slave.
    192.168.0.201:6380>
    ##现实工作场景中,写和读是1:10的吗,我们就可以,设置多1个主多个从这样,进行读写分离!
  • 相关阅读:
    一个长串由一个字串循环构成
    区间边界 张贴海报的可见性
    summary
    分区本质 从磁盘物理层面优化查询 分区操作的锁表
    全局变量在反汇编中是怎么体现的
    MathType怎么打定积分竖线
    定积分换元法洛必达法则求极限
    静态链表的插入和删除
    Git恢复之前版本的两种方法reset、revert
    服务去耦合
  • 原文地址:https://www.cnblogs.com/luotianshuai/p/4969522.html
Copyright © 2011-2022 走看看