mirror of
https://github.com/DeBrosOfficial/orama.git
synced 2026-03-17 03:33:01 +00:00
feat: enhance deployment scripts with improved error handling and add rolling upgrade functionality
This commit is contained in:
parent
a71b979036
commit
2b0bfaaa12
@ -1,37 +1,98 @@
|
||||
#!/bin/bash
|
||||
# Extracts /tmp/network-source.tar.gz on a VPS and places the CLI binary.
|
||||
# Run as root on the target VPS.
|
||||
# Extracts /tmp/network-source.tar.gz and places the CLI binary.
|
||||
#
|
||||
# What it does:
|
||||
# 1. Extracts source to /opt/orama/src/
|
||||
# 2. Installs CLI to /usr/local/bin/orama
|
||||
# All other binaries are built from source during `orama install`.
|
||||
# Local mode (run directly on VPS):
|
||||
# sudo bash /opt/orama/src/scripts/extract-deploy.sh
|
||||
#
|
||||
# Usage: sudo bash /opt/orama/src/scripts/extract-deploy.sh
|
||||
# Remote mode (run from dev machine):
|
||||
# ./scripts/extract-deploy.sh --env testnet
|
||||
# ./scripts/extract-deploy.sh <vps-ip> [<vps-ip2> ...]
|
||||
|
||||
set -e
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
ARCHIVE="/tmp/network-source.tar.gz"
|
||||
SRC_DIR="/opt/orama/src"
|
||||
BIN_DIR="/opt/orama/bin"
|
||||
CONF="$SCRIPT_DIR/remote-nodes.conf"
|
||||
|
||||
if [ ! -f "$ARCHIVE" ]; then
|
||||
echo "Error: $ARCHIVE not found"
|
||||
exit 1
|
||||
# --- Local mode (no args) ---
|
||||
if [ $# -eq 0 ]; then
|
||||
if [ ! -f "$ARCHIVE" ]; then
|
||||
echo "Error: $ARCHIVE not found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "Extracting source..."
|
||||
rm -rf "$SRC_DIR"
|
||||
mkdir -p "$SRC_DIR" "$BIN_DIR"
|
||||
tar xzf "$ARCHIVE" -C "$SRC_DIR"
|
||||
|
||||
# Install CLI binary
|
||||
if [ -f "$SRC_DIR/bin-linux/orama" ]; then
|
||||
cp "$SRC_DIR/bin-linux/orama" /usr/local/bin/orama
|
||||
chmod +x /usr/local/bin/orama
|
||||
echo " ✓ CLI installed: /usr/local/bin/orama"
|
||||
else
|
||||
echo " ⚠️ CLI binary not found in archive (bin-linux/orama)"
|
||||
fi
|
||||
|
||||
echo "Done. Ready for: sudo orama install --vps-ip <ip> ..."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
echo "Extracting source..."
|
||||
rm -rf "$SRC_DIR"
|
||||
mkdir -p "$SRC_DIR" "$BIN_DIR"
|
||||
tar xzf "$ARCHIVE" -C "$SRC_DIR"
|
||||
# --- Remote mode ---
|
||||
|
||||
# Install CLI binary
|
||||
if [ -f "$SRC_DIR/bin-linux/orama" ]; then
|
||||
cp "$SRC_DIR/bin-linux/orama" /usr/local/bin/orama
|
||||
chmod +x /usr/local/bin/orama
|
||||
echo " ✓ CLI installed: /usr/local/bin/orama"
|
||||
else
|
||||
echo " ⚠️ CLI binary not found in archive (bin-linux/orama)"
|
||||
fi
|
||||
resolve_nodes() {
|
||||
if [ "$1" = "--env" ] && [ -n "$2" ] && [ -f "$CONF" ]; then
|
||||
grep "^$2|" "$CONF" | while IFS='|' read -r env userhost pass role; do
|
||||
local user="${userhost%%@*}"
|
||||
local host="${userhost##*@}"
|
||||
echo "$user|$host|$pass"
|
||||
done
|
||||
return
|
||||
fi
|
||||
|
||||
echo "Done. Ready for: sudo orama install --vps-ip <ip> ..."
|
||||
for ip in "$@"; do
|
||||
if [ -f "$CONF" ]; then
|
||||
local match
|
||||
match=$(grep "|[^|]*@${ip}|" "$CONF" | head -1)
|
||||
if [ -n "$match" ]; then
|
||||
local userhost pass
|
||||
userhost=$(echo "$match" | cut -d'|' -f2)
|
||||
pass=$(echo "$match" | cut -d'|' -f3)
|
||||
local user="${userhost%%@*}"
|
||||
echo "$user|$ip|$pass"
|
||||
continue
|
||||
fi
|
||||
fi
|
||||
echo "ubuntu|$ip|"
|
||||
done
|
||||
}
|
||||
|
||||
extract_on_node() {
|
||||
local user="$1" host="$2" pass="$3"
|
||||
|
||||
echo "→ Extracting on $user@$host..."
|
||||
|
||||
local sudo_prefix=""
|
||||
[ "$user" != "root" ] && sudo_prefix="sudo "
|
||||
|
||||
local extract_cmd="${sudo_prefix}bash -c 'rm -rf /opt/orama/src && mkdir -p /opt/orama/src /opt/orama/bin && tar xzf /tmp/network-source.tar.gz -C /opt/orama/src 2>/dev/null && if [ -f /opt/orama/src/bin-linux/orama ]; then cp /opt/orama/src/bin-linux/orama /usr/local/bin/orama && chmod +x /usr/local/bin/orama; fi && echo \" ✓ Extracted (\$(ls /opt/orama/src/ | wc -l) files)\"'"
|
||||
|
||||
if [ -n "$pass" ]; then
|
||||
sshpass -p "$pass" ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
-o PreferredAuthentications=password -o PubkeyAuthentication=no \
|
||||
"$user@$host" "$extract_cmd"
|
||||
else
|
||||
ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
"$user@$host" "$extract_cmd"
|
||||
fi
|
||||
}
|
||||
|
||||
resolve_nodes "$@" | while IFS='|' read -r user host pass; do
|
||||
extract_on_node "$user" "$host" "$pass"
|
||||
echo ""
|
||||
done
|
||||
|
||||
echo "Done."
|
||||
|
||||
81
scripts/upgrade-nodes.sh
Executable file
81
scripts/upgrade-nodes.sh
Executable file
@ -0,0 +1,81 @@
|
||||
#!/bin/bash
|
||||
# Rolling upgrade of nodes: runs `orama node upgrade --restart` one node at a time.
|
||||
#
|
||||
# Usage:
|
||||
# ./scripts/upgrade-nodes.sh --env testnet
|
||||
# ./scripts/upgrade-nodes.sh --env devnet
|
||||
# ./scripts/upgrade-nodes.sh <vps-ip> [<vps-ip2> ...]
|
||||
|
||||
set -e
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
CONF="$SCRIPT_DIR/remote-nodes.conf"
|
||||
|
||||
resolve_nodes() {
|
||||
if [ "$1" = "--env" ] && [ -n "$2" ] && [ -f "$CONF" ]; then
|
||||
grep "^$2|" "$CONF" | while IFS='|' read -r env userhost pass role; do
|
||||
local user="${userhost%%@*}"
|
||||
local host="${userhost##*@}"
|
||||
echo "$user|$host|$pass"
|
||||
done
|
||||
return
|
||||
fi
|
||||
|
||||
for ip in "$@"; do
|
||||
if [ -f "$CONF" ]; then
|
||||
local match
|
||||
match=$(grep "|[^|]*@${ip}|" "$CONF" | head -1)
|
||||
if [ -n "$match" ]; then
|
||||
local userhost pass
|
||||
userhost=$(echo "$match" | cut -d'|' -f2)
|
||||
pass=$(echo "$match" | cut -d'|' -f3)
|
||||
local user="${userhost%%@*}"
|
||||
echo "$user|$ip|$pass"
|
||||
continue
|
||||
fi
|
||||
fi
|
||||
echo "ubuntu|$ip|"
|
||||
done
|
||||
}
|
||||
|
||||
upgrade_node() {
|
||||
local user="$1" host="$2" pass="$3"
|
||||
|
||||
echo "→ Upgrading $user@$host..."
|
||||
|
||||
local sudo_prefix=""
|
||||
[ "$user" != "root" ] && sudo_prefix="sudo "
|
||||
|
||||
local cmd="${sudo_prefix}orama node upgrade --restart"
|
||||
|
||||
if [ -n "$pass" ]; then
|
||||
sshpass -p "$pass" ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
-o PreferredAuthentications=password -o PubkeyAuthentication=no \
|
||||
"$user@$host" "$cmd"
|
||||
else
|
||||
ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
"$user@$host" "$cmd"
|
||||
fi
|
||||
}
|
||||
|
||||
if [ $# -eq 0 ]; then
|
||||
echo "Usage: $0 --env <testnet|devnet>"
|
||||
echo " $0 <vps-ip> [<vps-ip2> ...]"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Count nodes
|
||||
node_count=$(resolve_nodes "$@" | wc -l | tr -d ' ')
|
||||
echo "Rolling upgrade: $node_count nodes (serial)"
|
||||
echo ""
|
||||
|
||||
i=0
|
||||
resolve_nodes "$@" | while IFS='|' read -r user host pass; do
|
||||
i=$((i + 1))
|
||||
echo "[$i/$node_count] $user@$host"
|
||||
upgrade_node "$user" "$host" "$pass"
|
||||
echo " ✓ Done"
|
||||
echo ""
|
||||
done
|
||||
|
||||
echo "Rolling upgrade complete."
|
||||
@ -76,11 +76,11 @@ upload_to_node() {
|
||||
local extract_cmd="${sudo_prefix}bash -c 'rm -rf /opt/orama/src && mkdir -p /opt/orama/src /opt/orama/bin && tar xzf /tmp/network-source.tar.gz -C /opt/orama/src 2>/dev/null && if [ -f /opt/orama/src/bin-linux/orama ]; then cp /opt/orama/src/bin-linux/orama /usr/local/bin/orama && chmod +x /usr/local/bin/orama; fi && echo \" ✓ Extracted (\$(ls /opt/orama/src/ | wc -l) files)\"'"
|
||||
|
||||
if [ -n "$pass" ]; then
|
||||
sshpass -p "$pass" ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
sshpass -p "$pass" ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
-o PreferredAuthentications=password -o PubkeyAuthentication=no \
|
||||
"$user@$host" "$extract_cmd"
|
||||
else
|
||||
ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||
"$user@$host" "$extract_cmd"
|
||||
fi
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user