基于Docker的Kafka部署
一 准备
1.1 安装docker-dompose
#部署
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
#设置权限
chmod +x /usr/bin/docker-compose
#验证
docker-compose version
1.2 下载镜像
docker pull wurstmeister/zookeeper:latest
docker pull wurstmeister/kafka:0.10.0.1
也可以使用Dockerfile构建,构建文件都在Github上https://github.com/jdlzy/kafka-docker
二 部署Zookeeper
在hub.docker.com网站上,Star最多的kafka镜像是wurstmeister/kafka
https://github.com/wurstmeister/kafka-docker
首先需要新建专用网络
docker network create --driver bridge --subnet 172.23.0.0/25 --gateway 172.23.0.1 zookeeper_network
部署zookeeper需要在任意目录下新建docker-compose.yml,将下边的内容拷贝到目录中。
#前台启动
docker-compose up
#后台启动
docker-compose up -d
2.1 yml文件
version: '3.4'
services:
zoo1:
image: wurstmeister/zookeeper
restart: always
hostname: zookeeper
container_name: zookeeper
ports:
- :
volumes:
- "/root/lzy/kafka-docker/data/kafka/data:/data"
- "/root/lzy/kafka-docker/data/kafka/datalog:/datalog"
environment:
ZOO_MY_ID:
ZOO_SERVERS: server.=zookeeper::
networks:
default:
ipv4_address: 172.23.0.11
networks:
default:
external:
name: zookeeper_network
三 Kafka部署
在任意目录下新建docker-compose.yml,将下边的内容拷贝到目录中。
#前台启动
docker-compose up
#后台启动
docker-compose up -d
3.1 yml文件
10.95.3.172是我的物理机的IP,这里穿件3个节点,Broker端口分别为9092、9093、9094
version: ''
services:
kafka1:
image: wurstmeister/kafka:0.10.0.1
restart: always
hostname: kafka1
container_name: kafka1
ports:
- "9092:9092"
environment:
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://10.95.3.172:9092
KAFKA_ADVERTISED_HOST_NAME: 10.95.3.172
KAFKA_ADVERTISED_PORT:
KAFKA_ZOOKEEPER_CONNECT: zookeeper:
external_links:
- zookeeper
networks:
default:
ipv4_address: 172.23.0.14
kafka2:
image: wurstmeister/kafka:0.10.0.1
restart: always
hostname: kafka2
container_name: kafka2
ports:
- "9093:9092"
environment:
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://10.95.3.172:9093
KAFKA_ADVERTISED_HOST_NAME: 10.95.3.172
KAFKA_ADVERTISED_PORT:
KAFKA_ZOOKEEPER_CONNECT: zookeeper:
external_links: # 连接本compose文件以外的container
- zookeeper
networks:
default:
ipv4_address: 172.23.0.15
kafka3:
image: wurstmeister/kafka:0.10.0.1
restart: always
hostname: kafka3
container_name: kafka3
ports:
- "9094:9092"
environment:
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://10.95.3.172:9094
KAFKA_ADVERTISED_HOST_NAME: 10.95.3.172
KAFKA_ADVERTISED_PORT:
KAFKA_ZOOKEEPER_CONNECT: zookeeper:
external_links: # 连接本compose文件以外的container
- zookeeper
networks:
default:
ipv4_address: 172.23.0.16
networks:
default:
external: # 使用已创建的网络
name: zookeeper_network
四 测试
在任意物理机(需要部署了wurstmeister/kafka:0.10.0.1镜像),或者直接下载0.10.0.1的Kafka安装包。
如果是基于Docker,执行下边的命令启动一个临时容器
docker run --rm -v /var/run/docker.sock:/var/run/docker.sock -e HOST_IP=$ -e ZK=$ -i -t wurstmeister/kafka:0.10.0.1 /bin/bash
如果是基于Kafka安装包,直接解压即可。
然后到/opt/kafka/bin目录下
4.1 创建Topic
–replication-factor表示副本数,–partitions表示分片数量
./kafka-topics.sh --create --zookeeper 10.95.3.172: --replication-factor --partitions --topic t1
#查看topic
./kafka-topics.sh --list --zookeeper 10.95.3.172:
4.2 创建生产者
./kafka-console-producer.sh --broker-list 10.95.3.172:,10.95.3.172:,10.95.3.172: --topic t1
4.3 创建消费者
–from-beginning表示从消息起始开始读取
./kafka-console-consumer.sh --zookeeper 10.95.3.172: --topic t1 --from-beginning
五 非docker-compose部署方式
不使用docker-compose可以进行分布式部署,但是目前还有问题,有待进一步测试
5.1 部署zookeeper
docker run -d --name zookeeper --publish : --volume /etc/localtime:/etc/localtime wurstmeister/zookeeper:latest
5.2 部署kafka
创建多节点时候需要修改KAFKA_BROKER_ID为唯一,
-p映射到物理机的端口不能重复,第二个可以为9093,第三个可以为9094等。
docker run -d --name kafka \
-e HOST_IP=10.95.3.172 \
-e KAFKA_ADVERTISED_PORT= \
--env KAFKA_ADVERTISED_HOST_NAME=10.95.3.172 \
-e KAFKA_BROKER_ID= \
-e ZK=zk \
-p : \
--link zookeeper:zk \
-t wurstmeister/kafka:0.10.0.1
基于Docker的Kafka部署的更多相关文章
- 基于docker和cri-dockerd部署kubernetes v1.25.3
基于docker和cri-dockerd部署kubernetes v1.25.3 1.环境准备 1-1.主机清单 主机名 IP地址 系统版本 k8s-master01 k8s-master01.wan ...
- 基于Docker的GoldenGate部署
前言 Docker最近几年异常火爆,主要是因为其方便.快捷.轻量,相对于VM,它不需要占用太多资源,随时可以创建.删除,或在已有image上添加一些软件,再制作成另一个模板image供日后使用.Doc ...
- SpringBoot | 第十四章:基于Docker的简单部署
前言 讲解了单元测试,本章节讲讲应用的部署吧.总体而言,在进行自动化部署时,基本都会用上Jenkins+Maven+Docker进行部署.本章节主要讲解使用Maven+Docker进行SpringBo ...
- OpenLDAP 多主复制(基于docker容器模式部署)
**本文主要讲述在docker环境下如何进行 OpenLDAP 多主复制,至于 OpenLDAP 原理可以先参考这篇文章了解:https://cloud.tencent.com/developer/a ...
- 基于docker的wekan部署
镜像地址: https://hub.docker.com/r/wekanteam/wekan/ wiki: https://github.com/wekan/wekan/wiki#Developmen ...
- Ubuntu系统下基于docker部署Jenkins环境
本文是在ubuntu环境下安装jenkins,jenkins运行在docker容器中, 至于docker如何安装,请参考https://www.cnblogs.com/xingyunqiu/p/115 ...
- 庐山真面目之九微服务架构 NetCore 基于 Docker 基础镜像和挂载文件部署
庐山真面目之九微服务架构 NetCore 基于 Docker 基础镜像和挂载文件部署 一.简介 我们在上一篇文章<庐山真面目之八微服务架构 NetCore 基于 Dockerfile ...
- 庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群
庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群 一.简介 前面的两篇文章,我们已经介绍了Net Core项目基于Docker容器部署在Linux服 ...
- 基于Docker一键部署大规模Hadoop集群及设计思路
一.背景: 随着互联网的发展.互联网用户的增加,互联网中的数据也急剧膨胀.每天产生的数据量数以万计,本地文件系统和单机CPU已无法满足存储和计算要求.Hadoop分布式文件系统(HDFS)是海量数据存 ...
随机推荐
- VM 15 永久激活密钥
VMware Workstation 15 永久激活密钥 YG5H2-ANZ0H-M8ERY-TXZZZ-YKRV8 UG5J2-0ME12-M89WY-NPWXX-WQH88 UA5 ...
- keras损失函数
keras文档: http://keras.io/objectives/ mean_squared_error / mse 均方误差,常用的目标函数,公式为((y_pred-y_true)**2) ...
- Ionic4.x 中的 UI 组件(UI Components)表单相关组件
1.ion-input 单行文本框 2.ion-toggle 开关 3.ion-radio-group.ion-radio 单选按钮组 4.ion-checkbox 多选按钮组 5.ion-selec ...
- 001-http-总览、文件配置、常用http client、http连接池
一.概述 http请求项目搭建:地址:https://github.com/bjlhx15/common-study.git 中的common-http 主要针对post请求中的,form表单[app ...
- 5G && 物联网
可打电话的 2G.能够上网的 3G.满足移动互联网用户需求的 4G 相比,逐步可以商用的 5G 在多重性能上更胜一筹,如 高数据率: 低延迟: 更节能: 有效地降低通信成本: 具备更高的系统容量: 更 ...
- python中计算上个月和下个月的第一天的方法
闹腾,一个简单的东西复杂化了,记录下吧: import datetime,time def get_1st_of_last_month(): """ 获取上个月第一天的日 ...
- (二)UML之类图、接口、包
一.概念 类图(Class Diagram): 类图是面向对象系统建模中最常用和最重要的图,是定义其它图的基础.类图主要是用来显示系统中的类.接口以及它们之间的静态结构和关系的一种静态模型. 类图的3 ...
- Python3之类和实例继承和多态
在OPP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类,父类或超类 例如,我们已经编写了一个名为A ...
- Docker Machine(十五)
目录 一.Docker Machine 总览 1.Docker Engine VS Docker Machine 2.环境准备 二.安装 Docker Machine 1.Install Machin ...
- .Net中委托的协变和逆变详解
关于协变和逆变要从面向对象继承说起.继承关系是指子类和父类之间的关系:子类从父类继承所以子类的实例也就是父类的实例.比如说Animal是父类,Dog是从Animal继承的子类:如果一个对象的类型是Do ...