Add tilt
This commit is contained in:
3
Tiltfile
Normal file
3
Tiltfile
Normal file
@@ -0,0 +1,3 @@
|
||||
allow_k8s_contexts('default')
|
||||
|
||||
include('konvert/Tiltfile')
|
||||
15
init_cluster.sh
Executable file
15
init_cluster.sh
Executable file
@@ -0,0 +1,15 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
kind delete cluster
|
||||
|
||||
kind create cluster --config deployment/kind.yaml
|
||||
|
||||
kubectl wait -A --for=condition=ready pod --field-selector=status.phase!=Succeeded --timeout=15m
|
||||
|
||||
kubectl get cm -n kube-system kube-proxy -o yaml | sed 's/maxPerCore.*/maxPerCore: 0/' | kubectl apply -n kube-system -f -
|
||||
|
||||
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.7.1/deploy/static/provider/kind/deploy.yaml
|
||||
|
||||
LB_IP=$(kubectl get svc -n ingress-nginx ingress-nginx-controller -o jsonpath='{.status.loadBalancer.ingress[0].ip}')
|
||||
|
||||
echo "address=/kind.cluster/$LB_IP"
|
||||
19
konvert/Tiltfile
Normal file
19
konvert/Tiltfile
Normal file
@@ -0,0 +1,19 @@
|
||||
k8s_yaml('./redpanda-owl-shop-default-networkpolicy.yaml')
|
||||
k8s_yaml('./redpanda-persistentvolumeclaim.yaml')
|
||||
k8s_yaml('./redpanda-deployment.yaml')
|
||||
k8s_yaml('./redpanda-owl-shop-redpanda-network-networkpolicy.yaml')
|
||||
k8s_yaml('./redpanda-service.yaml')
|
||||
|
||||
k8s_yaml('./connect-service.yaml')
|
||||
k8s_yaml('./connect-deployment.yaml')
|
||||
|
||||
k8s_yaml('./owl-shop-deployment.yaml')
|
||||
|
||||
k8s_yaml('./console-deployment.yaml')
|
||||
k8s_yaml('./console-service.yaml')
|
||||
k8s_yaml('./console-ingress.yaml')
|
||||
|
||||
docker_build('kafka-lag-exporter', './..')
|
||||
|
||||
k8s_yaml('./kafka-lag-exporter-deployment.yaml')
|
||||
k8s_yaml('./kafka-lag-exporter-service.yaml')
|
||||
48
konvert/connect-deployment.yaml
Normal file
48
konvert/connect-deployment.yaml
Normal file
@@ -0,0 +1,48 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
io.kompose.service: connect
|
||||
name: connect
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
io.kompose.service: connect
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
io.kompose.service: connect
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: CONNECT_BOOTSTRAP_SERVERS
|
||||
value: redpanda:29092
|
||||
- name: CONNECT_CONFIGURATION
|
||||
value: |
|
||||
key.converter=org.apache.kafka.connect.converters.ByteArrayConverter
|
||||
value.converter=org.apache.kafka.connect.converters.ByteArrayConverter
|
||||
group.id=connectors-cluster
|
||||
offset.storage.topic=_internal_connectors_offsets
|
||||
config.storage.topic=_internal_connectors_configs
|
||||
status.storage.topic=_internal_connectors_status
|
||||
config.storage.replication.factor=-1
|
||||
offset.storage.replication.factor=-1
|
||||
status.storage.replication.factor=-1
|
||||
offset.flush.interval.ms=1000
|
||||
producer.linger.ms=50
|
||||
producer.batch.size=131072
|
||||
- name: CONNECT_GC_LOG_ENABLED
|
||||
value: "false"
|
||||
- name: CONNECT_HEAP_OPTS
|
||||
value: -Xms512M -Xmx512M
|
||||
- name: CONNECT_LOG_LEVEL
|
||||
value: info
|
||||
image: docker.redpanda.com/redpandadata/connectors:latest
|
||||
name: connect
|
||||
ports:
|
||||
- containerPort: 8083
|
||||
hostname: connect
|
||||
restartPolicy: Always
|
||||
13
konvert/connect-service.yaml
Normal file
13
konvert/connect-service.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: connect
|
||||
name: connect
|
||||
spec:
|
||||
ports:
|
||||
- name: "8083"
|
||||
port: 8083
|
||||
targetPort: 8083
|
||||
selector:
|
||||
io.kompose.service: connect
|
||||
48
konvert/console-deployment.yaml
Normal file
48
konvert/console-deployment.yaml
Normal file
@@ -0,0 +1,48 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
io.kompose.service: console
|
||||
name: console
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
io.kompose.service: console
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
io.kompose.service: console
|
||||
spec:
|
||||
containers:
|
||||
- args:
|
||||
- -c
|
||||
- echo "$(CONSOLE_CONFIG_FILE)" > /tmp/config.yml; /app/console
|
||||
command:
|
||||
- /bin/sh
|
||||
env:
|
||||
- name: CONFIG_FILEPATH
|
||||
value: /tmp/config.yml
|
||||
- name: CONSOLE_CONFIG_FILE
|
||||
value: |
|
||||
kafka:
|
||||
brokers: ["redpanda:29092"]
|
||||
schemaRegistry:
|
||||
enabled: true
|
||||
urls: ["http://redpanda:8081"]
|
||||
redpanda:
|
||||
adminApi:
|
||||
enabled: true
|
||||
urls: ["http://redpanda:9644"]
|
||||
connect:
|
||||
enabled: true
|
||||
clusters:
|
||||
- name: local-connect-cluster
|
||||
url: http://connect:8083
|
||||
image: docker.redpanda.com/redpandadata/console:v2.2.4
|
||||
name: console
|
||||
ports:
|
||||
- containerPort: 8080
|
||||
restartPolicy: Always
|
||||
17
konvert/console-ingress.yaml
Normal file
17
konvert/console-ingress.yaml
Normal file
@@ -0,0 +1,17 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: Ingress
|
||||
metadata:
|
||||
name: ingress-myserviceb
|
||||
spec:
|
||||
rules:
|
||||
- host: console.lechindianer.hack
|
||||
http:
|
||||
paths:
|
||||
- path: /
|
||||
pathType: Prefix
|
||||
backend:
|
||||
service:
|
||||
name: console
|
||||
port:
|
||||
number: 8080
|
||||
ingressClassName: nginx
|
||||
13
konvert/console-service.yaml
Normal file
13
konvert/console-service.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: console
|
||||
name: console
|
||||
spec:
|
||||
ports:
|
||||
- name: "8080"
|
||||
port: 8080
|
||||
targetPort: 8080
|
||||
selector:
|
||||
io.kompose.service: console
|
||||
29
konvert/kafka-lag-exporter-deployment.yaml
Normal file
29
konvert/kafka-lag-exporter-deployment.yaml
Normal file
@@ -0,0 +1,29 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: kafka-lag-exporter
|
||||
name: kafka-lag-exporter
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
io.kompose.service: kafka-lag-exporter
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.network/redpanda-owl-shop-default: "true"
|
||||
io.kompose.service: kafka-lag-exporter
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: KAFKA_BROKERS
|
||||
value: redpanda:29092
|
||||
image: kafka-lag-exporter
|
||||
name: kafka-lag-exporter
|
||||
ports:
|
||||
- containerPort: 4000
|
||||
# Remove the command for final part
|
||||
command: [ "/bin/sh", "-c", "--" ]
|
||||
args: [ "while true; do sleep 30; done;" ]
|
||||
restartPolicy: Always
|
||||
13
konvert/kafka-lag-exporter-service.yaml
Normal file
13
konvert/kafka-lag-exporter-service.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: kafka-lag-exporter
|
||||
name: kafka-lag-exporter
|
||||
spec:
|
||||
ports:
|
||||
- name: "4000"
|
||||
port: 4000
|
||||
targetPort: 4000
|
||||
selector:
|
||||
io.kompose.service: kafka-lag-exporter
|
||||
31
konvert/owl-shop-deployment.yaml
Normal file
31
konvert/owl-shop-deployment.yaml
Normal file
@@ -0,0 +1,31 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: owl-shop
|
||||
name: owl-shop
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
io.kompose.service: owl-shop
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
io.kompose.service: owl-shop
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: SHOP_KAFKA_BROKERS
|
||||
value: redpanda:29092
|
||||
- name: SHOP_KAFKA_TOPICREPLICATIONFACTOR
|
||||
value: "1"
|
||||
- name: SHOP_TRAFFIC_INTERVAL_DURATION
|
||||
value: 0.1s
|
||||
- name: SHOP_TRAFFIC_INTERVAL_RATE
|
||||
value: "6"
|
||||
image: quay.io/cloudhut/owl-shop:latest
|
||||
name: owl-shop
|
||||
restartPolicy: Always
|
||||
44
konvert/redpanda-deployment.yaml
Normal file
44
konvert/redpanda-deployment.yaml
Normal file
@@ -0,0 +1,44 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: redpanda
|
||||
name: redpanda
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
io.kompose.service: redpanda
|
||||
strategy:
|
||||
type: Recreate
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
io.kompose.service: redpanda
|
||||
spec:
|
||||
containers:
|
||||
- args:
|
||||
- redpanda start
|
||||
- --smp 1
|
||||
- --overprovisioned
|
||||
- --kafka-addr PLAINTEXT://0.0.0.0:29092,OUTSIDE://0.0.0.0:9092
|
||||
- --advertise-kafka-addr PLAINTEXT://redpanda:29092,OUTSIDE://localhost:9092
|
||||
- --pandaproxy-addr 0.0.0.0:8082
|
||||
- --advertise-pandaproxy-addr localhost:8082
|
||||
image: docker.redpanda.com/redpandadata/redpanda:v23.1.8
|
||||
name: redpanda
|
||||
ports:
|
||||
- containerPort: 8081
|
||||
- containerPort: 8082
|
||||
- containerPort: 9092
|
||||
- containerPort: 9644
|
||||
- containerPort: 29092
|
||||
volumeMounts:
|
||||
- mountPath: /var/lib/redpanda/data
|
||||
name: redpanda
|
||||
restartPolicy: Always
|
||||
volumes:
|
||||
- name: redpanda
|
||||
persistentVolumeClaim:
|
||||
claimName: redpanda
|
||||
13
konvert/redpanda-owl-shop-default-networkpolicy.yaml
Normal file
13
konvert/redpanda-owl-shop-default-networkpolicy.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: NetworkPolicy
|
||||
metadata:
|
||||
name: redpanda-owl-shop-default
|
||||
spec:
|
||||
ingress:
|
||||
- from:
|
||||
- podSelector:
|
||||
matchLabels:
|
||||
io.kompose.network/redpanda-owl-shop-default: "true"
|
||||
podSelector:
|
||||
matchLabels:
|
||||
io.kompose.network/redpanda-owl-shop-default: "true"
|
||||
@@ -0,0 +1,13 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: NetworkPolicy
|
||||
metadata:
|
||||
name: redpanda-owl-shop-redpanda-network
|
||||
spec:
|
||||
ingress:
|
||||
- from:
|
||||
- podSelector:
|
||||
matchLabels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
podSelector:
|
||||
matchLabels:
|
||||
io.kompose.network/redpanda-owl-shop-redpanda-network: "true"
|
||||
12
konvert/redpanda-persistentvolumeclaim.yaml
Normal file
12
konvert/redpanda-persistentvolumeclaim.yaml
Normal file
@@ -0,0 +1,12 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: redpanda
|
||||
name: redpanda
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 100Mi
|
||||
25
konvert/redpanda-service.yaml
Normal file
25
konvert/redpanda-service.yaml
Normal file
@@ -0,0 +1,25 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
io.kompose.service: redpanda
|
||||
name: redpanda
|
||||
spec:
|
||||
ports:
|
||||
- name: "8081"
|
||||
port: 8081
|
||||
targetPort: 8081
|
||||
- name: "8082"
|
||||
port: 8082
|
||||
targetPort: 8082
|
||||
- name: "9092"
|
||||
port: 9092
|
||||
targetPort: 9092
|
||||
- name: "9644"
|
||||
port: 9644
|
||||
targetPort: 9644
|
||||
- name: "29092"
|
||||
port: 29092
|
||||
targetPort: 29092
|
||||
selector:
|
||||
io.kompose.service: redpanda
|
||||
Reference in New Issue
Block a user