Refactor code for improved readability and performance
This commit is contained in:
150
scripts/check-deployments.sh
Executable file
150
scripts/check-deployments.sh
Executable file
@@ -0,0 +1,150 @@
|
||||
#!/bin/bash
|
||||
# Check Deployment Status on Proxmox Host
|
||||
# Shows what containers are deployed and their status
|
||||
|
||||
set +e
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
source "$SCRIPT_DIR/load-env.sh"
|
||||
load_env_file
|
||||
|
||||
PROXMOX_HOST="${PROXMOX_HOST:-192.168.11.10}"
|
||||
PROXMOX_PORT="${PROXMOX_PORT:-8006}"
|
||||
|
||||
echo ""
|
||||
echo "╔════════════════════════════════════════════════════════════════╗"
|
||||
echo "║ Deployment Status - ${PROXMOX_HOST} ║"
|
||||
echo "╚════════════════════════════════════════════════════════════════╝"
|
||||
echo ""
|
||||
|
||||
# Get first node
|
||||
NODES_RESPONSE=$(curl -k -s -m 10 \
|
||||
-H "Authorization: PVEAPIToken=${PROXMOX_USER}!${PROXMOX_TOKEN_NAME}=${PROXMOX_TOKEN_VALUE}" \
|
||||
"https://${PROXMOX_HOST}:${PROXMOX_PORT}/api2/json/nodes" 2>&1)
|
||||
|
||||
FIRST_NODE=$(echo "$NODES_RESPONSE" | python3 -c "import sys, json; print(json.load(sys.stdin)['data'][0]['node'])" 2>/dev/null)
|
||||
|
||||
# Get containers
|
||||
CONTAINERS_RESPONSE=$(curl -k -s -m 10 \
|
||||
-H "Authorization: PVEAPIToken=${PROXMOX_USER}!${PROXMOX_TOKEN_NAME}=${PROXMOX_TOKEN_VALUE}" \
|
||||
"https://${PROXMOX_HOST}:${PROXMOX_PORT}/api2/json/nodes/${FIRST_NODE}/lxc" 2>&1)
|
||||
|
||||
# Check if response is valid JSON
|
||||
if ! echo "$CONTAINERS_RESPONSE" | python3 -c "import sys, json; json.load(sys.stdin)" 2>/dev/null; then
|
||||
echo "Error: Failed to retrieve containers"
|
||||
echo "Response preview: $(echo "$CONTAINERS_RESPONSE" | head -c 200)"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Parse and display using Python
|
||||
python3 << PYEOF
|
||||
import sys, json
|
||||
|
||||
try:
|
||||
response = """$CONTAINERS_RESPONSE"""
|
||||
data = json.loads(response)['data']
|
||||
|
||||
if len(data) == 0:
|
||||
print("No containers found")
|
||||
print("\nTo deploy:")
|
||||
print(" ./scripts/deploy-to-proxmox-host.sh")
|
||||
sys.exit(0)
|
||||
|
||||
# Categorize containers
|
||||
validators = []
|
||||
sentries = []
|
||||
rpc_nodes = []
|
||||
services = []
|
||||
monitoring = []
|
||||
explorer = []
|
||||
hyperledger = []
|
||||
other = []
|
||||
|
||||
for container in data:
|
||||
vmid = container['vmid']
|
||||
name = container.get('name', 'N/A')
|
||||
status = container.get('status', 'unknown')
|
||||
|
||||
if 106 <= vmid <= 109:
|
||||
validators.append((vmid, name, status))
|
||||
elif 110 <= vmid <= 114:
|
||||
sentries.append((vmid, name, status))
|
||||
elif 115 <= vmid <= 119:
|
||||
rpc_nodes.append((vmid, name, status))
|
||||
elif 120 <= vmid <= 129:
|
||||
services.append((vmid, name, status))
|
||||
elif 130 <= vmid <= 139:
|
||||
monitoring.append((vmid, name, status))
|
||||
elif 140 <= vmid <= 149:
|
||||
explorer.append((vmid, name, status))
|
||||
elif 150 <= vmid <= 153:
|
||||
hyperledger.append((vmid, name, status))
|
||||
else:
|
||||
other.append((vmid, name, status))
|
||||
|
||||
# Display by category
|
||||
def print_category(title, containers):
|
||||
if containers:
|
||||
print(f"\n{title} ({len(containers)}):")
|
||||
print(f" {'VMID':<6} {'Name':<30} {'Status':<10}")
|
||||
print(" " + "-" * 48)
|
||||
for vmid, name, status in sorted(containers):
|
||||
if status == "running":
|
||||
status_display = f"\033[32m{status}\033[0m"
|
||||
elif status == "stopped":
|
||||
status_display = f"\033[31m{status}\033[0m"
|
||||
else:
|
||||
status_display = f"\033[33m{status}\033[0m"
|
||||
print(f" {vmid:<6} {name:<30} {status_display}")
|
||||
|
||||
print_category("Validators", validators)
|
||||
print_category("Sentries", sentries)
|
||||
print_category("RPC Nodes", rpc_nodes)
|
||||
print_category("Services", services)
|
||||
print_category("Monitoring", monitoring)
|
||||
print_category("Explorer", explorer)
|
||||
print_category("Hyperledger", hyperledger)
|
||||
|
||||
if other:
|
||||
print(f"\nOther Containers ({len(other)}):")
|
||||
for vmid, name, status in sorted(other):
|
||||
if status == "running":
|
||||
status_display = f"\033[32m{status}\033[0m"
|
||||
elif status == "stopped":
|
||||
status_display = f"\033[31m{status}\033[0m"
|
||||
else:
|
||||
status_display = f"\033[33m{status}\033[0m"
|
||||
print(f" VMID {vmid}: {name} ({status_display})")
|
||||
|
||||
# Summary
|
||||
print("\n" + "=" * 60)
|
||||
print("Summary")
|
||||
print("=" * 60)
|
||||
print(f"Total Containers: {len(data)}")
|
||||
|
||||
running = sum(1 for c in data if c.get('status') == 'running')
|
||||
stopped = sum(1 for c in data if c.get('status') == 'stopped')
|
||||
print(f" Running: {running}")
|
||||
print(f" Stopped: {stopped}")
|
||||
|
||||
print(f"\nSMOM-DBIS-138 Deployment:")
|
||||
print(f" Validators: {len(validators)}/4")
|
||||
print(f" Sentries: {len(sentries)}/3")
|
||||
print(f" RPC Nodes: {len(rpc_nodes)}/3")
|
||||
print(f" Services: {len(services)}")
|
||||
print(f" Monitoring: {len(monitoring)}")
|
||||
print(f" Explorer: {len(explorer)}")
|
||||
print(f" Hyperledger: {len(hyperledger)}")
|
||||
|
||||
if len(validators) == 0 and len(sentries) == 0 and len(rpc_nodes) == 0:
|
||||
print("\n⚠️ No SMOM-DBIS-138 containers found")
|
||||
print("To deploy: ./scripts/deploy-to-proxmox-host.sh")
|
||||
else:
|
||||
print("\n✅ SMOM-DBIS-138 deployment found")
|
||||
|
||||
except Exception as e:
|
||||
print(f"Error parsing response: {e}")
|
||||
import traceback
|
||||
traceback.print_exc()
|
||||
sys.exit(1)
|
||||
PYEOF
|
||||
Reference in New Issue
Block a user