Files
juwan-backend/deploy/k01/apply-infra.sh
T
zetaloop 8dac0b8d76
build-and-push-harbor / docker-build-push (push) Waiting to run
fix(k01): apply infra cr documents one by one to avoid scheduler storm
2026-05-06 03:44:54 +08:00

52 lines
1.5 KiB
Bash
Executable File

#!/usr/bin/env bash
set -euo pipefail
INFRA_DIR="$(cd "$(dirname "$0")/infra" && pwd)"
export KUBECONFIG="${KUBECONFIG:-/etc/rancher/k3s/k3s.yaml}"
apply_docs() {
local file="$1" kind="$2" wait_expr="$3" buf i
i=0
buf=""
while IFS= read -r line; do
if [[ "$line" == "---" ]]; then
printf '%s\n' "$buf" | kubectl apply -f -
((i++))
echo " ($i) applied"
buf=""
else
[[ -n "$buf" ]] && buf+=$'\n'
buf+="$line"
fi
done < "$file"
printf '%s\n' "$buf" | kubectl apply -f -
((i++))
echo " ($i) applied"
if [ -n "$kind" ]; then
kubectl -n juwan wait --for="$wait_expr" --timeout=900s "$kind" --all || true
fi
}
echo envoy + ratelimit
kubectl apply -f "${INFRA_DIR}/envoy.yaml"
kubectl apply -f "${INFRA_DIR}/ratelimit.yaml"
kubectl -n juwan wait --for=condition=Ready pod -l app=envoy-gateway --timeout=120s || true
kubectl -n juwan wait --for=condition=Ready pod -l "app in (ratelimit,rl-redis)" --timeout=120s || true
echo redis
apply_docs "${INFRA_DIR}/redis.yaml" redisreplication "jsonpath={.status.readyReplicas}=1"
echo postgres
apply_docs "${INFRA_DIR}/postgres.yaml" cluster.postgresql.cnpg.io "condition=Ready"
echo mongo
kubectl apply -f "${INFRA_DIR}/mongo.yaml"
kubectl -n juwan wait --for=jsonpath='{.status.phase}'=Running mongodbcommunity/chat-mongodb --timeout=600s || true
echo kafka
kubectl apply -f "${INFRA_DIR}/kafka.yaml"
kubectl -n kafka wait --for=condition=Ready kafka/juwan-kafka --timeout=900s || true
kubectl get pods -A