
本镜像提供了一个可扩展的Kafka部署方案,是https://hub.docker.com/r/wurstmeister/kafka/%E7%9A%84%E5%A2%9E%E5%BC%BA%E7%89%88%E3%80%82%E9%80%9A%E8%BF%87%E9%9B%86%E6%88%90HAproxy%E8%B4%9F%E8%BD%BD%E5%9D%87%E8%A1%A1%E5%99%A8%EF%BC%8C%E6%94%AF%E6%8C%81%E5%A4%9AKafka%E5%89%AF%E6%9C%AC%E7%9A%84%E5%BC%B9%E6%80%A7%E6%89%A9%E5%B1%95%EF%BC%8C%E5%B9%B6%E5%86%85%E7%BD%AEKafka Manager用于集群管理(可通过[主机IP]:9000访问)。镜像可直接从https://hub.docker.com/r/polinux/kafka/%E8%8E%B7%E5%8F%96%E3%80%82
适用于需要部署可扩展、高可用Kafka集群的开发、测试或生产环境,尤其适合需要动态调整集群规模、简化管理的场景。
set-address脚本设置主机IP(不可使用localhost或127.0.0.1,否则无法运行多broker):
bash./set-address --address 192.168.1.200
docker-compose.yml中添加环境变量(例如:KAFKA_MESSAGE_MAX_BYTES: 2000000设置消息最大字节数,KAFKA_AUTO_CREATE_TOPICS_ENABLE: 'false'关闭自动主题创建)start-kafka-cluster脚本支持以下参数:
--replicas (-r):指定启动的Kafka副本数量--test (-t):运行生产者/消费者测试(需下载polinux/php:7.1镜像,耗时较长)示例1:简单启动单节点集群
bash./start-kafka-cluster
示例2:启动4个副本并运行测试
bash./start-kafka-cluster --replicas 4 --test
示例3:扩展现有集群至5个副本
bashdocker-compose scale kafka=5
bashdocker-compose up -d
基于脚本
bash./destroy-kafka-cluster
基于docker-compose
bashdocker-compose stop docker-compose rm -f
未在docker-compose.yml中指定broker ID时,将自动生成(参考KAFKA-1070),支持集群弹性伸缩。建议使用docker-compose --no-recreate确保容器不被重建,保持名称和ID稳定。
通过KAFKA_CREATE_TOPICS环境变量在集群启动时自动创建主题,格式:"主题名:分区数:副本数[:cleanup.policy]"。示例:
yamlenvironment: KAFKA_CREATE_TOPICS: "Topic1:1:3,Topic2:1:1:compact"
Topic1:1个分区,3个副本Topic2:1个分区,1个副本,清理策略为compact可通过以下方式配置Kafka advertised hostname:
KAFKA_ADVERTISED_HOST_NAME: "主机IP"HOSTNAME_COMMAND: "命令"(例如AWS环境获取本地IP:wget -t3 -T2 -qO- http://169.254.169.254/latest/meta-data/local-ipv4)KAFKA_ADVERTISED_HOST_NAME优先级高于HOSTNAME_COMMAND。
通过KAFKA_JMX_OPTS和JMX_PORT配置JMX监控,示例:
yamlenvironment: KAFKA_JMX_OPTS: "-Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.0.50 -Dcom.sun.management.jmxremote.rmi.port=1099 -Djava.net.preferIPv4Stack=true" JMX_PORT: 1099
通过Jconsole连接:jconsole 192.168.0.50:1099
提供集群启动、Kafka Manager监控、副本扩展及集群销毁的演示(原始GIF演示包含启动、管理界面、扩展和销毁过程)。
以下是 polinux/kafka 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务