bin/ 230 CLI tools (ask-*, br-*, agent-*, roadid, carpool) scripts/ 99 automation scripts fleet/ Node configs and deployment workers/ Cloudflare Worker sources (roadpay, road-search, squad webhooks) roadc/ RoadC programming language roadnet/ Mesh network (5 APs, WireGuard) operator/ Memory system scripts config/ System configs dotfiles/ Shell configs docs/ Documentation BlackRoad OS — Pave Tomorrow. RoadChain-SHA2048: d1a24f55318d338b RoadChain-Identity: alexa@sovereign RoadChain-Full: d1a24f55318d338b24b60bad7be39286379c76ae5470817482100cb0ddbbcb97e147d07ac7243da0a9f0363e4e5c833d612b9c0df3a3cd20802465420278ef74875a5b77f55af6fe42a931b8b635b3d0d0b6bde9abf33dc42eea52bc03c951406d8cbe49f1a3d29b26a94dade05e9477f34a7d4d4c6ec4005c3c2ac54e73a68440c512c8e83fd9b1fe234750b898ef8f4032c23db173961fe225e67a0432b5293a9714f76c5c57ed5fdf35b9fb40fd73c03ebf88b7253c6a0575f5afb6a6b49b3bda310602fb1ef676859962dad2aebbb2875814b30eee0a8ba195e482d4cbc91d8819e7f38f6db53e8063401649c77bb994371473cabfb917fb53e8cbe73d60
47 lines
1.7 KiB
Bash
47 lines
1.7 KiB
Bash
#!/bin/bash
|
|
# BlackRoad Power Monitor — runs via cron on each Pi
|
|
# Logs thermal/voltage events and alerts via stats-push
|
|
# Usage: */5 * * * * /opt/blackroad/power-monitor.sh
|
|
|
|
LOGFILE="/var/log/blackroad-power.log"
|
|
HOSTNAME=$(hostname)
|
|
TEMP=$(($(cat /sys/class/thermal/thermal_zone0/temp 2>/dev/null || echo 0) / 1000))
|
|
FREQ=$(($(cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq 2>/dev/null || echo 0) / 1000))
|
|
GOV=$(cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor 2>/dev/null || echo "?")
|
|
|
|
# Voltage check (Pi 5 only)
|
|
VOLTS="n/a"
|
|
THROTTLE="0x0"
|
|
if command -v vcgencmd &>/dev/null; then
|
|
VOLTS=$(vcgencmd measure_volts core 2>/dev/null | cut -d= -f2 || echo "n/a")
|
|
THROTTLE=$(vcgencmd get_throttled 2>/dev/null | cut -d= -f2 || echo "n/a")
|
|
fi
|
|
|
|
# SD card health
|
|
IOWAIT=$(iostat -c 1 1 2>/dev/null | awk 'NR==4{print $4}' || echo "0")
|
|
|
|
TIMESTAMP=$(date '+%Y-%m-%d %H:%M:%S')
|
|
LINE="${TIMESTAMP} | ${HOSTNAME} | ${TEMP}°C | ${FREQ}MHz | ${GOV} | ${VOLTS} | thr:${THROTTLE} | iow:${IOWAIT}%"
|
|
|
|
echo "$LINE" >> "$LOGFILE"
|
|
|
|
# Alert thresholds
|
|
ALERT=""
|
|
[[ "$TEMP" -gt 70 ]] && ALERT+="TEMP_HIGH:${TEMP}C "
|
|
[[ "$THROTTLE" != "0x0" && "$THROTTLE" != "n/a" ]] && ALERT+="THROTTLED:${THROTTLE} "
|
|
|
|
# Check if voltage is below 0.82V (danger zone)
|
|
if [[ "$VOLTS" != "n/a" ]]; then
|
|
V_INT=$(echo "$VOLTS" | tr -d 'V' | awk '{printf "%d", $1*10000}')
|
|
[[ "$V_INT" -lt 8200 ]] && ALERT+="LOW_VOLTAGE:${VOLTS} "
|
|
fi
|
|
|
|
if [[ -n "$ALERT" ]]; then
|
|
echo "${TIMESTAMP} ALERT: ${ALERT}" >> "$LOGFILE"
|
|
# Could push to stats endpoint here
|
|
fi
|
|
|
|
# Rotate log at 1MB
|
|
LOGSIZE=$(stat -c %s "$LOGFILE" 2>/dev/null || stat -f %z "$LOGFILE" 2>/dev/null || echo 0)
|
|
[[ "$LOGSIZE" -gt 1048576 ]] && tail -500 "$LOGFILE" > "$LOGFILE.tmp" && mv "$LOGFILE.tmp" "$LOGFILE"
|