docker-compose编排项目redis容器实现主从复制

一.pip管理工具安装

  docker-compose是python项目,所以安装需要通过python下的包管理工具pip安装。一般linux服务器都会预安装有python环境,所以优先检查python是否已经安装,pip管理工具是否已经安装

  

# wget https://bootstrap.pypa.io/get-pip.py    #下载pip脚本
# python2.7 get-pip.py                 #将pip绑定到python2.7中
# pip install --upgrade pip        #更新pip
# pip install docker-compose==1.22    #安装指定版本的docker-compose
# docker -v
Docker version 18.09.0

   当安装docker-compose可能遇到一些错误提示,如:自动删除request包失败时可以通过pip install --ignore-installed request命令忽略安装request包再安装docker-compose

二.资料准备

  创建目录如/workdir作为redis容器的工作目录。在/workdir中创建redis-master.conf(主reids配置文件)、redis-slave.conf(从reids配置文件)、redis-master.sh(主容器的redis启动脚本)、redis-slave.sh(从容器的redis启动脚本)

  redis-master.conf主要配置如下:

  

################################## NETWORK #####################################
bind 0.0.0.0  
port 6379

################################## SECURITY ###################################
requirepass 1


################################# REPLICATION #################################
masterauth 1            #以防以后使用哨兵切换主节点后连接不到新主节点

   redis-slave.conf主要配置如下:

################################## NETWORK #####################################
bind 0.0.0.0
port 6379

################################## SECURITY ###################################
requirepass 1


################################# REPLICATION #################################
slaveof 172.20.0.2 6379      #指定主节点的ip
masterauth 1

   redis-master.sh代码如下:

#!/usr/bin/bash
redis-server /workdir/redis-master.conf

   redis-slave.sh代码如下:

#!/usr/bin/bash
redis-server /workdir/redis-slave.conf

 

   准备docker-compose编排文件,由于当前docker引擎版本是18.09.0所以这里version使用3.7版本

version: "3.7"
services:
  redis-master:
     image: redis
     container_name: redis-master
     stdin_open: true
     tty: true
     networks:
       redis:
         ipv4_address: 172.20.0.2
     volumes:
       - "/workdir:/workdir"
     expose:
       - "6379"
     command: ["/bin/bash","/workdir/redis.sh"]

  redis-slave:
     image: redis
     container_name: redis-slave
     stdin_open: true
     tty: true
     depends_on:
       - redis-master
     networks:
       redis:
         ipv4_address: 172.20.0.3
     volumes:
       - "/workdir:/workdir"
     expose:
       - "6379"
     command: ["/bin/bash","/workdir/redis.sh"]


networks:
  redis:
     driver: bridge
     ipam:
       driver: default
       config:
         - subnet: 172.20.0.0/16

 

 

  执行编排文件。

# docker-compose up -d
Creating network "docker-compose_redis" with driver "bridge"
Creating redis-master ... done
Creating redis-slave  ... done
# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
3f586ac5a1b8        redis               "/bin/bash /workdir/…"   11 seconds ago      Up 10 seconds       6379/tcp            redis-slave
354d20e933bf        redis               "/bin/bash /workdir/…"   11 seconds ago      Up 10 seconds       6379/tcp            redis-master

 

  备注:

  1.如果在编排文件测试的过程中遇到error等错误,经重新编写后不能马上执行docker-compose up -d执行编排任务。因为之前的命令中很可能已经创建了指定的容器或网络等。需要执行 docker-compose down先停掉编排任务再执行 docker-compose up -d执行编排任务。

  2.写编排文件的时候曾经踩了一个大坑,容器建立完后使用bash脚本启动主、从redis服务时曾经尝试公用一个配置文件来启动。后来一台启动成功一台启动不成功。经过docker logs redis-slave查看日志后发现是

 

':C 15 Dec 09:43:39.423 # Fatal error, can't open config file '/workdir/docker-compose/redis-master.conf

 

   经过测试发现当一个redis服务通过一个配置文件启动后会把该配置文件的权限修改并且在服务执行的过程中会主动根据环境配置(如:哨兵或客户端设置环境变量时)的变动修改配置文件的值。所以两个redis服务不能共用一个配置文件,需要独立拥有自己的配置文件。

  3.根据上面的道理,在容器的使用过程中,不同容器尽量不要共用同一个文件或脚本,尽量分开使用,尽管使用的脚本内容一样也不要自己去跳这些坑。

 

posted @ 2018-12-16 00:23  #walter#  阅读(2087)  评论(0编辑  收藏  举报