deploy.sh 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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="/home/lq/nginx/html_app/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,从 config.prod.yaml 创建...${NC}"
  44. cp config.prod.yaml config.yaml
  45. echo -e "${GREEN}已使用生产环境配置${NC}"
  46. fi
  47. # 创建数据目录
  48. mkdir -p data
  49. # 检查是否需要重新构建镜像(只有依赖变更才需要)
  50. NEED_BUILD=false
  51. # 检查镜像是否存在
  52. if ! docker image inspect lq-label-backend:latest > /dev/null 2>&1; then
  53. echo "镜像不存在,需要构建..."
  54. NEED_BUILD=true
  55. fi
  56. # 依赖文件哈希(只有这些变更才需要重建镜像)
  57. DEPS_HASH=$(md5sum requirements.txt Dockerfile 2>/dev/null | md5sum | cut -d' ' -f1)
  58. if [ -f ".last_deps_hash" ]; then
  59. LAST_DEPS_HASH=$(cat .last_deps_hash)
  60. if [ "$DEPS_HASH" != "$LAST_DEPS_HASH" ]; then
  61. echo "检测到依赖或 Dockerfile 变更,需要重建镜像..."
  62. NEED_BUILD=true
  63. fi
  64. else
  65. NEED_BUILD=true
  66. fi
  67. # 执行构建(只在需要时)
  68. if [ "$NEED_BUILD" = true ]; then
  69. echo "构建 Docker 镜像..."
  70. docker build -t lq-label-backend:latest .
  71. echo "$DEPS_HASH" > .last_deps_hash
  72. echo -e "${GREEN}镜像构建完成${NC}"
  73. else
  74. echo -e "${GREEN}依赖无变更,跳过镜像构建${NC}"
  75. echo "代码已通过 volume 挂载,重启容器即可生效"
  76. fi
  77. echo "启动后端服务..."
  78. docker compose down 2>/dev/null || true
  79. docker compose up -d
  80. # 等待服务启动
  81. echo "等待服务启动..."
  82. sleep 5
  83. # 健康检查
  84. if curl -s http://localhost:8003/health > /dev/null; then
  85. echo -e "${GREEN}后端服务启动成功${NC}"
  86. else
  87. echo -e "${RED}后端服务启动失败,请检查日志: docker compose logs${NC}"
  88. exit 1
  89. fi
  90. cd "$SCRIPT_DIR"
  91. # ============================================
  92. # 3. 部署前端
  93. # ============================================
  94. echo
  95. echo -e "${YELLOW}[3/4] 部署前端...${NC}"
  96. # 检查前端包是否存在
  97. if [ ! -f "lq_label_dist.tar.gz" ]; then
  98. echo -e "${RED}错误: 未找到 lq_label_dist.tar.gz${NC}"
  99. echo -e "${YELLOW}请先在 Windows 开发环境运行 build.bat 构建前端${NC}"
  100. exit 1
  101. fi
  102. # 创建部署目录
  103. sudo mkdir -p "$FRONTEND_DEPLOY_DIR"
  104. # 备份旧版本(可选)
  105. if [ -d "$FRONTEND_DEPLOY_DIR" ] && [ "$(ls -A $FRONTEND_DEPLOY_DIR 2>/dev/null)" ]; then
  106. BACKUP_DIR="${FRONTEND_DEPLOY_DIR}_backup_$(date +%Y%m%d_%H%M%S)"
  107. echo "备份旧版本到 $BACKUP_DIR"
  108. sudo mv "$FRONTEND_DEPLOY_DIR" "$BACKUP_DIR"
  109. sudo mkdir -p "$FRONTEND_DEPLOY_DIR"
  110. fi
  111. # 解压前端文件
  112. echo "解压前端文件到 $FRONTEND_DEPLOY_DIR"
  113. sudo tar -xzvf lq_label_dist.tar.gz -C "$FRONTEND_DEPLOY_DIR" --strip-components=1
  114. # 设置权限
  115. sudo chown -R www-data:www-data "$FRONTEND_DEPLOY_DIR" 2>/dev/null || \
  116. sudo chown -R nginx:nginx "$FRONTEND_DEPLOY_DIR" 2>/dev/null || \
  117. echo "请手动设置目录权限"
  118. echo -e "${GREEN}前端部署完成${NC}"
  119. # ============================================
  120. # 4. 重载 Nginx
  121. # ============================================
  122. echo
  123. echo -e "${YELLOW}[4/4] 重载 Nginx 配置...${NC}"
  124. # 检查 Nginx 配置
  125. if sudo nginx -t; then
  126. sudo systemctl reload nginx || sudo nginx -s reload
  127. echo -e "${GREEN}Nginx 重载完成${NC}"
  128. else
  129. echo -e "${RED}Nginx 配置错误,请检查配置文件${NC}"
  130. exit 1
  131. fi
  132. # ============================================
  133. # 完成
  134. # ============================================
  135. echo
  136. echo -e "${GREEN}============================================${NC}"
  137. echo -e "${GREEN} 部署完成!${NC}"
  138. echo -e "${GREEN}============================================${NC}"
  139. echo
  140. echo "前端地址: http://localhost:9101"
  141. echo "后端地址: http://localhost:8003"
  142. echo "API 文档: http://localhost:8003/docs"
  143. echo
  144. echo -e "${YELLOW}常用命令:${NC}"
  145. echo " 查看后端日志: cd backend && docker compose logs -f"
  146. echo " 重启后端: cd backend && docker compose restart"
  147. echo " 停止后端: cd backend && docker compose down"