## Summary - Step 0.1: Update Pulumi ACLs with tag:registry - Step 0.3: Create Zot registry ansible role with mcquack LaunchAgent - Step 0.4: Add Zot to Tailscale Serve configuration - Step 0.5: Create Zot metrics role for Prometheus scraping - Step 0.6: Add Zot log collection to Alloy - Step 0.7: Update indri-services-check with zot checks - Step 0.8: Add podman role for container runtime - Step 0.9: Add minikube role for Kubernetes cluster - Step 0.10: Configure remote kubectl access with 1Password credentials ## Remaining Steps - [ ] Step 0.11: Add minikube to indri-services-check - [ ] Step 0.12: Create zettelkasten documentation - [ ] Step 0.13: Verify main playbook (already done - roles added) ## Deployment and Testing - [x] Zot registry deployed and accessible at https://registry.tail8d86e.ts.net - [x] Podman machine running on indri - [x] Minikube cluster running on indri - [x] kubectl access from gilbert working with 1Password credentials - [ ] indri-services-check passes all checks 🤖 Generated with [Claude Code](https://claude.com/claude-code) Reviewed-on: https://forge.tail8d86e.ts.net/eblume/blumeops/pulls/26
57 lines
1.9 KiB
Django/Jinja
57 lines
1.9 KiB
Django/Jinja
#!/bin/bash
|
|
# {{ ansible_managed }}
|
|
# Collects minikube/kubernetes metrics for node_exporter textfile collector
|
|
|
|
set -euo pipefail
|
|
|
|
OUTPUT_FILE="{{ minikube_metrics_dir }}/minikube.prom"
|
|
TEMP_FILE="${OUTPUT_FILE}.tmp"
|
|
|
|
# Start output file
|
|
cat > "$TEMP_FILE" << 'HEADER'
|
|
# HELP minikube_up Minikube cluster is running
|
|
# TYPE minikube_up gauge
|
|
# HELP minikube_apiserver_up Kubernetes API server is responding
|
|
# TYPE minikube_apiserver_up gauge
|
|
# HELP minikube_node_count Number of nodes in the cluster
|
|
# TYPE minikube_node_count gauge
|
|
# HELP minikube_pod_count Number of pods in the cluster
|
|
# TYPE minikube_pod_count gauge
|
|
# HELP minikube_namespace_count Number of namespaces in the cluster
|
|
# TYPE minikube_namespace_count gauge
|
|
HEADER
|
|
|
|
# Check if minikube is running
|
|
if minikube status --format='{% raw %}{{.Host}}{% endraw %}' 2>/dev/null | grep -q "Running"; then
|
|
echo "minikube_up 1" >> "$TEMP_FILE"
|
|
else
|
|
echo "minikube_up 0" >> "$TEMP_FILE"
|
|
echo "minikube_apiserver_up 0" >> "$TEMP_FILE"
|
|
echo "minikube_node_count 0" >> "$TEMP_FILE"
|
|
echo "minikube_pod_count 0" >> "$TEMP_FILE"
|
|
echo "minikube_namespace_count 0" >> "$TEMP_FILE"
|
|
mv "$TEMP_FILE" "$OUTPUT_FILE"
|
|
exit 0
|
|
fi
|
|
|
|
# Check API server health
|
|
if kubectl get --raw /healthz >/dev/null 2>&1; then
|
|
echo "minikube_apiserver_up 1" >> "$TEMP_FILE"
|
|
else
|
|
echo "minikube_apiserver_up 0" >> "$TEMP_FILE"
|
|
fi
|
|
|
|
# Get node count
|
|
NODE_COUNT=$(kubectl get nodes --no-headers 2>/dev/null | wc -l | tr -d ' ')
|
|
echo "minikube_node_count ${NODE_COUNT:-0}" >> "$TEMP_FILE"
|
|
|
|
# Get pod count (all namespaces)
|
|
POD_COUNT=$(kubectl get pods -A --no-headers 2>/dev/null | wc -l | tr -d ' ')
|
|
echo "minikube_pod_count ${POD_COUNT:-0}" >> "$TEMP_FILE"
|
|
|
|
# Get namespace count
|
|
NS_COUNT=$(kubectl get namespaces --no-headers 2>/dev/null | wc -l | tr -d ' ')
|
|
echo "minikube_namespace_count ${NS_COUNT:-0}" >> "$TEMP_FILE"
|
|
|
|
# Atomic move
|
|
mv "$TEMP_FILE" "$OUTPUT_FILE"
|