Files
2026-05-31 16:07:30 +02:00

147 lines
3.1 KiB
YAML

apiVersion: v1
kind: Namespace
metadata:
name: kafka
---
apiVersion: v1
kind: Service
metadata:
name: kafka-headless
namespace: kafka
labels:
app: kafka
spec:
clusterIP: None
selector:
app: kafka
ports:
- name: broker
port: 9092
- name: controller
port: 9093
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: kafka
namespace: kafka
spec:
serviceName: kafka-headless
replicas: 1
selector:
matchLabels:
app: kafka
template:
metadata:
labels:
app: kafka
spec:
securityContext:
runAsUser: 1000
runAsGroup: 1000
fsGroup: 1000
containers:
- name: kafka
image: apache/kafka:4.0.0
ports:
- containerPort: 9092
name: broker
- containerPort: 9093
name: controller
env:
- name: KAFKA_PROCESS_ROLES
value: "broker,controller"
- name: KAFKA_NODE_ID
value: "1"
- name: KAFKA_CONTROLLER_LISTENER_NAMES
value: "CONTROLLER"
- name: KAFKA_LISTENERS
value: "PLAINTEXT://0.0.0.0:9092,CONTROLLER://0.0.0.0:9093"
- name: KAFKA_ADVERTISED_LISTENERS
value: "PLAINTEXT://kafka-0.kafka-headless.kafka.svc.cluster.local:9092"
- name: KAFKA_LISTENER_SECURITY_PROTOCOL_MAP
value: "PLAINTEXT:PLAINTEXT,CONTROLLER:PLAINTEXT"
- name: KAFKA_CONTROLLER_QUORUM_VOTERS
value: "1@kafka-0.kafka-headless.kafka.svc.cluster.local:9093"
- name: KAFKA_LOG_DIRS
value: "/var/lib/kafka/data"
volumeMounts:
- name: kafka-storage
mountPath: /var/lib/kafka
volumeClaimTemplates:
- metadata:
name: kafka-storage
spec:
accessModes:
- ReadWriteOnce
storageClassName: longhorn
resources:
requests:
storage: 2Gi
---
apiVersion: v1
kind: Service
metadata:
name: kafka-ui
namespace: kafka
spec:
type: NodePort
selector:
app: kafka-ui
ports:
- name: http
port: 8080
targetPort: 8080
nodePort: 31890
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: kafka-ui
namespace: kafka
spec:
replicas: 1
selector:
matchLabels:
app: kafka-ui
template:
metadata:
labels:
app: kafka-ui
spec:
containers:
- name: kafka-ui
image: provectuslabs/kafka-ui:latest
ports:
- containerPort: 8080
env:
- name: KAFKA_CLUSTERS_0_NAME
value: "kraft-cluster"
- name: KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS
value: "kafka-0.kafka-headless.kafka.svc.cluster.local:9092"
---
apiVersion: traefik.io/v1alpha1
kind: IngressRoute
metadata:
name: kafka-ui-tls
namespace: kafka
spec:
entryPoints:
- websecure
routes:
- match: Host(`kafka-dev.allarddcs.nl`)
kind: Rule
services:
- name: kafka-ui
port: 8080
tls:
certResolver: letsencrypt