Files
azerothcore_installer/script/6_server-start.sh
2026-01-10 19:39:22 +01:00

83 lines
2.9 KiB
Bash
Executable File

#!/bin/bash
##########################################################################################
# Toggle debug mode: ./script.sh debug
##########################################################################################
DEBUG_MODE=0
if [[ "$1" == "debug" ]]; then
DEBUG_MODE=1
fi
##########################################################################################
# Paths for logs and crash dumps
##########################################################################################
export LOGS_PATH="/tmp/ac/logs"
export CRASHES_PATH="/tmp/ac/crashes"
# Ensure directories exist
mkdir -p "$LOGS_PATH" "$CRASHES_PATH"
##########################################################################################
# Sessions
##########################################################################################
AUTHSERVER_SESSION="authserver"
WORLDSERVER_SESSION="worldserver"
# Path to binaries
AUTH_EXE="${SERVER_ROOT}/env/dist/bin/authserver"
WORLD_EXE="${SERVER_ROOT}/env/dist/bin/worldserver"
# Helper to start a tmux session
start_tmux_session() {
local session_name=$1
local command=$2
local log_file=$3
if tmux has-session -t "$session_name" 2>/dev/null; then
echo "Tmux session '$session_name' already exists."
else
if tmux new-session -d -s "$session_name"; then
echo "Created tmux session: $session_name"
else
echo "Error creating tmux session: $session_name"
return 1
fi
fi
# Run the command inside tmux
tmux send-keys -t "$session_name" "export LOGS_PATH=$LOGS_PATH; export CRASHES_PATH=$CRASHES_PATH" C-m
tmux send-keys -t "$session_name" "$command | tee -a $log_file" C-m
echo "Running '$command' inside $session_name, logging to $log_file"
echo
}
##########################################################################################
# Start servers
##########################################################################################
# Authserver always normal
start_tmux_session "$AUTHSERVER_SESSION" "$AUTH_EXE" "$LOGS_PATH/authserver.log"
# Worldserver normal or debug
if [[ $DEBUG_MODE -eq 1 ]]; then
TIMESTAMP=$(date +%Y%m%d_%H%M%S)
GDB_LOG="$CRASHES_PATH/worldserver_gdb_$TIMESTAMP.log"
WORLD_COMMAND="gdb -ex \"set logging file $GDB_LOG\" \
-ex \"set logging enabled on\" \
-ex \"run\" \
-ex \"bt full\" \
-ex \"quit\" \
--args $WORLD_EXE"
echo "DEBUG MODE: Running worldserver under GDB"
else
WORLD_COMMAND="$WORLD_EXE"
fi
start_tmux_session "$WORLDSERVER_SESSION" "$WORLD_COMMAND" "$LOGS_PATH/worldserver.log"
##########################################################################################
# Launch interactive menu if needed
##########################################################################################
source "${ROOT_DIR}/script/menu.sh"