mirror of
https://github.com/DeBrosOfficial/orama.git
synced 2026-03-17 09:36:56 +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
|
#!/bin/bash
|
||||||
# Extracts /tmp/network-source.tar.gz on a VPS and places the CLI binary.
|
# Extracts /tmp/network-source.tar.gz and places the CLI binary.
|
||||||
# Run as root on the target VPS.
|
|
||||||
#
|
#
|
||||||
# What it does:
|
# Local mode (run directly on VPS):
|
||||||
# 1. Extracts source to /opt/orama/src/
|
# sudo bash /opt/orama/src/scripts/extract-deploy.sh
|
||||||
# 2. Installs CLI to /usr/local/bin/orama
|
|
||||||
# All other binaries are built from source during `orama install`.
|
|
||||||
#
|
#
|
||||||
# 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
|
set -e
|
||||||
|
|
||||||
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||||
ARCHIVE="/tmp/network-source.tar.gz"
|
ARCHIVE="/tmp/network-source.tar.gz"
|
||||||
SRC_DIR="/opt/orama/src"
|
SRC_DIR="/opt/orama/src"
|
||||||
BIN_DIR="/opt/orama/bin"
|
BIN_DIR="/opt/orama/bin"
|
||||||
|
CONF="$SCRIPT_DIR/remote-nodes.conf"
|
||||||
|
|
||||||
if [ ! -f "$ARCHIVE" ]; then
|
# --- Local mode (no args) ---
|
||||||
|
if [ $# -eq 0 ]; then
|
||||||
|
if [ ! -f "$ARCHIVE" ]; then
|
||||||
echo "Error: $ARCHIVE not found"
|
echo "Error: $ARCHIVE not found"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Extracting source..."
|
echo "Extracting source..."
|
||||||
rm -rf "$SRC_DIR"
|
rm -rf "$SRC_DIR"
|
||||||
mkdir -p "$SRC_DIR" "$BIN_DIR"
|
mkdir -p "$SRC_DIR" "$BIN_DIR"
|
||||||
tar xzf "$ARCHIVE" -C "$SRC_DIR"
|
tar xzf "$ARCHIVE" -C "$SRC_DIR"
|
||||||
|
|
||||||
# Install CLI binary
|
# Install CLI binary
|
||||||
if [ -f "$SRC_DIR/bin-linux/orama" ]; then
|
if [ -f "$SRC_DIR/bin-linux/orama" ]; then
|
||||||
cp "$SRC_DIR/bin-linux/orama" /usr/local/bin/orama
|
cp "$SRC_DIR/bin-linux/orama" /usr/local/bin/orama
|
||||||
chmod +x /usr/local/bin/orama
|
chmod +x /usr/local/bin/orama
|
||||||
echo " ✓ CLI installed: /usr/local/bin/orama"
|
echo " ✓ CLI installed: /usr/local/bin/orama"
|
||||||
else
|
else
|
||||||
echo " ⚠️ CLI binary not found in archive (bin-linux/orama)"
|
echo " ⚠️ CLI binary not found in archive (bin-linux/orama)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Done. Ready for: sudo orama install --vps-ip <ip> ..."
|
||||||
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Done. Ready for: sudo orama install --vps-ip <ip> ..."
|
# --- Remote mode ---
|
||||||
|
|
||||||
|
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
|
||||||
|
}
|
||||||
|
|
||||||
|
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)\"'"
|
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
|
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 \
|
-o PreferredAuthentications=password -o PubkeyAuthentication=no \
|
||||||
"$user@$host" "$extract_cmd"
|
"$user@$host" "$extract_cmd"
|
||||||
else
|
else
|
||||||
ssh -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
ssh -n -o StrictHostKeyChecking=no -o ConnectTimeout=10 \
|
||||||
"$user@$host" "$extract_cmd"
|
"$user@$host" "$extract_cmd"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user