【K8S】 基于Kubernetes部署Kafka集群,2024年最新字节面试官迟到

apiVersion: v1

kind: Service

metadata:

name: kafka-service

labels:

app: kafka

spec:

type: NodePort

ports:

  • port: 9092

name: kafka-port

targetPort: 9092

nodePort: 30092

protocol: TCP

selector:

app: kafka

kind: Deployment

apiVersion: extensions/v1beta1

metadata:

name: kafka-deployment

spec:

replicas: 1

selector:

matchLabels:

name: kafka

template:

metadata:

labels:

name: kafka

app: kafka

spec:

containers:

  • name: kafka

image: wurstmeister/kafka

imagePullPolicy: IfNotPresent

ports:

  • containerPort: 9092

env:

  • name: KAFKA_ADVERTISED_PORT

value: “9092”

  • name: KAFKA_ADVERTISED_HOST_NAME

value: “[kafka的service的clusterIP]”

  • name: KAFKA_ZOOKEEPER_CONNECT

value: [zookeeper的service的clusterIP]:2181

  • name: KAFKA_BROKER_ID

value: “1”

clusterIP通过kubectl get svc进行查看。KAFKA_ZOOKEEPER_CONNECT的值也可以改为zookeeper-service:2181。

3.创建后,需要对服务进行测试。参考了https://blog.csdn.net/boling_cavalry/article/details/78309050的方法。

在此之前,针对虚拟化的Kafka,需要先执行下面的命令以进入容器:

kubectl exec -it [Kafka的pod名称] /bin/bash

进入容器后,Kafka的命令存储在opt/kafka/bin目录下,用cd命令进入:

cd opt/kafka/bin

后面的操作就跟上面的博客中写的类似了。针对单节点Kafka,需要将同一个节点作为生产者和消费者。执行命令如下:

kafka-console-producer.sh --broker-list [kafka的service的clusterIP]:9092 --topic test

运行正常的话,下方会出现>标记以提示输入消息。这样这个终端就成为了生产者。

另外打开一个linux终端,执行相同的命令进入容器。这次将这个终端作为消费者。注意,上面的博客中写

  • 14
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值