zoukankan      html  css  js  c++  java
  • redis主从复制

    一.安装redis

    安装依赖类库

    yum -y install cpp binutils glibc glibc-kernheaders glibc-common glibc-devel gcc make gcc-c++ libstdc++-devel tcl

    下载redis
    http://download.redis.io/releases/

    安装redis

    mkdir -p /usr/local/src/redis
    cd /usr/local/src/redis
    rz 上传
    tar -xvf redis-3.0.2.tar.gz 
    cd redis-3.0.2
    make
    make test #这个就不要执行了,需要很长时间
    make install
    cp redis.conf /etc/
    vi /etc/redis.conf
    # 修改如下,默认为no
    daemonize yes
    #启动
    redis-server /etc/redis.conf
    #测试
    redis-cli
    

    二.主从复制的好处有2点:

    1、避免redis单点故障
    2.构建读写分离架构,满足读多写少的应用场景
    3.主从架构

    主从安装redis(这里以一台机器作为实验)

    1.创建6379、6380、6381目录,分别将安装目录下的redis.conf拷贝到这三个目录下。

    cd /root
    mkdir redis && cd redis
    mkdir 6379 6380 6381
    cp /etc/redis.conf 6379/
    cp /etc/redis.conf 6380/
    cp /etc/redis.conf 6381/
    

    2.修改6380 6381 redis.conf文件

    port 6380
    pidfile /var/run/redis-6380.pid
    
    port 6381
    pidfile /var/run/redis-6381.pid
    

    3.关掉“一”中redis服务

    ps -ef|grep reids
    kill -9 pid
    

    4.分别启动/root/redis中6379,6380,6381配置

    cd /root/reids
    cd 6379 redis-server && ./redis.conf && cd ..
    cd 6380 redis-server && ./redis.conf && cd ..
    cd 6381 redis-server && ./redis.conf && cd ..
    ps -ef|grep reids #查看是否启动
    

    5.设置主从

    在redis中设置主从有2种方式:
    1、在redis.conf中设置slaveof`
    slaveof <masterip> <masterport>
    2、使用redis-cli客户端连接到redis服务,执行slaveof命令`
    slaveof <masterip> <masterport>`
    主从关系搭建成功会产生一个dump.rdb文件
    例如:
    redis-cli -p 6380 #连接到6380
    slaveof 127.0.0.1 6379
    redis-cli -p 6379 #链接到6379主reids
    set cary 'cary'
    reids-cli -p 6380
    get cary #检验是否能够查到数据
    
    第二种方式在重启后将失去主从复制关系
    

    6.查看主从信息

    执行 INFO replication  #在主库和从库中都可以执行
    
    role:角色
    connected_slaves:从库数量
    slave0:从库信息
    

    四.哨兵配置

    接下来开始配置哨兵。建立一个配置文件sentinel.conf,内容为:

    cd /root/6379/
    vim sentinel.conf
    添加:
    sentinel monitor mymaster 127.0.0.1 6379 1  
    启动哨兵
    redis-sentinel /root/redis/6379/sentinel.conf  
    
    命令号输出
    

    13283:X 17 Jan 06:49:21.139 # +monitor master mymaster 127.0.0.1 6379 quorum 1

    13283:X 17 Jan 06:49:21.155 * +slave slave 127.0.0.1:6381 127.0.0.1 6381 @ mymaster 127.0.0.1 6379

    13283:X 17 Jan 06:49:21.159 * +slave slave 127.0.0.1:6380 127.0.0.1 6380 @ mymaster 127.0.0.1 6379

    其中”+slave”表示新发现了从库,可见哨兵成功地发现了两个从库

    现在哨兵已经在监控这3个Redis实例了,这时将从库关闭(杀死进程或使用 shutdown 命令),等待指定时间后(可配置,默认为 30 秒),哨兵会输出如下内容

    13283:X 17 Jan 06:50:41.440 # +sdown slave 127.0.0.1:6381 127.0.0.1 6381 @ mymaster 127.0.0.1 6379

  • 相关阅读:
    Spark-sql windows 下 执行错误.
    notepad ++ 注册表
    log4j 配置文件 示例
    linux 查看 进程 内存占用
    spring boot 常见错误解决
    python 轻量 web 框架 Bottle 使用
    Spring cloud eureka 添加 spring-security
    vue can‘ not resolver sass-loader 的 解决办法。
    外国人眼中的珍珠奶茶是啥?
    75.2亿美元:诺基亚、微软终于在一起
  • 原文地址:https://www.cnblogs.com/weiguo21/p/5762206.html
Copyright © 2011-2022 走看看