125 lines
3.9 KiB
Bash
125 lines
3.9 KiB
Bash
#!/usr/bin/env bash
|
||
#
|
||
# 卸载中学成绩档案系统(停止服务 + 可选删除数据/目录)
|
||
# 用法:
|
||
# sudo bash deploy/uninstall.sh # 停止服务,保留代码/数据库/上传
|
||
# sudo bash deploy/uninstall.sh --purge # 额外删除 /opt/secondary-school-grade-archive
|
||
# sudo bash deploy/uninstall.sh --purge-db # 额外删除 PostgreSQL 库与用户
|
||
# sudo bash deploy/uninstall.sh --purge --purge-db # 完全清除后重装
|
||
#
|
||
set -euo pipefail
|
||
|
||
INSTALL_DIR="${INSTALL_DIR:-/opt/secondary-school-grade-archive}"
|
||
OCR_SCREEN_NAME="${OCR_SCREEN_NAME:-ocr-worker}"
|
||
|
||
RED='\033[0;31m'
|
||
GREEN='\033[0;32m'
|
||
YELLOW='\033[1;33m'
|
||
NC='\033[0m'
|
||
|
||
log_info() { echo -e "${GREEN}[INFO]${NC} $*"; }
|
||
log_warn() { echo -e "${YELLOW}[WARN]${NC} $*"; }
|
||
log_error() { echo -e "${RED}[ERROR]${NC} $*" >&2; }
|
||
|
||
PURGE_DIR=0
|
||
PURGE_DB=0
|
||
for arg in "$@"; do
|
||
case "${arg}" in
|
||
--purge) PURGE_DIR=1 ;;
|
||
--purge-db) PURGE_DB=1 ;;
|
||
-h|--help)
|
||
sed -n '2,8p' "$0"
|
||
exit 0
|
||
;;
|
||
esac
|
||
done
|
||
|
||
if [[ "${EUID:-$(id -u)}" -ne 0 ]]; then
|
||
log_error "请使用 root: sudo bash deploy/uninstall.sh"
|
||
exit 1
|
||
fi
|
||
|
||
if [[ -f "${INSTALL_DIR}/.env" ]]; then
|
||
# shellcheck disable=SC1090
|
||
set -a && source "${INSTALL_DIR}/.env" && set +a
|
||
fi
|
||
|
||
POSTGRES_USER="${POSTGRES_USER:-gradeapp}"
|
||
POSTGRES_DB="${POSTGRES_DB:-student_archive}"
|
||
|
||
echo ""
|
||
echo "=========================================="
|
||
echo " 卸载中学成绩档案系统"
|
||
echo "=========================================="
|
||
echo " 安装目录: ${INSTALL_DIR}"
|
||
echo " 删除目录: $([[ ${PURGE_DIR} -eq 1 ]] && echo 是 || echo 否(保留))"
|
||
echo " 删除数据库: $([[ ${PURGE_DB} -eq 1 ]] && echo 是 || echo 否(保留))"
|
||
echo "=========================================="
|
||
echo ""
|
||
|
||
if [[ -t 0 ]]; then
|
||
read -rp "确认继续? [y/N] " confirm
|
||
if [[ "${confirm}" != [yY] ]]; then
|
||
echo "已取消"
|
||
exit 0
|
||
fi
|
||
fi
|
||
|
||
log_info "停止主程序 systemd…"
|
||
systemctl stop grade-archive 2>/dev/null || true
|
||
systemctl disable grade-archive 2>/dev/null || true
|
||
rm -f /etc/systemd/system/grade-archive.service
|
||
systemctl daemon-reload
|
||
|
||
log_info "停止 OCR Worker systemd(若曾安装)…"
|
||
systemctl stop ocr-worker 2>/dev/null || true
|
||
systemctl disable ocr-worker 2>/dev/null || true
|
||
rm -f /etc/systemd/system/ocr-worker.service
|
||
systemctl daemon-reload
|
||
|
||
log_info "停止 OCR screen 会话…"
|
||
if command -v screen >/dev/null; then
|
||
screen -S "${OCR_SCREEN_NAME}" -X quit 2>/dev/null || true
|
||
fi
|
||
|
||
log_info "停止旧版 PM2(若存在)…"
|
||
if command -v pm2 >/dev/null; then
|
||
pm2 delete grade-api grade-web 2>/dev/null || true
|
||
pm2 save --force 2>/dev/null || true
|
||
fi
|
||
|
||
if [[ ${PURGE_DB} -eq 1 ]]; then
|
||
if command -v psql >/dev/null && systemctl is-active postgresql &>/dev/null; then
|
||
log_info "删除 PostgreSQL 数据库 ${POSTGRES_DB}…"
|
||
sudo -u postgres psql -c "DROP DATABASE IF EXISTS \"${POSTGRES_DB}\";" 2>/dev/null || true
|
||
sudo -u postgres psql -c "DROP USER IF EXISTS \"${POSTGRES_USER}\";" 2>/dev/null || true
|
||
else
|
||
log_warn "PostgreSQL 未运行,跳过删库"
|
||
fi
|
||
fi
|
||
|
||
if [[ ${PURGE_DIR} -eq 1 ]]; then
|
||
log_info "删除安装目录 ${INSTALL_DIR}…"
|
||
rm -rf "${INSTALL_DIR}"
|
||
else
|
||
log_info "保留安装目录(含 uploads、.env、数据库文件若未 --purge-db)"
|
||
fi
|
||
|
||
echo ""
|
||
echo "=========================================="
|
||
echo " 卸载完成"
|
||
echo "=========================================="
|
||
if [[ ${PURGE_DIR} -eq 0 ]]; then
|
||
echo " 代码仍在: ${INSTALL_DIR}"
|
||
echo " 重新部署:"
|
||
echo " cd ${INSTALL_DIR} && git pull"
|
||
echo " export OLLAMA_BASE_URL=http://Ollama电脑IP:11434"
|
||
echo " sudo bash deploy/install.sh"
|
||
else
|
||
echo " 重新部署(全新):"
|
||
echo " export OLLAMA_BASE_URL=http://Ollama电脑IP:11434"
|
||
echo " sudo bash deploy/install.sh"
|
||
echo " (install.sh 会自动 git clone 到 ${INSTALL_DIR})"
|
||
fi
|
||
echo "=========================================="
|