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

来源:脚本之家  责任编辑:小易  

 一、构建 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搭建Redis主从复制的集群centos6使用docker部署redis主从数据库操作示例Docker下redis的主从配置教程详解

  • 本文相关:
  • 在docker容器中使用iptables时的最小权限的开启方法
  • 详解docker中vlan网络模式的配置
  • docker 报错 exited (1) 4 minutes ago的原因分析
  • 详解docker下的mysql镜像的使用方法
  • docker nginx 部署多个项目的示例方法
  • 解决docker network create加--subnet后遇到问题
  • 详解docker镜像centos7配置java运行环境
  • 详解springboot项目docker环境运行时无限重启问题
  • docker创建镜像两种方法详解
  • 利用docker-compsoe部署前后端分离的项目方法
  • 如何使用docker构建redis集群
  • docker怎么部署redis
  • 如何使用Docker实现Redis 3.0集群的一键部署交付
  • 如何使用Docker安装Redis\Zookeeper\Mysql
  • 如何访问docker里的redis
  • docker部署redis哨兵模式怎么返回宿主机ip而不是do...
  • 怎么样使用docker启动redis映射接口
  • docker下怎么连接redis指定的库
  • 如何利用docker快速构建MySQL主从复制环境
  • springboot如何连接docker 搭建的redis 哨兵?
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全dockerhyper-vvmwarevirtualboxxenserverkvmqemuopenvzxencloudstackopenstack云计算技术云其它首页服务器云和虚拟化使用docker搭建redis主从复制的集群centos6使用docker部署redis主从数据库操作示例docker下redis的主从配置教程详解在docker容器中使用iptables时的最小权限的开启方法详解docker中vlan网络模式的配置docker 报错 exited (1) 4 minutes ago的原因分析详解docker下的mysql镜像的使用方法docker nginx 部署多个项目的示例方法解决docker network create加--subnet后遇到问题详解docker镜像centos7配置java运行环境详解springboot项目docker环境运行时无限重启问题docker创建镜像两种方法详解利用docker-compsoe部署前后端分离的项目方法docker 给运行中的容器设置端口映docker获取镜像报错docker: errodocker.service启动失败:unit ndocker 清理命令集锦浅谈docker-compose网络设置之neubuntu14.04+docker的安装及使用docker容器如何优雅的终止详解docker容器访问宿主机网络的方法详解如何使用docker部署一个web项详解docker国内镜像拉取和镜像加docke容器分离部署lnmp的实现docker swarm 集群故障与异常详解docker端口映射实现网络访问的方法docker容器中运行nginxdocker 深入了解镜像、容器、仓库等概念使用 docker 企业版搭建自己的私有注册服docker 使用cmd或者entrypoint命令同时启docker下修改mysql配置文件的方法详解docker 容器基础系统镜像打包docker 修改文件是否需要重启(命令详解)
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved