AnalisiServer
Generare un file server.csv:
hostname,ip postgreslab01,192.168.1.220
Verrà usato l'ip per la connessione e il nome per il file di output nella sotto directory: output
Creare un file con lo script del collegamento ai server mediante certificati e rileva le informazioni:
vi check_server_info.sh
#!/bin/bash
SERVER_LIST="server.csv" SSH_USER="root" SSH_KEY="$HOME/.ssh/id_rsa" # Cambia se usi una chiave diversa OUTPUT_DIR="output" mkdir -p "$OUTPUT_DIR"
while IFS=',' read -r name ip; do # Salta intestazione o righe vuote | -z "$ip" && continue
# Pulisci spazi bianchi name=$(echo "$name" | xargs) ip=$(echo "$ip" | xargs)
echo "Controllo connessione a $name ($ip)..."
# Test connessione SSH con timeout breve ssh -i "$SSH_KEY" -o BatchMode=yes -o ConnectTimeout=5 -o StrictHostKeyChecking=no "$SSH_USER@$ip" 'exit' 2>/dev/null
if [ $? -ne 0 ]; then echo "❌ Connessione fallita a $ip ($name), salto." continue fi
echo "✅ Connessione riuscita a $ip ($name). Raccolgo informazioni..."
OUTPUT_FILE="${OUTPUT_DIR}/${name}.txt" echo "=== Informazioni per $name ($ip) ===" > "$OUTPUT_FILE"
ssh -i "$SSH_KEY" -o StrictHostKeyChecking=no "$SSH_USER@$ip" bash << 'EOF' >> "$OUTPUT_FILE" echo -e "\n--- CPU Info ---" lscpu | grep 'Model name'
echo -e "\n--- RAM Totale ---" free -h | grep Mem
echo -e "\n--- SWAP ---" free -h | grep Swap
echo -e "\n--- Sistema Operativo ---" cat /etc/os-release | grep PRETTY_NAME
echo -e "\n--- Ultima Patch Installata ---" if command -v rpm &>/dev/null; then rpm -qa --last | head -n 1 elif command -v dpkg &>/dev/null; then ls -lt /var/lib/dpkg/info/ | head -n 1 else echo "Gestore pacchetti non riconosciuto" fi
echo -e "\n--- Ultimo Riavvio ---" who -b
echo -e "\n--- Elenco Dischi ---" lsblk
echo -e "\n--- Top 5 Processi per Uso CPU ---" ps -eo pid,comm,%cpu --sort=-%cpu | head -n 6
echo -e "\n--- Top 5 Processi per Uso RAM ---" ps -eo pid,comm,%mem --sort=-%mem | head -n 6 EOF
echo "📄 File ${OUTPUT_FILE} creato." done < "$SERVER_LIST"