Linux 服务器较为强大的运维及管理脚本实现(支援:本机线上操作)

功能:

Copyright (C) 2019 ~ 2023 Sichuan Jiaile Network Information Technology Co., LTD. All rights reserved.

STG SCRIPT.(X) 1.0.0 VERSION

Usage:

./linux.sh make 编译

./linux.sh make ld 编译(LD)

./linux.sh make re 编译(RE)

./linux.sh git p Git : 拉取

./linux.sh git r Git : 变基

./linux.sh git ... Git : 命令

./linux.sh io cp [source]... [destination]... IO : 复制

./linux.sh io rm [source]... [destination]... IO : 删除

./linux.sh io mv [source]... [destination]... IO : 移动(文件)

./linux.sh io md [source]... [destination]... IO : 移动(目录)

./linux.sh io ll IO : 列表

./linux.sh sys OS

./linux.sh cmd CMD

./linux.sh remote [user] [password] [host] [port] ... RPC

./linux.sh redis save [dump] ... Redis : 备份

./linux.sh mysql save [dump] ... MySQL : 备份

./linux.sh mysql save-all [dump] ... MySQL : 备份(全部)

./linux.sh server list 服务器 : 列出(全部)

./linux.sh server start [debug|release] 服务器 : 开服

./linux.sh server start-all [debug|release] 服务器 : 开服(全部)

./linux.sh server start-dev [debug|release] 服务器 : 开服(开发)

./linux.sh server stop 服务器 : 关闭

./linux.sh server stop-all 服务器 : 关闭(全部)

./linux.sh server pack [dump] 服务器 : 打包

./linux.sh server pack-bin [dump] 服务器 : 打包(程式)

./linux.sh server pack-res [dump] 服务器 : 打包(资源)

./linux.sh server publish [user] [password] [host] [port] 服务器 : 发布

./linux.sh server publish-clear 服务器 : 发布(清理)

./linux.sh help 帮助

bash 复制代码
#! /bin/bash

# Copyright  : Copyright (C) 2019 ~ 2023 Sichuan Jiaile Network Information Technology Co., LTD. All rights reserved.
# Description: STG SCRIPT.(X) 1.0.0 VERSION.
# Author     : Kyou.
# Date-Time  : 2023/12/13

STG_SCRIPT_NAME=$(basename "$0")
STG_BUILD_OPERATE_TYPE=$1
STG_BUILD_VERSION_TYPE=$2
STG_BUILD_C_TRHEAD_NUM=$3

RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
SKYBLUE='\033[0;36m'
PLAIN='\033[0m'

# 编译线程数量,默认为12线程
if [ -z "$STG_BUILD_C_TRHEAD_NUM" ]; then
    STG_BUILD_C_TRHEAD_NUM=12
fi

# 编译版本类型,默认为调试版
if [[ "${STG_BUILD_VERSION_TYPE,,}" == "release" ]]; then
    STG_BUILD_VERSION_TYPE="release"
else
    STG_BUILD_VERSION_TYPE="debug"
fi

# 编译操作类型到小写字符串
STG_BUILD_OPERATE_TYPE=${STG_BUILD_OPERATE_TYPE,,}

# 编译工程解决方案(rebuild, tips) 
STG_build_executable() {
    local DONE_TIP_STRING='编译完成'
    local BEFO_TIP_STRING='正在编译'
    echo $BEFO_TIP_STRING

    # 清理服务器之前生成的程序
    local OPERATE_TYPE=$1
    OPERATE_TYPE=${OPERATE_TYPE,,}
    
    local REBUILD_OPERATE=false
    if [[ $OPERATE_TYPE == "ld" ]]; then
        local STG_BIN_EXE_DIR="Debug"
        if [[ $STG_BUILD_VERSION_TYPE == "release" ]]; then
            $STG_BIN_EXE_DIR="Release"
        fi

        rm -rf server/bin/$STG_BIN_EXE_DIR/GameServer
        rm -rf server/bin/$STG_BIN_EXE_DIR/GMServer
        rm -rf server/bin/$STG_BIN_EXE_DIR/LoginServer
        rm -rf server/bin/$STG_BIN_EXE_DIR/LoginServer
        rm -rf server/bin/$STG_BIN_EXE_DIR/Robot
        rm -rf server/bin/$STG_BIN_EXE_DIR/TestClient
    elif [[ $OPERATE_TYPE == "re" ]]; then
        REBUILD_OPERATE=true
    fi

    # 编译服务器引擎静态链接库
    cd code/ServerEngine/
    if $REBUILD_OPERATE; then
        rm -rf build/
    fi

    premake5 gmake
    cd build/
    make -j$STG_BUILD_C_TRHEAD_NUM config=$STG_BUILD_VERSION_TYPE

    # 编译全部的服务器程序代码
    cd ../../Server/
    if $REBUILD_OPERATE; then
        rm -rf build/
    fi

    premake5 gmake
    cd build/
    make -j$STG_BUILD_C_TRHEAD_NUM config=$STG_BUILD_VERSION_TYPE

    # 输出当前编译结束提示文本
    echo $DONE_TIP_STRING
}

# 变基解决方案代码
STG_rebase_code_sources() {
    echo '正在变基'

    # 主模块
    echo '源码...'
    git checkout .
    git clean -f -d
    git fetch
    git pull --rebase
    echo

    # 子模块
    echo '资源...'
    git checkout .
    git clean -f -d
    git fetch
    git pull --rebase

    echo '变基完成'
}

# 拉取解决方案代码
STG_pull_code_sources() {
    echo '正在拉取'

    # 主模块
    echo '源码...'
    git fetch
    git stash
    git pull
    git stash pop
    echo

    # 子模块
    echo '资源...'
    cd server/
    git fetch
    git stash
    git pull
    git stash pop

    echo '拉取完成'
}

# 显示脚本帮助信息
STG_help() {
    echo "Copyright (C) 2019 ~ 2023 Sichuan Jiaile Network Information Technology Co., LTD. All rights reserved."
    echo "STG SCRIPT.(X) 1.0.0 VERSION"
    echo 
    echo "Usage:"
    echo "    ./$STG_SCRIPT_NAME make                                                   编译"
    echo "    ./$STG_SCRIPT_NAME make ld                                                编译(LD)"
    echo "    ./$STG_SCRIPT_NAME make re                                                编译(RE)"

    echo "    ./$STG_SCRIPT_NAME git p                                                  Git         : 拉取"
    echo "    ./$STG_SCRIPT_NAME git r                                                  Git         : 变基"
    echo "    ./$STG_SCRIPT_NAME git ...                                                Git         : 命令"

    echo "    ./$STG_SCRIPT_NAME io cp            [source]... [destination]...          IO          : 复制"
    echo "    ./$STG_SCRIPT_NAME io rm            [source]... [destination]...          IO          : 删除"
    echo "    ./$STG_SCRIPT_NAME io mv            [source]... [destination]...          IO          : 移动(文件)"
    echo "    ./$STG_SCRIPT_NAME io md            [source]... [destination]...          IO          : 移动(目录)"
    echo "    ./$STG_SCRIPT_NAME io ll                                                  IO          : 列表"

    echo "    ./$STG_SCRIPT_NAME sys                                                    OS"
    echo "    ./$STG_SCRIPT_NAME cmd                                                    CMD"
    echo "    ./$STG_SCRIPT_NAME remote           [user] [password] [host] [port] ...   RPC"

    echo "    ./$STG_SCRIPT_NAME redis save       [dump] ...                            Redis       : 备份"
    echo "    ./$STG_SCRIPT_NAME mysql save       [dump] ...                            MySQL       : 备份"
    echo "    ./$STG_SCRIPT_NAME mysql save-all   [dump] ...                            MySQL       : 备份(全部)"

    echo "    ./$STG_SCRIPT_NAME server list                                            服务器      : 列出(全部)"
    echo "    ./$STG_SCRIPT_NAME server start     [debug|release]                       服务器      : 开服"
    echo "    ./$STG_SCRIPT_NAME server start-all [debug|release]                       服务器      : 开服(全部)"
    echo "    ./$STG_SCRIPT_NAME server start-dev [debug|release]                       服务器      : 开服(开发)"
    echo "    ./$STG_SCRIPT_NAME server stop                                            服务器      : 关闭"
    echo "    ./$STG_SCRIPT_NAME server stop-all                                        服务器      : 关闭(全部)"
    echo "    ./$STG_SCRIPT_NAME server pack      [dump]                                服务器      : 打包"
    echo "    ./$STG_SCRIPT_NAME server pack-bin  [dump]                                服务器      : 打包(程式)"
    echo "    ./$STG_SCRIPT_NAME server pack-res  [dump]                                服务器      : 打包(资源)"
    echo "    ./$STG_SCRIPT_NAME server publish   [user] [password] [host] [port]       服务器      : 发布"
    echo "    ./$STG_SCRIPT_NAME server publish-clear                                   服务器      : 发布(清理)"

    echo "    ./$STG_SCRIPT_NAME help                                                   帮助"
}

# 列出全部的服务器
STG_list_all_servers() {
    ps aux | 
        grep -E "./(Game|Login|GM|Proxy)Server" | 
            awk 'BEGIN {print "进程ID\tCPU负载\tCPU时间\t内存负载\t运行时间\t线程数\t进程名称\t配置文件"; flag=0} {cmd="ps -T -p "$2" | wc -l"; cmd|getline tnum; close(cmd); printf "%-10s %-8s %-10s %-10s %-12s %-8s %-20s %-20s\n", $2, $3"%", $10"%", $4"%", $9, tnum-1, $11, $13; flag=1} END {if (flag==0) {printf "%50s\n", "服务器未就绪!"}}' | 
                column -t
}

# 虚拟机环境的检查
STG_virt_check(){
    if hash ifconfig 2>/dev/null; then
        eth=$(ifconfig)
    fi

    virtualx=$(dmesg) 2>/dev/null
    if  [ $(which dmidecode) ]; then
        sys_manu=$(dmidecode -s system-manufacturer) 2>/dev/null
        sys_product=$(dmidecode -s system-product-name) 2>/dev/null
        sys_ver=$(dmidecode -s system-version) 2>/dev/null
    else
        sys_manu=""
        sys_product=""
        sys_ver=""
    fi
    
    if grep docker /proc/1/cgroup -qa; then
        virtual="Docker"
    elif grep lxc /proc/1/cgroup -qa; then
        virtual="Lxc"
    elif grep -qa container=lxc /proc/1/environ; then
        virtual="Lxc"
    elif [[ -f /proc/user_beancounters ]]; then
        virtual="OpenVZ"
    elif [[ "$virtualx" == *kvm-clock* ]]; then
        virtual="KVM"
    elif [[ "$cname" == *KVM* ]]; then
        virtual="KVM"
    elif [[ "$cname" == *QEMU* ]]; then
        virtual="KVM"
    elif [[ "$virtualx" == *"VMware Virtual Platform"* ]]; then
        virtual="VMware"
    elif [[ "$virtualx" == *"Parallels Software International"* ]]; then
        virtual="Parallels"
    elif [[ "$virtualx" == *VirtualBox* ]]; then
        virtual="VirtualBox"
    elif [[ -e /proc/xen ]]; then
        virtual="Xen"
    elif [[ "$sys_manu" == *"Microsoft Corporation"* ]]; then
        if [[ "$sys_product" == *"Virtual Machine"* ]]; then
            if [[ "$sys_ver" == *"7.0"* || "$sys_ver" == *"Hyper-V" ]]; then
                virtual="Hyper-V"
            else
                virtual="Microsoft Virtual Machine"
            fi
        fi
    else
        virtual="Dedicated"
    fi
    
    echo $virtual
}

# 计算设备磁盘大小
STG_calc_disk_size() {
    local total_size=0
    local array=$@
    for size in ${array[@]}
    do
        [ "${size}" == "0" ] && size_t=0 || size_t=`echo ${size:0:${#size}-1}`
        [ "`echo ${size:(-1)}`" == "K" ] && size=0
        [ "`echo ${size:(-1)}`" == "M" ] && size=$(awk 'BEGIN{printf "%.1f", '$size_t' / 1024}')
        [ "`echo ${size:(-1)}`" == "T" ] && size=$(awk 'BEGIN{printf "%.1f", '$size_t' * 1024}')
        [ "`echo ${size:(-1)}`" == "G" ] && size=${size_t}
        total_size=$(awk 'BEGIN{printf "%.1f", '$total_size' + '$size'}')
    done
    echo ${total_size}
}

# 查看工作主机信息
STG_sys() {
    # 显示CPU型号、主频、物理核心数、逻辑核心数、CPU缓存大小
    cpu_model=$(grep "model name" /proc/cpuinfo | head -n1 | awk -F: '{print $2}' | xargs)
    cpu_freq=$(lscpu | grep "CPU MHz" | awk '{printf "%.3f MHz\n", $3}')
    phy_cores=$(lscpu | grep "Core(s) per socket" | awk '{print $4}')
    logic_cores=$(lscpu | grep "^CPU(s):" | awk '{print $2}')
    cpu_cache=$(lscpu | grep "L3 cache" | awk '{gsub(/K/," "); printf "%s KB\n", $NF}')
    cpu_arch=$(lscpu | grep "Architecture" | awk '{print $2}')

    # 显示内存总量和当前使用的内存(单位:MB)
    memory_total=$(free -m | awk '/^Mem:/ {print $2}')
    memory_used=$(free -m | awk '/^Mem:/ {print $3}')
    memory_bram=$(free -m | awk '/^Mem:/ {print $6}')

    # 显示总磁盘空间和已用磁盘空间(单位:GB)
    disk_size1=$(LANG=C df -hPl | grep -wvE '\-|none|tmpfs|overlay|shm|udev|devtmpfs|by-uuid|chroot|Filesystem' | awk '{print $2}')
    disk_size2=$(LANG=C df -hPl | grep -wvE '\-|none|tmpfs|overlay|shm|udev|devtmpfs|by-uuid|chroot|Filesystem' | awk '{print $3}')
    disk_total=$(STG_calc_disk_size ${disk_size1[@]})
    disk_used=$(STG_calc_disk_size ${disk_size2[@]})

    # 显示总交换区大小和当前使用的交换区(单位:MB)
    swap_total=$(free -m | awk '/^Swap:/ {print $2}')
    swap_used=$(free -m | awk '/^Swap:/ {print $3}')

    # 显示当前TCP控制协议
    tcp_congestion=$(sysctl net.ipv4.tcp_congestion_control | awk -F'=' '{print $2}' | xargs)

    # 显示当前系统信息和内核版本
    system_info=$(cat /etc/*-release | head -n1)
    kernel_version=$(uname -r)

    # 显示当前的uptime
    uptime_raw=$(cut -d " " -f1 /proc/uptime)
    uptime_days=$(echo "$uptime_raw/60/60/24" | bc)
    uptime_hours=$(echo "$uptime_raw/60/60%24" | bc) #$((uptime_raw/60/60%24))
    uptime_minutes=$(echo "$uptime_raw/60%24" | bc) #$((uptime_raw/60%60))
    uptime_formatted="${uptime_days} days ${uptime_hours} hours ${uptime_minutes} min"

    # 打印输出
    echo -e "CPU Model    : ${SKYBLUE}$cpu_model${PLAIN}"
    echo -e "CPU Cores    : ${YELLOW}$phy_cores Cores $logic_cores Threads ${SKYBLUE}$cpu_freq $cpu_arch${PLAIN}"
    echo -e "CPU Cache    : ${SKYBLUE}$cpu_cache${PLAIN}"
    echo -e "OS           : ${SKYBLUE}$system_info${PLAIN} $YELLOW$(STG_virt_check)$PLAIN"
    echo -e "OS Time      : ${SKYBLUE}$(date +"%Y-%m-%d %H:%M:%S %Z")${PLAIN}"
    echo -e "Kernel       : ${SKYBLUE}$kernel_version${PLAIN}"

    echo -e "Total Space  : ${SKYBLUE}${disk_used} GB / ${YELLOW}${disk_total} GB ${PLAIN}"
    echo -e "Total RAM    : ${SKYBLUE}${memory_used} MB / ${YELLOW}${memory_total} MB${PLAIN} ${SKYBLUE}(${memory_bram} MB Buff)${PLAIN}"
    echo -e "Total Swap   : ${SKYBLUE}${swap_used} MB / ${YELLOW}${swap_total} MB${PLAIN}"
    
    echo -e "Uptime       : ${SKYBLUE}$uptime_formatted${PLAIN}"
    echo -e "TCP CC       : ${YELLOW}$tcp_congestion${PLAIN}"
}

# 停止指定的服务器
STG_stop_server_by_pid_and_name() {
    local PID=$1
    local NAME=$2
    local CONF=$3
    if [[ -z $CONF ]]; then
        CONF="config is <none>"
    else
        CONF="config is $CONF"
    fi

    echo -n "KILL: [$PID] $NAME ${CONF} "
    kill -SIGUSR1 $PID
    while pgrep -x "$CLASS_TYPE" | grep $PID >/dev/null; do
        sleep 1
        echo -n "."
    done
    echo " [OK]"
}

# 停止所有的服务器(某一类)
STG_stop_all_servers_by_class() {
    local CLASS_TYPE=$1
    local PROC_LIST=$(ps aux | grep -E "./($CLASS_TYPE)" | grep -v grep)

    echo "$PROC_LIST" | while read LINE; do
        if [ -n "$LINE" ]; then
            local PID=$(echo "$LINE" | awk '{print $2}')
            local NAME=$(echo "$LINE" | awk '{print $11}')
            local CONF=$(echo "$LINE" | awk '{print $13}')
            STG_stop_server_by_pid_and_name $PID $NAME $CONF
        fi
    done
}

# 开启服务器(指定)
STG_start_server_by_exe_path() {
    local EXE_PATH=$2
    local CONF_PATH=$3
    if test -f $EXE_PATH; then
        if test -f $CONF_PATH; then
            local START_CMD="$EXE_PATH"
            if $1; then
                START_CMD="$START_CMD -daemon"
            fi

            # 输出正在启动进程信息
            echo -n "START: $EXE_PATH"

            # 输出当前配置文件名
            if [[ -z $CONF_PATH ]]; then
                echo -n " config is <none> "
            else
                START_CMD="$START_CMD $CONF_PATH"
                echo -n " config is $CONF_PATH "
            fi

            # 程序是否已经在运行
            if ps -ef | grep -v grep | grep "$START_CMD" > /dev/null; then
                echo -n " ... [RE]"
            else
                # 先延迟等待三秒之后
                $START_CMD > /dev/null 2>&1
                for ((i=0; i<3; i++)); do
                    echo -n "."
                    sleep 1
                done

                # 确定服务器是否正确开启
                if ps -ef | grep "$START_CMD" | grep -v grep > /dev/null; then
                    echo -n " [OK]"
                else
                    echo -n " [ER]"
                fi
            fi
            echo
        fi
    fi
}

# 开启服务器(全部)
STG_start_all_servers() {
    local OPERATE_TYPE=$2
    OPERATE_TYPE=${OPERATE_TYPE,,}

    if [[ $OPERATE_TYPE == "release" ]]; then
        OPERATE_TYPE="Release"
    else
        OPERATE_TYPE="Debug"
    fi

    # 运行代理服务器
    if [[ $1 -eq 1 ]]; then
        if [ -d ProxyServer/ ]; then
            cd ProxyServer/
            STG_start_server_by_exe_path false ./ProxyServer
            cd ../
        else
            echo "代理服务器程式,目录不存在!"
            return 0
        fi
    fi

    # 切程序目录
    if [ -d server/bin/$OPERATE_TYPE ]; then
        cd server/bin/$OPERATE_TYPE
    elif [ -d server/bin/ ]; then
        cd server/bin/
    else
        echo "游戏服务器程式,目录不存在!"
        return 0
    fi

    # 前置服务器
    STG_start_server_by_exe_path true "./GMServer"
    STG_start_server_by_exe_path true "./GameServer" "../../config/Distributed-Center.json"
    STG_start_server_by_exe_path true "./GameServer" "../../config/Distributed-Arena.json"

    # 游戏服务器
    for config_file in $(find ../../config/ -name 'Distributed-Game*.json' 2>/dev/null); do
        STG_start_server_by_exe_path true "./GameServer" $config_file
    done

    # 战斗服务器
    STG_start_server_by_exe_path true "./GameServer" "../../config/Distributed-Battle.json"

    # 登入服务器
    if [[ $1 -eq 2 ]]; then
        STG_start_server_by_exe_path true "./LoginServer" "../../config/Distributed-Login.json" 
    else
        for config_file in $(find ../../config/ -name 'Distributed-Login*.json' 2>/dev/null); do
            STG_start_server_by_exe_path true "./LoginServer" $config_file
        done
    fi
    return 1
}

# 服务器打包
STG_server_package() {
    local PACKAGE_NAME=$2
    if [ -z $PACKAGE_NAME ]; then
        PACKAGE_NAME="$(date +%Y%m%d_%H%M%S)"
    fi

    # 打包程序
    if [[ $1 -eq 0 ]] || [[ $1 -eq 1 ]]; then
        cd server/bin/Release/
        tar jcvf ../../../bin_$PACKAGE_NAME.tar.bz2 GameServer GMServer LoginServer
        cd ../../../
    fi

    # 打包资源
    if [[ $1 -eq 0 ]] || [[ $1 -eq 2 ]]; then
        cd server/
        zip -r ../res_$PACKAGE_NAME.zip fbs/ sql/ data/ script/
        cd ../
    fi
}

# 服务器资源发布(清理)
STG_server_publish_clear() {
    find ./ -name 'res_*.zip' -type f -delete
    find ./ -name 'bin_*.tar.bz2' -type f -delete
}

# 服务器资源发布
STG_server_publish() { # [host] [user] [password]
    local USER=$1
    local PASS=$2
    local HOST=$3
    local PORT=$4
    if [ -z $PORT ]; then
        PORT=22
    fi

    # 检查参数
    if [ -z $USER ] || [ -z $PASS ] || [ -z $HOST ]; then
        echo "用户名、密码或主机地址不可以为空!"
        return 0
    fi 

    # 搜索资源
    local file_res=$(find ./ -name 'res_*.zip' 2>/dev/null)
    local file_bin=$(find ./ -name 'bin_*.tar.bz2' 2>/dev/null)
    if [ -z $file_res ] && [ -z $file_bin ]; then
        STG_server_package 0

        file_res=$(find ./ -name 'res_*.zip' 2>/dev/null)
        file_bin=$(find ./ -name 'bin_*.tar.bz2' 2>/dev/null)
        if [ -z $file_res ] && [ -z $file_bin ]; then
            echo "重新打包失败!"
            return 0
        fi
    fi

    # 复制程序
    for file in $file_bin; do
        echo "SCP: $file"
        sshpass -p $PASS scp -P $PORT -r $file $USER@$HOST:/root/stg
    done

    # 复制资源
    for file in $file_res; do
        echo "SCP: $file"
        sshpass -p $PASS scp -P $PORT -r $file $USER@$HOST:/root/stg
    done

    # 复制本脚本到远程服务器上
    sshpass -p $PASS scp -P $PORT -r ./$STG_SCRIPT_NAME $USER@$HOST:/root/stg

    # 在远程服务器上解压缩文件
    sshpass -p $PASS ssh -p $PORT $USER@$HOST "cd /root/stg/ && chmod a+x ./$STG_SCRIPT_NAME && ./$STG_SCRIPT_NAME -------------------------publish-unpack-------------------------"
}

# 服务器发布解包(内部命令)
STG_publish_unpack() {
    # 解压程序
    local file_bin=$(find ./ -name 'bin_*.tar.bz2' 2>/dev/null)
    for file in $file_bin; do
        echo "UNPACK: $file"
        cd server/bin/

        # 解压程序
        if [ -d Release/ ]; then
            cd Release/
            tar jxvf ../../../$file --overwrite
            cd ../../../
        else
            tar jxvf ../../$file --overwrite
            cd ../../
        fi

        # 删除文件
        rm -rf $file
    done

    # 解压资源
    local file_res=$(find ./ -name 'res_*.zip' 2>/dev/null)
    for file in $file_res; do
        echo "UNPACK: $file"
        cd server/
        unzip -o ../$file
        cd ../
        rm -rf $file
    done
}

# 服务器命令操作
STG_server() {
    local OPERATE_TYPE=$1
    OPERATE_TYPE=${OPERATE_TYPE,,}

    if [[ $OPERATE_TYPE == "list" ]]; then 
        STG_list_all_servers
    elif [[ $OPERATE_TYPE == "start" ]]; then 
        STG_start_all_servers 0 $2
    elif [[ $OPERATE_TYPE == "start-all" ]]; then 
        STG_start_all_servers 1 $2
    elif [[ $OPERATE_TYPE == "start-dev" ]]; then 
        STG_start_all_servers 2 $2
    elif [[ $OPERATE_TYPE == "stop" ]]; then 
        STG_stop_all_servers_by_class "LoginServer"
        STG_stop_all_servers_by_class "GameServer"
        STG_stop_all_servers_by_class "GMServer"
    elif [[ $OPERATE_TYPE == "stop-all" ]]; then 
        STG_stop_all_servers_by_class "LoginServer"
        STG_stop_all_servers_by_class "GameServer"
        STG_stop_all_servers_by_class "GMServer"
        STG_stop_all_servers_by_class "ProxyServer"
    elif [[ $OPERATE_TYPE == "pack" ]]; then
        STG_server_package 0 $2
    elif [[ $OPERATE_TYPE == "pack-bin" ]]; then
        STG_server_package 1 $2
    elif [[ $OPERATE_TYPE == "pack-res" ]]; then
        STG_server_package 2 $2
    elif [[ $OPERATE_TYPE == "publish" ]]; then
        STG_server_publish "${@:2}"
    elif [[ $OPERATE_TYPE == "publish-clear" ]]; then
        STG_server_publish_clear
    elif [[ $OPERATE_TYPE == "-------------------------publish-unpack-------------------------" ]]; then 
        STG_publish_unpack
    else
        STG_list_all_servers
    fi
}

# GIT命令操作
STG_git() {
    local OPERATE_TYPE=$1
    OPERATE_TYPE=${OPERATE_TYPE,,}

    if [[ $OPERATE_TYPE == "r" ]]; then
        STG_rebase_code_sources
    elif [[ $OPERATE_TYPE == "p" ]]; then
        STG_pull_code_sources
    elif [ -n "$OPERATE_TYPE" ]; then
        git "${@:1}"
    else
        git status
    fi
}

# 文件操作
STG_io() {
    local OPERATE_TYPE=$1
    OPERATE_TYPE=${OPERATE_TYPE,,}

    if [[ $OPERATE_TYPE == "cp" ]]; then
        yes | cp -rf "${@:2}" > /dev/null 2>&1
    elif [[ $OPERATE_TYPE == "rm" ]]; then 
        yes | rm -rf "${@:2}" > /dev/null 2>&1
    elif [[ $OPERATE_TYPE == "mv" ]]; then
        yes | mv -f "${@:2}" > /dev/null 2>&1
    elif [[ $OPERATE_TYPE == "md" ]]; then
        yes | mv -T -f "${@:2}" > /dev/null 2>&1
    elif [[ $OPERATE_TYPE == "ll" ]]; then
        ls -al
    elif [ -n "$OPERATE_TYPE" ]; then
        ${@:1}
    else
        ls -al
    fi
}

# MYSQL数据库备份
STG_mysql_dump_all_dbs() {
    local MYSQL_DUMP_CMD="mysqldump ${@:3}" 
    if [ -z ${@:3} ]; then
        if [ "$1" = "true" ]; then
            option="save-all"
        else
            option="save"
        fi
        
        echo "Usage:"
        echo "    ./$STG_SCRIPT_NAME mysql $option ./dump_$(date +%Y%m%d_%H%M%S).sql -uroot -h10.10.10.10 -ptest"
        return 0
    fi

    if $1; then
        MYSQL_DUMP_CMD="$MYSQL_DUMP_CMD --databases stg_account stg_game"
    else
        MYSQL_DUMP_CMD="$MYSQL_DUMP_CMD --all-databases"
    fi

    local MYSQL_DUMP_FN=$2
    if [ -z $MYSQL_DUMP_FN ]; then
        MYSQL_DUMP_FN="./dump_$(date +%Y%m%d_%H%M%S).sql"
    fi

    MYSQL_DUMP_CMD="$MYSQL_DUMP_CMD > $MYSQL_DUMP_FN > /dev/null 2>&1"
    $MYSQL_DUMP_CMD 
    return 1
}

# 数据库操作
STG_mysql() {
    local OPERATE_TYPE=$1
    OPERATE_TYPE=${OPERATE_TYPE,,}

    if [[ $OPERATE_TYPE == "save" ]]; then
        STG_mysql_dump_all_dbs false "${@:2}"
    elif [[ $OPERATE_TYPE == "save-all" ]]; then
        STG_mysql_dump_all_dbs true "${@:2}"
    else
        echo "操作不支持!"
    fi
}

# 远程执行命令
STG_remote() {
    local USER=$1
    local PASS=$2
    local HOST=$3
    local PORT=$4
    if [ -z $PORT ]; then
        PORT=22
    fi

    # 检查参数
    if [ -z $USER ] || [ -z $PASS ] || [ -z $HOST ]; then
        echo "Usage:"
        echo "    ./$STG_SCRIPT_NAME remote root test 10.10.10.10"
        echo "    ./$STG_SCRIPT_NAME remote root test 10.10.10.10 22 server list"
        return 0
    fi 

    # 复制本脚本到远程服务器上
    sshpass -p $PASS scp -P $PORT -r ./$STG_SCRIPT_NAME $USER@$HOST:/root/stg

    # 在远程服务器上解压缩文件
    sshpass -p $PASS ssh -p $PORT $USER@$HOST "cd /root/stg/ && chmod a+x ./$STG_SCRIPT_NAME && ./$STG_SCRIPT_NAME ${@:5}"
}

# 在本机执行命令
STG_cmd() {
    ${@:1}
}

# 重新编译解决方案
if [[ $STG_BUILD_OPERATE_TYPE == "make" ]]; then
    STG_build_executable "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "git" ]]; then
    STG_git "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "io" ]]; then
    STG_io "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "cmd" ]]; then
    STG_cmd "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "sys" ]]; then
    STG_sys "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "mysql" ]]; then
    STG_mysql "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "server" ]]; then
    STG_server "${@:2}"
elif [[ $STG_BUILD_OPERATE_TYPE == "remote" ]]; then
    STG_remote "${@:2}"
else
    STG_help "${@:2}"
fi
相关推荐
co0t5 分钟前
计算机网络(14)ip地址超详解
服务器·tcp/ip·计算机网络
C++忠实粉丝6 分钟前
计算机网络socket编程(3)_UDP网络编程实现简单聊天室
linux·网络·c++·网络协议·计算机网络·udp
淡水猫.11 分钟前
Fakelocation Server服务器/专业版 ubuntu
运维·服务器·ubuntu
wenyue112118 分钟前
Ease Monitor 会把基础层,中间件层的监控数据和服务的监控数据打通,从总体的视角提供监控分析
运维·中间件·监控
量子网络24 分钟前
debian 如何进入root
linux·服务器·debian
时光の尘27 分钟前
C语言菜鸟入门·关键字·float以及double的用法
运维·服务器·c语言·开发语言·stm32·单片机·c
我们的五年31 分钟前
【Linux课程学习】:进程描述---PCB(Process Control Block)
linux·运维·c++
运维老司机1 小时前
Jenkins修改LOGO
运维·自动化·jenkins
D-海漠1 小时前
基础自动化系统的特点
运维·自动化
我言秋日胜春朝★1 小时前
【Linux】进程地址空间
linux·运维·服务器