Long builds (NVIDIA driver download+compile) would abort on SSH timeout. Now build runs in a detached screen session on the VM, run-builder.sh streams the log and waits for completion safely. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
92 lines
2.5 KiB
Bash
Executable File
92 lines
2.5 KiB
Bash
Executable File
#!/bin/sh
|
|
# run-builder.sh — trigger debug ISO build on remote Alpine builder VM
|
|
#
|
|
# Usage:
|
|
# sh scripts/run-builder.sh
|
|
# sh scripts/run-builder.sh --authorized-keys /path/to/authorized_keys
|
|
|
|
set -e
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
|
REPO_ROOT="$(cd "${SCRIPT_DIR}/.." && pwd)"
|
|
|
|
# load .env
|
|
ENV_FILE="${REPO_ROOT}/.env"
|
|
if [ -f "$ENV_FILE" ]; then
|
|
# shellcheck disable=SC1090
|
|
. "$ENV_FILE"
|
|
fi
|
|
|
|
BUILDER_HOST="${BUILDER_HOST:-}"
|
|
if [ -z "$BUILDER_HOST" ]; then
|
|
echo "ERROR: BUILDER_HOST not set. Copy .env.example to .env and set the address."
|
|
exit 1
|
|
fi
|
|
|
|
EXTRA_ARGS=""
|
|
while [ $# -gt 0 ]; do
|
|
case "$1" in
|
|
--authorized-keys) EXTRA_ARGS="--authorized-keys $2"; shift 2 ;;
|
|
*) echo "unknown arg: $1"; exit 1 ;;
|
|
esac
|
|
done
|
|
|
|
echo "=== bee builder ==="
|
|
echo "Builder: ${BUILDER_HOST}"
|
|
echo ""
|
|
|
|
ssh -o StrictHostKeyChecking=no root@"${BUILDER_HOST}" /bin/sh <<ENDSSH
|
|
set -e
|
|
REPO=/root/bee
|
|
LOG=/var/log/bee-build.log
|
|
|
|
if [ ! -d "\$REPO/.git" ]; then
|
|
echo "--- cloning bee repo ---"
|
|
git clone https://git.mchus.pro/reanimator/bee.git "\$REPO"
|
|
fi
|
|
|
|
cd "\$REPO"
|
|
echo "--- pulling latest ---"
|
|
git pull --ff-only
|
|
|
|
# Kill any previous build session
|
|
screen -S bee-build -X quit 2>/dev/null || true
|
|
|
|
echo "--- starting build in screen session (survives SSH disconnect) ---"
|
|
echo "--- log: \$LOG ---"
|
|
screen -dmS bee-build sh -c "sh iso/builder/build-debug.sh ${EXTRA_ARGS} > \$LOG 2>&1; echo \$? > /tmp/bee-build-exit"
|
|
|
|
# Stream log until build finishes
|
|
echo "--- streaming build log (Ctrl+C safe — build continues on VM) ---"
|
|
while screen -list | grep -q bee-build; do
|
|
tail -n +1 -f "\$LOG" 2>/dev/null & TAIL_PID=\$!
|
|
sleep 1
|
|
while screen -list | grep -q bee-build; do sleep 2; done
|
|
kill \$TAIL_PID 2>/dev/null || true
|
|
break
|
|
done
|
|
tail -n 20 "\$LOG" 2>/dev/null || true
|
|
|
|
EXIT_CODE=\$(cat /tmp/bee-build-exit 2>/dev/null || echo 1)
|
|
exit \$EXIT_CODE
|
|
ENDSSH
|
|
|
|
echo ""
|
|
echo "=== downloading ISO ==="
|
|
LOCAL_ISO_DIR="${REPO_ROOT}/iso/out"
|
|
mkdir -p "${LOCAL_ISO_DIR}"
|
|
if command -v rsync >/dev/null 2>&1 && ssh -o StrictHostKeyChecking=no root@"${BUILDER_HOST}" command -v rsync >/dev/null 2>&1; then
|
|
rsync -az --progress \
|
|
-e "ssh -o StrictHostKeyChecking=no" \
|
|
"root@${BUILDER_HOST}:/root/bee/dist/*.iso" \
|
|
"${LOCAL_ISO_DIR}/"
|
|
else
|
|
scp -o StrictHostKeyChecking=no \
|
|
"root@${BUILDER_HOST}:/root/bee/dist/*.iso" \
|
|
"${LOCAL_ISO_DIR}/"
|
|
fi
|
|
echo ""
|
|
echo "=== build complete ==="
|
|
echo "ISO saved to: ${LOCAL_ISO_DIR}/"
|
|
ls -lh "${LOCAL_ISO_DIR}/"*.iso 2>/dev/null || true
|