我的编程空间,编程开发者的网络收藏夹
学习永远不晚

docker部署zookeeper集群方式(单主机、多主机)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

docker部署zookeeper集群方式(单主机、多主机)

1、一台主机上部署zookeeper集群

下面这个是官方给出的docker-compose的部署方案(这个是都在一台主机上部署的):

version: '3'
services:
    zoo1:
        image: zookeeper
        restart: always
        ports:
            - 2182:2181
        environment:
            ZOO_MY_ID: 1
            ZOO_SERVERS: server.1=zoo1:2888:3888;2181 server.2=zoo2:2888:3888;2181 server.3=zoo3:2888:3888;2181
    zoo2:
        image: zookeeper
        restart: always
        ports:
            - 2183:2181
        environment:
            ZOO_MY_ID: 2
            ZOO_SERVERS: server.1=zoo1:2888:3888;2181 server.2=zoo2:2888:3888;2181 server.3=zoo3:2888:3888;2181
    zoo3:
        image: zookeeper
        restart: always
        ports:
            - 2184:2181
        environment:
            ZOO_MY_ID: 3
            ZOO_SERVERS: server.1=zoo1:2888:3888;2181 server.2=zoo2:2888:3888;2181 server.3=zoo3:2888:3888;2181

2、一台主机部署zookeeper集群分析

我们从上面的分析,最主要的就是ZOO_MY_ID和ZOO_SERVERS(更多环境变量配置参考:https://hub.docker.com/_/zookeeper)

  • ZOO_MY_ID:节点ID
  • ZOO_SERVERS:集群节点地址,多个节点之间使用空格隔开

由此可以看出如果不在一个主机上,那么这几个容器之间就得是想通的,为了使其想通,我们运用了Macvlan网络

3、Macvlan网络

macvlan本身是linxu kernel的模块,本质上是一种网卡虚拟化技术。

其功能是允许在同一个物理网卡上虚拟出多个网卡,通过不同的MAC地址在数据链路层进行网络数据的转发,一块网卡上配置多个 MAC 地址(即多个 interface),每个interface可以配置自己的IP,Docker的macvlan网络实际上就是使用了Linux提供的macvlan驱动.在物理网络看来,每张虚拟网卡都是一个单独的接口。

4、跨主机环境准备

编号主机IP容器IP
主机1192.168.1.18710.0.3.71
主机2192.168.1.18810.0.3.72
主机3192.168.1.18910.0.3.73

5、创建macvlan网络

主机1(主机2和主机3也做如下类似操作):

docker network create -d macvlan --subnet=10.0.3.0/24 --gateway=10.0.3.1 -o parent=em2 zookeeper-kafka-net
  • subnet这里结尾最好是/24,代表255.255.255.0,如果是/16代表255.255.0.0,16这种据说在设置了iptable的情况下会出问题
  • parent后是网卡名称192.168.1.187的网卡名称,可通过ipconfig查找

最后的zookeeper-kafka-net是你创建的macvlan网络名称,可随意写

6、docker-compose.yml文件

主机1:

version: "3"
services:
  zookeeper1:
    container_name: zookeeper1
    image: zookeeper:3.6.2
    networks:
      zookeeper-kafka-net:
        ipv4_address: 10.0.3.71
    ports:
      - "22181:2181"
      - "22888:2888"
      - "23888:3888"
    environment:
      ZOO_MY_ID: 1
      ZOO_SERVERS: server.1=10.0.3.71:2888:3888;2181 server.2=10.0.3.72:2888:3888;2181 server.3=10.0.3.73:2888:3888;2181
    restart: always
networks:
  zookeeper-kafka-net:
    external:
      name: zookeeper-kafka-net

主机2:

version: "3"
services:
  zookeeper2:
    container_name: zookeeper2
    image: zookeeper:3.6.2
    networks:
      zookeeper-kafka-net:
        ipv4_address: 10.0.3.72
    ports:
      - "22181:2181"
      - "22888:2888"
      - "23888:3888"
    environment:
      ZOO_MY_ID: 2
      ZOO_SERVERS: server.1=10.0.3.71:2888:3888;2181 server.2=10.0.3.72:2888:3888;2181 server.3=10.0.3.73:2888:3888;2181
    restart: always
networks:
  zookeeper-kafka-net:
    external:
      name: zookeeper-kafka-net

主机3:

version: "3"
services:
  zookeeper3:
    container_name: zookeeper3
    image: zookeeper:3.6.2
    networks:
      zookeeper-kafka-net:
        ipv4_address: 10.0.3.73
    ports:
      - "22181:2181"
      - "22888:2888"
      - "23888:3888"
    environment:
      ZOO_MY_ID: 3
      ZOO_SERVERS: server.1=10.0.3.71:2888:3888;2181 server.2=10.0.3.72:2888:3888;2181 server.3=10.0.3.73:2888:3888;2181
    restart: always
networks:
  zookeeper-kafka-net:
    external:
      name: zookeeper-kafka-net

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

docker部署zookeeper集群方式(单主机、多主机)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

docker部署zookeeper集群方式(单主机、多主机)

这篇文章主要介绍了docker部署zookeeper集群方式(单主机、多主机),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-15

Linux主机与Ceph集群部署

在Linux主机上部署Ceph集群是一个涉及多个步骤的过程,需要考虑网络配置、节点角色分配、时间同步等多个方面。以下是使用cephadm工具进行部署的基本步骤:部署前准备节点准备:确保所有节点已关闭防火墙,配置了SSH免密登录,并安装了必
Linux主机与Ceph集群部署
2024-09-27

Redis从单点到集群部署模式(单机模式 主从模式 哨兵模式)

目录导读单机模式优势劣势主从模式优势劣势哨兵模式优势劣势集群模式优势劣势全量复制部分复制导读Redis 从单点 -> 集群总共有三个部署模式:单机模式,主从模式,哨兵模式,集群模式单机模式新手入门模式。单机模式意味着 Redis 是单
Redis从单点到集群部署模式(单机模式 主从模式 哨兵模式)
2023-11-08

docker-compose启动redis多机集群的实现(6台服务器3主3从)

目录1. 环境说明2. 集群部署Redis-node-1redis-node-2redis-node-3redis-node-4redis-node-5redis-node-63. 初始化4. 测试1. 环境说明节点IPredis-nod
2022-07-13

编程热搜

目录