deploy.sh 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. #!/bin/bash
  2. # ============================================
  3. # 一键部署脚本 (Linux)
  4. # 用于服务器环境部署前后端
  5. # ============================================
  6. set -e
  7. # 颜色定义
  8. RED='\033[0;31m'
  9. GREEN='\033[0;32m'
  10. YELLOW='\033[1;33m'
  11. NC='\033[0m'
  12. # 配置变量(根据实际情况修改)
  13. FRONTEND_DEPLOY_DIR="/var/www/lq_label" # 前端部署目录(Nginx root)
  14. GIT_BRANCH="main" # Git 分支
  15. echo -e "${GREEN}============================================${NC}"
  16. echo -e "${GREEN} LQ Label 一键部署脚本${NC}"
  17. echo -e "${GREEN}============================================${NC}"
  18. echo
  19. # 获取脚本所在目录
  20. SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
  21. cd "$SCRIPT_DIR"
  22. # ============================================
  23. # 1. 拉取最新代码
  24. # ============================================
  25. echo -e "${YELLOW}[1/4] 拉取最新代码...${NC}"
  26. if [ -d ".git" ]; then
  27. git fetch origin
  28. git checkout $GIT_BRANCH
  29. git pull origin $GIT_BRANCH
  30. echo -e "${GREEN}代码更新完成${NC}"
  31. else
  32. echo -e "${RED}错误: 当前目录不是 Git 仓库${NC}"
  33. exit 1
  34. fi
  35. # ============================================
  36. # 2. 部署后端 (Docker)
  37. # ============================================
  38. echo
  39. echo -e "${YELLOW}[2/4] 部署后端服务...${NC}"
  40. cd backend
  41. # 检查配置文件
  42. if [ ! -f "config.yaml" ]; then
  43. echo -e "${YELLOW}未找到 config.yaml,从模板创建...${NC}"
  44. cp config.docker.yaml config.yaml
  45. echo -e "${RED}请编辑 backend/config.yaml 配置数据库和密钥后重新运行${NC}"
  46. exit 1
  47. fi
  48. # 创建数据目录
  49. mkdir -p data
  50. # 检查是否需要重新构建镜像
  51. NEED_BUILD=false
  52. # 检查镜像是否存在
  53. if ! docker image inspect lq-label-backend:latest > /dev/null 2>&1; then
  54. echo "镜像不存在,需要构建..."
  55. NEED_BUILD=true
  56. fi
  57. # 检查 requirements.txt 或 Dockerfile 是否有变更
  58. if [ -f ".last_build_hash" ]; then
  59. CURRENT_HASH=$(md5sum requirements.txt Dockerfile 2>/dev/null | md5sum | cut -d' ' -f1)
  60. LAST_HASH=$(cat .last_build_hash)
  61. if [ "$CURRENT_HASH" != "$LAST_HASH" ]; then
  62. echo "检测到依赖或 Dockerfile 变更,需要重新构建..."
  63. NEED_BUILD=true
  64. fi
  65. else
  66. NEED_BUILD=true
  67. fi
  68. if [ "$NEED_BUILD" = true ]; then
  69. echo "构建 Docker 镜像..."
  70. docker build -t lq-label-backend:latest .
  71. # 保存构建哈希
  72. md5sum requirements.txt Dockerfile 2>/dev/null | md5sum | cut -d' ' -f1 > .last_build_hash
  73. else
  74. echo "镜像无变更,跳过构建"
  75. fi
  76. echo "启动后端服务..."
  77. docker compose down 2>/dev/null || true
  78. docker compose up -d
  79. # 等待服务启动
  80. echo "等待服务启动..."
  81. sleep 5
  82. # 健康检查
  83. if curl -s http://localhost:8003/health > /dev/null; then
  84. echo -e "${GREEN}后端服务启动成功${NC}"
  85. else
  86. echo -e "${RED}后端服务启动失败,请检查日志: docker compose logs${NC}"
  87. exit 1
  88. fi
  89. cd "$SCRIPT_DIR"
  90. # ============================================
  91. # 3. 部署前端
  92. # ============================================
  93. echo
  94. echo -e "${YELLOW}[3/4] 部署前端...${NC}"
  95. # 检查前端包是否存在
  96. if [ ! -f "lq_label_dist.tar.gz" ]; then
  97. echo -e "${RED}错误: 未找到 lq_label_dist.tar.gz${NC}"
  98. echo -e "${YELLOW}请先在 Windows 开发环境运行 build.bat 构建前端${NC}"
  99. exit 1
  100. fi
  101. # 创建部署目录
  102. sudo mkdir -p "$FRONTEND_DEPLOY_DIR"
  103. # 备份旧版本(可选)
  104. if [ -d "$FRONTEND_DEPLOY_DIR" ] && [ "$(ls -A $FRONTEND_DEPLOY_DIR 2>/dev/null)" ]; then
  105. BACKUP_DIR="${FRONTEND_DEPLOY_DIR}_backup_$(date +%Y%m%d_%H%M%S)"
  106. echo "备份旧版本到 $BACKUP_DIR"
  107. sudo mv "$FRONTEND_DEPLOY_DIR" "$BACKUP_DIR"
  108. sudo mkdir -p "$FRONTEND_DEPLOY_DIR"
  109. fi
  110. # 解压前端文件
  111. echo "解压前端文件到 $FRONTEND_DEPLOY_DIR"
  112. sudo tar -xzvf lq_label_dist.tar.gz -C "$FRONTEND_DEPLOY_DIR" --strip-components=1
  113. # 设置权限
  114. sudo chown -R www-data:www-data "$FRONTEND_DEPLOY_DIR" 2>/dev/null || \
  115. sudo chown -R nginx:nginx "$FRONTEND_DEPLOY_DIR" 2>/dev/null || \
  116. echo "请手动设置目录权限"
  117. echo -e "${GREEN}前端部署完成${NC}"
  118. # ============================================
  119. # 4. 重载 Nginx
  120. # ============================================
  121. echo
  122. echo -e "${YELLOW}[4/4] 重载 Nginx 配置...${NC}"
  123. # 检查 Nginx 配置
  124. if sudo nginx -t; then
  125. sudo systemctl reload nginx || sudo nginx -s reload
  126. echo -e "${GREEN}Nginx 重载完成${NC}"
  127. else
  128. echo -e "${RED}Nginx 配置错误,请检查配置文件${NC}"
  129. exit 1
  130. fi
  131. # ============================================
  132. # 完成
  133. # ============================================
  134. echo
  135. echo -e "${GREEN}============================================${NC}"
  136. echo -e "${GREEN} 部署完成!${NC}"
  137. echo -e "${GREEN}============================================${NC}"
  138. echo
  139. echo "前端地址: http://localhost (根据 Nginx 配置)"
  140. echo "后端地址: http://localhost:8003"
  141. echo "API 文档: http://localhost:8003/docs"
  142. echo
  143. echo -e "${YELLOW}常用命令:${NC}"
  144. echo " 查看后端日志: cd backend && docker compose logs -f"
  145. echo " 重启后端: cd backend && docker compose restart"
  146. echo " 停止后端: cd backend && docker compose down"