Apply Composer changes: comprehensive API updates, migrations, middleware, and infrastructure improvements
- Add comprehensive database migrations (001-024) for schema evolution - Enhance API schema with expanded type definitions and resolvers - Add new middleware: audit logging, rate limiting, MFA enforcement, security, tenant auth - Implement new services: AI optimization, billing, blockchain, compliance, marketplace - Add adapter layer for cloud integrations (Cloudflare, Kubernetes, Proxmox, storage) - Update Crossplane provider with enhanced VM management capabilities - Add comprehensive test suite for API endpoints and services - Update frontend components with improved GraphQL subscriptions and real-time updates - Enhance security configurations and headers (CSP, CORS, etc.) - Update documentation and configuration files - Add new CI/CD workflows and validation scripts - Implement design system improvements and UI enhancements
This commit is contained in:
196
scripts/check-cluster-status.sh
Executable file
196
scripts/check-cluster-status.sh
Executable file
@@ -0,0 +1,196 @@
|
||||
#!/bin/bash
|
||||
# check-cluster-status.sh
|
||||
# Checks the status of a Proxmox cluster
|
||||
|
||||
set -euo pipefail
|
||||
|
||||
# Load environment variables
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
if [ -f "${SCRIPT_DIR}/../.env" ]; then
|
||||
set -a
|
||||
source <(grep -v '^#' "${SCRIPT_DIR}/../.env" | grep -v '^$' | sed 's/^/export /')
|
||||
set +a
|
||||
fi
|
||||
|
||||
# Colors
|
||||
GREEN='\033[0;32m'
|
||||
RED='\033[0;31m'
|
||||
YELLOW='\033[1;33m'
|
||||
BLUE='\033[0;34m'
|
||||
CYAN='\033[0;36m'
|
||||
NC='\033[0m'
|
||||
|
||||
# Configuration
|
||||
CLUSTER_NAME="${1:-sankofa-sfv-01}"
|
||||
NODE1_IP="192.168.11.10"
|
||||
NODE1_NAME="ML110-01"
|
||||
NODE1_TOKEN="${PROXMOX_TOKEN_ML110_01:-}"
|
||||
NODE2_IP="192.168.11.11"
|
||||
NODE2_NAME="R630-01"
|
||||
NODE2_TOKEN="${PROXMOX_TOKEN_R630_01:-}"
|
||||
|
||||
log() {
|
||||
echo -e "${GREEN}[INFO]${NC} $1"
|
||||
}
|
||||
|
||||
error() {
|
||||
echo -e "${RED}[ERROR]${NC} $1" >&2
|
||||
}
|
||||
|
||||
warn() {
|
||||
echo -e "${YELLOW}[WARN]${NC} $1"
|
||||
}
|
||||
|
||||
info() {
|
||||
echo -e "${BLUE}[INFO]${NC} $1"
|
||||
}
|
||||
|
||||
check_cluster_status() {
|
||||
local endpoint=$1
|
||||
local token=$2
|
||||
local node_name=$3
|
||||
|
||||
echo ""
|
||||
info "=== ${node_name} Cluster Status ==="
|
||||
|
||||
# Check cluster status
|
||||
local status_response=$(curl -k -s -H "Authorization: PVEAPIToken ${token}" \
|
||||
"${endpoint}/api2/json/cluster/status" 2>/dev/null)
|
||||
|
||||
if echo "$status_response" | jq -e '.data' >/dev/null 2>&1; then
|
||||
local cluster_name=$(echo "$status_response" | jq -r '.data[0].name // "unknown"')
|
||||
local node_count=$(echo "$status_response" | jq -r '.data | length')
|
||||
|
||||
if [ "$cluster_name" != "null" ] && [ -n "$cluster_name" ]; then
|
||||
log "✓ Cluster found: ${cluster_name}"
|
||||
log " Node count: ${node_count}"
|
||||
echo "$status_response" | jq -r '.data[] | " • \(.name) - Type: \(.type) - Status: \(.status // "unknown")"'
|
||||
else
|
||||
warn "Cluster status endpoint accessible but no cluster data"
|
||||
fi
|
||||
else
|
||||
local error_msg=$(echo "$status_response" | jq -r '.message // "Unknown error"')
|
||||
if echo "$error_msg" | grep -q "Permission check failed"; then
|
||||
warn "Permission denied (may need Sys.Audit permission)"
|
||||
else
|
||||
warn "Not in cluster or cluster not accessible: ${error_msg}"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
check_cluster_nodes() {
|
||||
local endpoint=$1
|
||||
local token=$2
|
||||
local node_name=$3
|
||||
|
||||
echo ""
|
||||
info "=== ${node_name} Cluster Nodes ==="
|
||||
|
||||
local nodes_response=$(curl -k -s -H "Authorization: PVEAPIToken ${token}" \
|
||||
"${endpoint}/api2/json/cluster/config/nodes" 2>/dev/null)
|
||||
|
||||
if echo "$nodes_response" | jq -e '.data' >/dev/null 2>&1; then
|
||||
local node_count=$(echo "$nodes_response" | jq -r '.data | length')
|
||||
|
||||
if [ "$node_count" -gt 0 ]; then
|
||||
log "✓ Cluster nodes found: ${node_count}"
|
||||
echo "$nodes_response" | jq -r '.data[] | " • Node: \(.node) - Node ID: \(.nodeid) - Votes: \(.votes)"'
|
||||
else
|
||||
warn "No nodes found in cluster configuration"
|
||||
fi
|
||||
else
|
||||
local error_msg=$(echo "$nodes_response" | jq -r '.message // "Unknown error"')
|
||||
if echo "$error_msg" | grep -q "Permission check failed"; then
|
||||
warn "Permission denied (may need Sys.Audit permission)"
|
||||
else
|
||||
warn "Cluster nodes not accessible: ${error_msg}"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
check_cluster_config() {
|
||||
local endpoint=$1
|
||||
local token=$2
|
||||
local node_name=$3
|
||||
|
||||
echo ""
|
||||
info "=== ${node_name} Cluster Configuration ==="
|
||||
|
||||
local config_response=$(curl -k -s -H "Authorization: PVEAPIToken ${token}" \
|
||||
"${endpoint}/api2/json/cluster/config" 2>/dev/null)
|
||||
|
||||
if echo "$config_response" | jq -e '.data' >/dev/null 2>&1; then
|
||||
local cluster_name=$(echo "$config_response" | jq -r '.data.clustername // "unknown"')
|
||||
|
||||
if [ "$cluster_name" != "null" ] && [ -n "$cluster_name" ]; then
|
||||
log "✓ Cluster name: ${cluster_name}"
|
||||
|
||||
if [ "$cluster_name" = "$CLUSTER_NAME" ]; then
|
||||
log " ✓ Matches expected cluster name: ${CLUSTER_NAME}"
|
||||
else
|
||||
warn " ⚠ Cluster name mismatch. Expected: ${CLUSTER_NAME}, Found: ${cluster_name}"
|
||||
fi
|
||||
else
|
||||
warn "Cluster config accessible but no cluster name found"
|
||||
fi
|
||||
else
|
||||
local error_msg=$(echo "$config_response" | jq -r '.message // "Unknown error"')
|
||||
if echo "$error_msg" | grep -q "Permission check failed"; then
|
||||
warn "Permission denied (may need Sys.Audit permission)"
|
||||
else
|
||||
warn "Cluster config not accessible: ${error_msg}"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
main() {
|
||||
echo ""
|
||||
echo "╔══════════════════════════════════════════════════════════════╗"
|
||||
echo "║ Proxmox Cluster Status Check ║"
|
||||
echo "╚══════════════════════════════════════════════════════════════╝"
|
||||
echo ""
|
||||
|
||||
info "Checking cluster: ${CLUSTER_NAME}"
|
||||
echo ""
|
||||
|
||||
# Check Node 1
|
||||
check_cluster_status "https://${NODE1_IP}:8006" "${NODE1_TOKEN}" "${NODE1_NAME}"
|
||||
check_cluster_nodes "https://${NODE1_IP}:8006" "${NODE1_TOKEN}" "${NODE1_NAME}"
|
||||
check_cluster_config "https://${NODE1_IP}:8006" "${NODE1_TOKEN}" "${NODE1_NAME}"
|
||||
|
||||
# Check Node 2
|
||||
check_cluster_status "https://${NODE2_IP}:8006" "${NODE2_TOKEN}" "${NODE2_NAME}"
|
||||
check_cluster_nodes "https://${NODE2_IP}:8006" "${NODE2_TOKEN}" "${NODE2_NAME}"
|
||||
check_cluster_config "https://${NODE2_IP}:8006" "${NODE2_TOKEN}" "${NODE2_NAME}"
|
||||
|
||||
echo ""
|
||||
echo "╔══════════════════════════════════════════════════════════════╗"
|
||||
echo "║ Summary ║"
|
||||
echo "╚══════════════════════════════════════════════════════════════╝"
|
||||
echo ""
|
||||
|
||||
# Try to determine overall status
|
||||
local node1_status=$(curl -k -s -H "Authorization: PVEAPIToken ${NODE1_TOKEN}" \
|
||||
"https://${NODE1_IP}:8006/api2/json/cluster/status" 2>/dev/null | \
|
||||
jq -r 'if .data then "in-cluster" else "standalone" end' 2>/dev/null || echo "unknown")
|
||||
|
||||
local node2_status=$(curl -k -s -H "Authorization: PVEAPIToken ${NODE2_TOKEN}" \
|
||||
"https://${NODE2_IP}:8006/api2/json/cluster/status" 2>/dev/null | \
|
||||
jq -r 'if .data then "in-cluster" else "standalone" end' 2>/dev/null || echo "unknown")
|
||||
|
||||
if [ "$node1_status" = "in-cluster" ] && [ "$node2_status" = "in-cluster" ]; then
|
||||
log "✓ Both nodes appear to be in a cluster"
|
||||
elif [ "$node1_status" = "standalone" ] && [ "$node2_status" = "standalone" ]; then
|
||||
warn "Both nodes are standalone (not clustered)"
|
||||
else
|
||||
warn "Mixed status: Node 1: ${node1_status}, Node 2: ${node2_status}"
|
||||
fi
|
||||
|
||||
echo ""
|
||||
info "Note: Some checks may require additional API permissions (Sys.Audit)"
|
||||
info "For full cluster status, use Proxmox web UI or SSH: pvecm status"
|
||||
echo ""
|
||||
}
|
||||
|
||||
main "$@"
|
||||
|
||||
Reference in New Issue
Block a user