• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    使用docker搭建redis主从的方法步骤

     一、构建 Docker 环境

    1、创建 dockerfile

    FROM centos:latest
    RUN groupadd -r redis && useradd -r -g redis redis
    RUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-tools
    EXPOSE 6379
    

    2、构建镜像

    docker build -t docker-test .

    3、查看当前镜像

    docker iamges
    REPOSITORY  TAG     IMAGE ID    CREATED       SIZE
    docker-test  latest   ccebd30e466a  12 minutes ago   396MB
    centos    latest   470671670cac  7 weeks ago     237MB
    

    4、查看docker默认的网络类型

    docker network ls
    NETWORK ID     NAME        DRIVER       SCOPE
    a43e79987e98    bridge       bridge       local
    6b73067403dc    host        host        local
    b8ad4981e57e    none        null        local

    5、创建自定义网络类型

    docker network create --subnet=172.10.0.0/16 haveyb-network

    二、搭建 Redis 主从

    1、创建 redis-master 容器

    docker run -itd --name redis-master --net haveyb-network -p 6380:6379 --ip 172.10.0.2 docker-test
    
    

    参数解释:

    -i: 以交互模式运行容器,通常与 -t 同时使用

    -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用

    -d: 后台运行容器,并返回容器ID;

    --name: 为创建的容器命名

    --net: 指定网络模式(这里指定刚才创建的自定义网络模式)

    -p: 端口映射,格式为:主机(宿主)端口:容器端口

    --ip: 为容器制定一个固定的ip

    后面再指定一下使用的镜像(这里使用的就是刚才创建的镜像 docker-test)

    2、查看运行中的容器

    docker ps -a
    
    CONTAINER ID    IMAGE     COMMAND       CREATED
    dc9344bbd25f   docker-test   "/bin/bash"     2 minutes ago
     
    STATUS      PORTS             NAMES
    Up 2 minutes   0.0.0.0:6380->6379/tcp    redis-master

    注:查看某个网络下容器的ip地址

    docker network inspect haveyb-network

    3、创建 redis-slave1、redis-slave2 容器

    docker run -itd --name redis-slave1 --net haveyb-network -p 6381:6379 --ip 172.10.0.3 docker-test
    docker run -itd --name redis-slave2 --net haveyb-network -p 6382:6379 --ip 172.10.0.4 docker-test

    4、配置 redis-master 容器

    (1)进入redis-master 容器

    docker exec -it redis-master bash

    注:退出容器 `exit`

    (2)修改redis.conf 配置文件

    vi /etc/redis.conf

    (3)修改参数 bind 127.0.0.1 为 0.0.0.0

    bind 0.0.0.0

    (4)设置主redis 密码

    requirepass YourPasswordSettings

    (5)启动主redis

    redis-server /etc/redis.conf &

    (6)redis-cli

    redis-cli
    auth yourPasswordSettings

    5、配置 redis-slave1

    (1)进入redis-slave1 容器

    docker exec -it redis-slave1 bash

    (2)修改redis.conf 配置文件

    vi /etc/redis.conf

    (3)修改参数 bind 127.0.0.1 为 0.0.0.0

    bind 0.0.0.0
    

    (4)设置 masterauth,添加以下代码(主redis设置密码后,从redis连接需要此参数验权)

    masterauth yourPasswordSettings
    

    (5)设置 slaveof (设置主 redis 的 ip 和 port)

    slaveof 172.10.0.2 6379
    

    (5)启动从redis

    redis-server /etc/redis.conf &
    

    (6)redis 客户端

    redis-cli
    

     6、配置 redis-slave2

    同配置 redis-slave1

    7、在redis -cli中执行 `info replication` 可以查看主从信息

     redis-master

    127.0.0.1:6379> info replication
    # Replication
    role:master
    connected_slaves:2
    slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1
    slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1
    master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1
    master_replid2:0000000000000000000000000000000000000000
    master_repl_offset:3105
    second_repl_offset:-1
    repl_backlog_active:1
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:1
    repl_backlog_histlen:3105
    127.0.0.1:6379> 

    redis-slave1

    127.0.0.1:6379> info replication 
    # Replication
    role:slave
    master_host:172.10.0.2
    master_port:6379
    master_link_status:up
    master_last_io_seconds_ago:1
    master_sync_in_progress:0
    slave_repl_offset:3203
    slave_priority:100
    slave_read_only:1
    connected_slaves:0
    master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1
    master_replid2:0000000000000000000000000000000000000000
    master_repl_offset:3203
    second_repl_offset:-1
    repl_backlog_active:1
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:1
    repl_backlog_histlen:3203
    127.0.0.1:6379> 

    8、在 redis-master 中写入key,redis-slave1 和 redis-slave2 已经可以获取了

    到此这篇关于使用docker搭建redis主从的方法步骤的文章就介绍到这了,更多相关docker搭建redis主从内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    上一篇:docker-compose教程之安装使用和快速入门
    下一篇:Docker容器开jupyter不能访问到的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    使用docker搭建redis主从的方法步骤 使用,docker,搭建,redis,主从,