DevOps系列文章 之 docker 制作kafka镜像

Docker制作Kafka镜像教程

概述

本教程将指导你如何使用Docker制作一个Kafka镜像。Kafka是一个高性能、分布式的消息队列系统,用于处理大规模的实时数据流。使用Docker制作Kafka镜像可以方便地部署和管理Kafka集群。

整体流程

下面是制作Kafka镜像的整体流程:

复制代码
步骤    描述
1    安装Docker
2    下载Kafka
3    创建Dockerfile
4    构建Docker镜像
5    运行Kafka容器
现在,让我们逐步来完成这些步骤。

步骤1:安装Docker

首先,你需要在你的机器上安装Docker。Docker是一个开源的容器化平台,可以帮助我们创建、部署和运行应用程序。

你可以通过以下命令来安装Docker:

复制代码
sudo apt-get update
sudo apt-get install docker-ce

步骤2:下载Kafka

在制作Kafka镜像之前,你需要下载Kafka二进制文件。你可以从Kafka的官方网站(

复制代码
wget 
tar -xzf kafka_2.13-2.8.0.tgz

步骤3:创建Dockerfile

Dockerfile是一个用于构建Docker镜像的文本文件。在这一步,我们将创建一个Dockerfile,用于制作Kafka镜像。

在你的项目目录下创建一个名为Dockerfile的文件,并将以下代码复制到文件中:

复制代码
# 基于官方的OpenJDK 8镜像作为基础镜像
FROM openjdk:8

# 设置Kafka版本
ARG KAFKA_VERSION=2.8.0

# 设置Kafka安装路径
ARG KAFKA_HOME=/opt/kafka

# 下载并安装Kafka
RUN wget -q  && \
    tar -xzf kafka_2.13-${KAFKA_VERSION}.tgz -C /opt && \
    rm kafka_2.13-${KAFKA_VERSION}.tgz

# 设置Kafka环境变量
ENV PATH=${KAFKA_HOME}/bin:$PATH

# 设置Kafka工作目录
WORKDIR ${KAFKA_HOME}

# 暴露Kafka监听端口
EXPOSE 9092

# 启动Kafka
CMD ["kafka-server-start.sh", "config/server.properties"]

以上Dockerfile使用了官方的OpenJDK 8镜像作为基础镜像,并下载并安装了指定版本的Kafka。同时,它还设置了Kafka的环境变量和工作目录,并暴露Kafka的监听端口。

步骤4:构建Docker镜像

在完成Dockerfile的编写后,我们将使用以下命令构建Docker镜像:

复制代码
docker build -t kafka:2.8.0 .

该命令会在当前目录下构建一个名为kafka:2.8.0的Docker镜像。

步骤5:运行Kafka容器

完成Docker镜像的构建后,我们可以使用以下命令来运行Kafka容器:

复制代码
docker run -d --name kafka -p 9092:9092 kafka:2.8.0

该命令会在后台运行一个名为kafka的容器,并将主机的9092端口映射到容器的9092端口。

至此,你已经成功地用Docker制作了一个Kafka镜像,并成功运行了一个Kafka容器。

完整案例

复制代码
# 基于官方的OpenJDK 8镜像作为基础镜像
FROM openjdk:8

# 设置Kafka版本
ARG KAFKA_VERSION=3.4.1

# 设置Kafka安装路径
ARG KAFKA_HOME=/opt/kafka
ADD kafka_2.12-3.4.1.tgz /opt
# 下载并安装Kafka
RUN mv /opt/kafka_2.12-3.4.1 /opt/kafka

# 设置Kafka环境变量
ENV PATH=${KAFKA_HOME}/bin:$PATH

# 设置Kafka工作目录
WORKDIR ${KAFKA_HOME}
COPY docker-entrypoint.sh docker-entrypoint.sh
# 暴露Kafka监听端口
EXPOSE 9092 2181

# 启动Kafka
ENTRYPOINT ["/bin/bash", "docker-entrypoint.sh" ]

复制代码
#!/bin/bash
 
if [ "$1" = 'zk' ]; then
	zookeeper-server-start.sh config/zookeeper.properties 2>&1 &
	echo "zk ..."
fi
 
kafka-server-start.sh config/server.properties
相关推荐
2501_9411421315 分钟前
前端高性能优化与微前端架构设计在大型互联网系统中的实践经验分享
kafka
20岁30年经验的码农1 小时前
Kafka 消息中间件实战指南
分布式·kafka·linq
S***y3964 小时前
DevOps监控告警体系
运维·devops
一夜空中最亮的星一5 小时前
【Linux】ubuntu24.04 安装docker
linux·docker·eureka
会飞的小蛮猪6 小时前
Ubuntu24.04基于Docker部署K8s(使用私服部署)
经验分享·docker·云原生·容器·kubernetes
yumgpkpm6 小时前
腾讯云TBDS与CDH迁移常见问题有哪些?建议由CDH迁移到CMP 7.13 平台(类Cloudera CDP,如华为鲲鹏 ARM 版)
hive·hadoop·zookeeper·flink·spark·kafka·hbase
weixin_436525079 小时前
使用 idea 命令行构建 Docker 镜像并部署到云服务器
linux·docker·github
S***q19210 小时前
DevOps在云中的云计算
运维·云计算·devops
h***015411 小时前
Docker启动安装nacos(详情讲解,全网最细)
运维·docker·容器
人工智能训练12 小时前
windows系统中的docker,xinference直接运行在容器目录和持载在宿主机目录中的区别
linux·服务器·人工智能·windows·ubuntu·docker·容器