-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathinit.sh
executable file
·58 lines (45 loc) · 2.41 KB
/
init.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/usr/bin/env bash
STRIMZI_VERSION="0.45.0" && export STRIMZI_VERSION
NAMESPACE="test" && export NAMESPACE
[[ "${BASH_SOURCE[0]}" -ef "$0" ]] && echo "Usage: source init.sh" && exit 1
for x in curl kubectl openssl keytool unzip yq java javac jshell mvn; do
if ! command -v "$x" &>/dev/null; then
echo "Missing required utility: $x"; return 1
fi
done
kafka-cp() {
local id="${1-}" part="${2-50}"
[[ -z $id ]] && echo "Missing params" && return
echo 'public void run(String id, int part) { System.out.println(abs(id.hashCode()) % part); }
private int abs(int n) { return (n == Integer.MIN_VALUE) ? 0 : Math.abs(n); }
run("'"$id"'", '"$part"');' | jshell -
}
kubectl-kafka() {
kubectl get po kafka-tools &>/dev/null || kubectl run kafka-tools -q --restart="Never" \
--image="apache/kafka:latest" -- sh -c "trap : TERM INT; sleep infinity & wait"
kubectl wait --for=condition=ready po kafka-tools &>/dev/null
kubectl exec kafka-tools -itq -- sh -c "/opt/kafka/$*"
}
echo "Deploying Strimzi"
# create test namespace
kubectl config set-context --current --namespace="$NAMESPACE" &>/dev/null
# delete any topic first to clean finalizers
kubectl get kt -o yaml 2>/dev/null | yq 'del(.items[].metadata.finalizers[])' \
| kubectl apply -f - &>/dev/null; kubectl delete kt --all --force &>/dev/null
kubectl delete ns "$NAMESPACE" --ignore-not-found --force --wait=false &>/dev/null
kubectl wait --for=delete ns/"$NAMESPACE" --timeout=120s &>/dev/null && kubectl create ns "$NAMESPACE"
# set privileged SecurityStandard label for this namespace
kubectl label ns "$NAMESPACE" pod-security.kubernetes.io/enforce=privileged --overwrite &>/dev/null
# PersistentVolumes cleanup
# shellcheck disable=SC2046
kubectl delete pv $(kubectl get pv 2>/dev/null | grep "my-cluster" | awk '{print $1}') --ignore-not-found --force &>/dev/null
# deploy Strimzi
STRIMZI_FILE="/tmp/strimzi-$STRIMZI_VERSION.yaml"
if [[ ! -f "$STRIMZI_FILE" ]]; then
echo "Downloading Strimzi to $STRIMZI_FILE"
curl -sLk "https://github.com/strimzi/strimzi-kafka-operator/releases/download/$STRIMZI_VERSION/strimzi-cluster-operator-$STRIMZI_VERSION.yaml" -o "$STRIMZI_FILE"
fi
sed -E "s/namespace: .*/namespace: $NAMESPACE/g ; s/memory: .*/memory: 500Mi/g" "$STRIMZI_FILE" \
| kubectl create -f - --dry-run=client -o yaml | kubectl replace --force -f - &>/dev/null
kubectl wait --for=condition=Available deploy strimzi-cluster-operator --timeout=300s
echo "Done"