#!/usr/bin/env bash # Analyze Besu Logs for Deployment Errors # Searches for transaction-related errors and deployment issues set -euo pipefail RPC_IP="${1:-192.168.11.250}" SSH_PASSWORD="${2:-***REDACTED-LEGACY-PW***}" LOG_LINES="${3:-1000}" echo "╔══════════════════════════════════════════════════════════════╗" echo "║ ANALYZING BESU LOGS FOR DEPLOYMENT ERRORS ║" echo "╚══════════════════════════════════════════════════════════════╝" echo "" echo "RPC IP: $RPC_IP" echo "Analyzing last $LOG_LINES lines of logs" echo "" # Check if sshpass is available if ! command -v sshpass >/dev/null 2>&1; then echo "⚠️ sshpass not installed. Installing..." sudo apt-get update -qq && sudo apt-get install -y sshpass 2>/dev/null || { echo "❌ Cannot install sshpass automatically" echo "Please install manually: sudo apt-get install sshpass" exit 1 } fi # Get full logs echo "Retrieving Besu logs..." FULL_LOGS=$(sshpass -p "$SSH_PASSWORD" ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 \ root@"$RPC_IP" \ "journalctl -u besu-rpc -n $LOG_LINES --no-pager 2>/dev/null" 2>&1) if [ -z "$FULL_LOGS" ] || echo "$FULL_LOGS" | grep -q "Permission denied\|Connection refused"; then echo "❌ Failed to retrieve logs" exit 1 fi echo "✅ Retrieved logs" echo "" # Search for transaction-related errors echo "═══════════════════════════════════════════════════════════════" echo "1. TRANSACTION-RELATED ERRORS" echo "═══════════════════════════════════════════════════════════════" echo "" TX_ERRORS=$(echo "$FULL_LOGS" | grep -iE "transaction|tx|reject|invalid|revert|error|fail" | grep -v "PersistBlock" || echo "") if [ -n "$TX_ERRORS" ]; then echo "$TX_ERRORS" | tail -50 else echo " ℹ️ No transaction errors found in recent logs" fi echo "" # Search for deployment/contract creation errors echo "═══════════════════════════════════════════════════════════════" echo "2. CONTRACT CREATION / DEPLOYMENT ERRORS" echo "═══════════════════════════════════════════════════════════════" echo "" DEPLOY_ERRORS=$(echo "$FULL_LOGS" | grep -iE "deploy|create|contract|bytecode|code|init" | grep -iE "error|fail|reject|invalid" || echo "") if [ -n "$DEPLOY_ERRORS" ]; then echo "$DEPLOY_ERRORS" | tail -50 else echo " ℹ️ No deployment errors found in recent logs" fi echo "" # Search for gas-related errors echo "═══════════════════════════════════════════════════════════════" echo "3. GAS-RELATED ERRORS" echo "═══════════════════════════════════════════════════════════════" echo "" GAS_ERRORS=$(echo "$FULL_LOGS" | grep -iE "gas|limit|exceed|out of gas" | grep -iE "error|fail|reject" || echo "") if [ -n "$GAS_ERRORS" ]; then echo "$GAS_ERRORS" | tail -50 else echo " ℹ️ No gas-related errors found in recent logs" fi echo "" # Search for permission-related errors echo "═══════════════════════════════════════════════════════════════" echo "4. PERMISSION-RELATED ERRORS" echo "═══════════════════════════════════════════════════════════════" echo "" PERM_ERRORS=$(echo "$FULL_LOGS" | grep -iE "permission|allowlist|whitelist|denied|forbidden" || echo "") if [ -n "$PERM_ERRORS" ]; then echo "$PERM_ERRORS" | tail -50 else echo " ℹ️ No permission errors found in recent logs" fi echo "" # Search for specific transaction hashes from failed deployments echo "═══════════════════════════════════════════════════════════════" echo "5. FAILED DEPLOYMENT TRANSACTIONS" echo "═══════════════════════════════════════════════════════════════" echo "" FAILED_TXS=( "0x4dc9f5eedf580c2b37457916b04048481aba19cf3c1a106ea1ee9eefa0dc03c8" "0xc6502cdc4cb2f583fc6b3ddeb8b67b81877cff7a3c824634874a844651609a51" "0x808eab4238297ea68930cd5bf33b887937be0d8e533b638c33d8d1bd0de48018" "0xf43b359ea1f99c3c38651796647903bc5f9c2b5ffb7948062b9be924da97b828" ) for tx in "${FAILED_TXS[@]}"; do TX_SHORT="${tx:0:20}..." TX_LOG=$(echo "$FULL_LOGS" | grep -i "$tx" || echo "") if [ -n "$TX_LOG" ]; then echo " Found transaction: $TX_SHORT" echo "$TX_LOG" | head -5 echo "" fi done if [ -z "$TX_LOG" ]; then echo " ℹ️ No logs found for known failed transactions" echo " (Transactions may have been processed but not logged)" fi echo "" # Search for WARN and ERROR level messages echo "═══════════════════════════════════════════════════════════════" echo "6. WARN AND ERROR LEVEL MESSAGES" echo "═══════════════════════════════════════════════════════════════" echo "" WARN_ERROR=$(echo "$FULL_LOGS" | grep -iE "WARN|ERROR" | grep -v "PersistBlock" || echo "") if [ -n "$WARN_ERROR" ]; then echo "$WARN_ERROR" | tail -50 else echo " ℹ️ No WARN or ERROR messages found in recent logs" fi echo "" # Summary echo "═══════════════════════════════════════════════════════════════" echo "SUMMARY" echo "═══════════════════════════════════════════════════════════════" echo "" TX_ERROR_COUNT=$(echo "$TX_ERRORS" | wc -l) DEPLOY_ERROR_COUNT=$(echo "$DEPLOY_ERRORS" | wc -l) GAS_ERROR_COUNT=$(echo "$GAS_ERRORS" | wc -l) PERM_ERROR_COUNT=$(echo "$PERM_ERRORS" | wc -l) WARN_ERROR_COUNT=$(echo "$WARN_ERROR" | wc -l) echo "Transaction errors: $TX_ERROR_COUNT" echo "Deployment errors: $DEPLOY_ERROR_COUNT" echo "Gas errors: $GAS_ERROR_COUNT" echo "Permission errors: $PERM_ERROR_COUNT" echo "WARN/ERROR messages: $WARN_ERROR_COUNT" echo "" if [ "$TX_ERROR_COUNT" -eq 0 ] && [ "$DEPLOY_ERROR_COUNT" -eq 0 ] && [ "$GAS_ERROR_COUNT" -eq 0 ] && [ "$PERM_ERROR_COUNT" -eq 0 ]; then echo "⚠️ No errors found in logs, but deployments are still failing." echo " This suggests the issue may be:" echo " 1. Network-level restriction (not logged)" echo " 2. Validator-level restriction" echo " 3. Transaction pool rejection (before processing)" echo " 4. RPC node configuration issue" echo "" echo " Next steps:" echo " - Check transaction pool status" echo " - Verify network configuration" echo " - Check validator logs" fi echo ""