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

docker-compose编排项目redis容器实现主从复制的更多相关文章

  1. Docker Compose部署项目到容器-基于Tomcat和mysql的项目yml配置文件代码

    场景 Docker-Compose简介与Ubuntu Server 上安装Compose: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/deta ...

  2. Docker Compose部署项目到容器-基于Tomcat和mysql的商城项目(附源码和sql下载)

    场景 Docker-Compose简介与Ubuntu Server 上安装Compose: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/deta ...

  3. 使用Docker compose编排Laravel应用

    前言 Laravel官方开发环境推荐的是Homestead(其实就是一个封装好的Vagrant box),我感觉这个比较重,于是自己用Docker compose编排了一套开发环境,在这里分享下. 环 ...

  4. 使用docker compose编排容器

    一.安装docker compose 二进制包安装 1.安装 Docker Compose 从 官方 GitHub Release 处直接下载编译好的二进制文件即可 # curl -L https:/ ...

  5. docker之compose 编排项目

    一.docker-compose 的介绍 docker-compose是一种容器编排工具,可以将多个docker容器关联部署.通过yaml文件,可以描述应用的架构,如使用什么镜像.数据卷.网络.绑定服 ...

  6. Docker(二十六)-Docker Compose编排容器

    1. 前言 Docker Compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器. 使用Compose 基本上分为三步: Dockerfile 定义应用 ...

  7. Docker系列之(五):使用Docker Compose编排容器

    1. 前言 Docker Compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器. 使用Compose 基本上分为三步: Dockerfile 定义应用 ...

  8. docker compose 编排

    Compose是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说明:Comp ...

  9. 使用Docker Compose编排Spring Cloud微服务

    文章目录 微服务构建实例 简化Compose的编写 编排高可用的Eureka Server 编排高可用Spring Cloud微服务集群及动态伸缩 微服务项目名称 项目微服务中的角色 microser ...

随机推荐

  1. 【Spark篇】---SparkStreaming算子操作transform和updateStateByKey

    一.前述 今天分享一篇SparkStreaming常用的算子transform和updateStateByKey. 可以通过transform算子,对Dstream做RDD到RDD的任意操作.其实就是 ...

  2. Python内置函数(6)——bool

    英文文档: class bool([x]) Return a Boolean value, i.e. one of True or False. x is converted using the st ...

  3. Python使用Xpath轻松爬虫(脑残式)

    1.在PyCharm安装lxml. 2.找到源码 3.F12.copy源码的xpath 4.代码 from lxml import etree import requests wb_data = re ...

  4. Kafka分区与消费者的关系

    1.  前言 我们知道,生产者发送消息到主题,消费者订阅主题(以消费者组的名义订阅),而主题下是分区,消息是存储在分区中的,所以事实上生产者发送消息到分区,消费者则从分区读取消息,那么,这里问题来了, ...

  5. ASP.NET Core中如何针对一个使用HttpClient对象的类编写单元测试

    原文地址: How to unit test a class that consumes an HttpClient with IHttpClientFactory in ASP.NET Core? ...

  6. Shader 入门笔记(二) CPU和GPU之间的通信,渲染流水线

    渲染流水线 1)应用阶段(CPU处理) 首先,准备好场景数据(摄像机位置,视锥体,模型和光源等) 接着,做粗粒度剔除工作. 最后,设置好每个模型的渲染状态(使用的材质,纹理,shader等) 这一阶段 ...

  7. 在 Vue 结合 Axios 使用过程 中 post 方法,后台无法接受到数据问题

    关于在 vue 中 使用 axios 相关 bug 首先,我们来看下 axios 的 github 传送门 axios 然后我们再介绍下 axios 的作者的 github 传送门 Matt 最后,我 ...

  8. Android 9.0/P http 网络请求的问题

    Google表示,为保证用户数据和设备的安全,针对下一代 Android 系统(Android P) 的应用程序,将要求默认使用加密连接,这意味着 Android P 将禁止 App 使用所有未加密的 ...

  9. Jenkins时间修改为北京时间

    jenkins安装后时间一直是utc时间,不太方便. 系统管理->脚本命令行 运行: System.setProperty('org.apache.commons.jelly.tags.fmt. ...

  10. rabbitmq.config配置参数详解

    rabbitmq.config详细配置参数 详细使用方法请点击:http://www.cnblogs.com/wyt007/p/9073316.html Key Documentation tcp_l ...