chore: 清理大文件和部署配置

This commit is contained in:
爽哒哒
2026-03-19 00:56:19 +08:00
parent ef9057306c
commit 636ac24e70
4 changed files with 204 additions and 83 deletions

View File

@@ -1,83 +0,0 @@
name: Deploy to Server
on: [push]
jobs:
deploy:
runs-on: ubuntu
timeout-minutes: 30
steps:
- name: Deploy using SSH
# 使用 Gitea 官方镜像源,加速国内访问
uses: https://gitea.com/actions/appleboy-ssh-action@v1.0.3
with:
host: 6.6.6.66
username: quant
password: 123quant-speed
script: |
TARGET_DIR="/home/quant/data/dev/sign-up"
SUDO_PASSWORD="123quant-speed"
REPO_URL="https://gitea.tangledup-ai.com/quant-speed-AI/Scoring-System.git"
# 1. 检查目录是否存在,不存在则创建并克隆
echo "===== 检查目标目录: $TARGET_DIR ====="
if [ ! -d "$TARGET_DIR" ]; then
echo "目录不存在,创建目录并克隆仓库..."
mkdir -p $TARGET_DIR
git clone $REPO_URL $TARGET_DIR
fi
# 2. 切换到目标目录
echo "===== 切换到目标目录: $TARGET_DIR ====="
cd $TARGET_DIR || {
echo "错误:目录 $TARGET_DIR 不存在!"
exit 1
}
# 3. 停止并移除 Docker 容器及镜像
echo -e "\n===== 停止并清理 Docker ====="
# 强制停止并删除容器,忽略错误
echo $SUDO_PASSWORD | sudo -S docker compose down --remove-orphans 2>/dev/null || true
# 等待容器完全停止
sleep 5
# 清理本项目残留容器(避免影响其他项目)
echo $SUDO_PASSWORD | sudo -S docker ps -aq --filter "name=cywl-scoring" | xargs -r docker rm -f 2>/dev/null || true
# 4. 拉取 Git 最新代码
echo -e "\n===== 拉取 Git 代码 ====="
# 尝试拉取,如果失败则强制重置,增强鲁棒性
if ! git pull; then
echo "警告Git pull 失败,尝试强制同步远程代码..."
git fetch --all
# 获取当前分支名并重置
CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD)
git reset --hard origin/$CURRENT_BRANCH
git pull
fi
# 5. 创建/更新 .env 文件 (从本地环境变量注入)
echo -e "\n===== 配置环境变量 ====="
cat > backend/.env <<EOF
# Aliyun OSS Configuration
ALIYUN_ACCESS_KEY_ID=LTAI5tE62GW8MKyoEaotzxXk
ALIYUN_ACCESS_KEY_SECRET=Zdzqo1fgj57DxxioXOotNKhJdSfVQW
ALIYUN_OSS_ENDPOINT=https://oss-cn-shanghai.aliyuncs.com
ALIYUN_OSS_BUCKET_NAME=tangledup-ai-staging
ALIYUN_OSS_INTERNAL_ENDPOINT=https://oss-cn-shanghai-internal.aliyuncs.com
# Aliyun Tingwu Configuration
ALIYUN_TINGWU_APP_KEY=6eOX7N3tKE0fDwb
DASHSCOPE_API_KEY=sk-84e9eef24a274f568d4fa15c97556c9f
EOF
# 6. 重新启动 Docker 容器
echo -e "\n===== 启动 Docker 容器 ====="
echo $SUDO_PASSWORD | sudo -S docker compose up -d --build --quiet-pull
# 7. 等待服务启动
echo -e "\n===== 等待服务启动 ====="
sleep 15
# 8. 检查服务状态
echo -e "\n===== 检查服务状态 ====="
echo $SUDO_PASSWORD | sudo -S docker compose ps
echo -e "\n===== 操作完成!====="

42
docker-compose.dev.yml Normal file
View File

@@ -0,0 +1,42 @@
# 本地开发模式 - 不使用 Docker 构建,直接挂载代码运行
version: '3.8'
services:
# 后端服务 - 使用本地 Python
scoring-backend:
image: python:3.12-slim
container_name: cywl-scoring-backend
working_dir: /app
volumes:
- ./backend:/app
ports:
- "8876:8876"
environment:
- DEBUG=True
- SECRET_KEY=local-dev-secret-key
- DB_NAME=scoring_system
- DB_USER=postgres
- DB_PASSWORD=password
- DB_HOST=host.docker.internal
- DB_PORT=5432
command: >
sh -c "pip install -r requirements.txt &&
python manage.py migrate &&
python manage.py runserver 0.0.0.0:8876"
extra_hosts:
- "host.docker.internal:host-gateway"
# 前端服务 - 使用本地 Node
scoring-frontend:
image: node:20-alpine
container_name: cywl-scoring-frontend
working_dir: /app
volumes:
- ./frontend:/app
ports:
- "5173:5173"
environment:
- VITE_API_URL=http://localhost:8876/api
command: >
sh -c "npm install &&
npm run dev -- --host 0.0.0.0"

49
run-local.sh Normal file
View File

@@ -0,0 +1,49 @@
#!/bin/bash
# 本地运行脚本(不使用 Docker
echo "===== 启动创赢未来评分系统(本地模式)====="
echo ""
# 检查端口占用
echo "检查端口..."
lsof -ti:8876 | xargs kill -9 2>/dev/null || true
lsof -ti:5173 | xargs kill -9 2>/dev/null || true
# 启动后端
echo ""
echo "===== 启动后端服务 ====="
cd backend
source venv/bin/activate 2>/dev/null || echo "请确保虚拟环境已创建"
python manage.py migrate --check 2>/dev/null || echo "需要运行: python manage.py migrate"
python manage.py runserver 0.0.0.0:8876 &
BACKEND_PID=$!
echo "后端 PID: $BACKEND_PID"
cd ..
# 等待后端启动
sleep 3
# 启动前端
echo ""
echo "===== 启动前端服务 ====="
cd frontend
npm run dev &
FRONTEND_PID=$!
echo "前端 PID: $FRONTEND_PID"
cd ..
echo ""
echo "===== 服务已启动 ====="
echo "前端: http://localhost:5173"
echo "后端: http://localhost:8876"
echo "API文档: http://localhost:8876/api/docs/"
echo "后台: http://localhost:8876/admin/"
echo ""
echo "按 Ctrl+C 停止服务"
# 捕获终止信号
trap "echo ''; echo '正在停止服务...'; kill $BACKEND_PID $FRONTEND_PID 2>/dev/null; exit 0" INT
# 保持运行
wait

113
start-local.sh Executable file
View File

@@ -0,0 +1,113 @@
#!/bin/bash
echo "========================================"
echo " 创赢未来评分系统 - 本地启动脚本"
echo "========================================"
echo ""
# 函数:检查端口并释放
check_port() {
local port=$1
local pid=$(lsof -ti:$port 2>/dev/null)
if [ -n "$pid" ]; then
echo "端口 $port 被占用,正在释放..."
kill -9 $pid 2>/dev/null || true
sleep 1
fi
}
# 释放端口
check_port 8876
check_port 5173
# 检查环境
echo "✅ 检查环境..."
# 检查后端虚拟环境
if [ ! -d "backend/venv" ]; then
echo "❌ 后端虚拟环境不存在,正在创建..."
cd backend
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
cd ..
else
echo "✅ 后端虚拟环境已存在"
fi
# 检查前端依赖
if [ ! -d "frontend/node_modules" ]; then
echo "❌ 前端依赖不存在,正在安装..."
cd frontend
npm install
cd ..
else
echo "✅ 前端依赖已存在"
fi
echo ""
echo "========================================"
echo " 启动服务"
echo "========================================"
echo ""
# 启动后端
echo "🚀 启动后端服务 (http://localhost:8876)"
cd backend
source venv/bin/activate
python manage.py migrate 2>/dev/null || echo "迁移可能需要手动执行"
python manage.py runserver 0.0.0.0:8876 > /tmp/backend.log 2>&1 &
BACKEND_PID=$!
echo " 后端 PID: $BACKEND_PID"
echo " 日志: /tmp/backend.log"
cd ..
# 等待后端启动
sleep 3
# 启动前端
echo ""
echo "🚀 启动前端服务 (http://localhost:5173)"
cd frontend
npm run dev > /tmp/frontend.log 2>&1 &
FRONTEND_PID=$!
echo " 前端 PID: $FRONTEND_PID"
echo " 日志: /tmp/frontend.log"
cd ..
echo ""
echo "========================================"
echo " 服务已启动!"
echo "========================================"
echo ""
echo "📱 前端页面: http://localhost:5173"
echo "🔧 后端 API: http://localhost:8876"
echo "📚 API文档: http://localhost:8876/api/docs/"
echo "⚙️ 后台管理: http://localhost:8876/admin/"
echo ""
echo "💡 查看日志:"
echo " tail -f /tmp/backend.log"
echo " tail -f /tmp/frontend.log"
echo ""
echo "🛑 停止服务: 按 Ctrl+C"
echo ""
# 保存 PID
echo "$BACKEND_PID $FRONTEND_PID" > /tmp/scoring_pids
# 捕获终止信号
cleanup() {
echo ""
echo "========================================"
echo " 正在停止服务..."
echo "========================================"
kill $BACKEND_PID $FRONTEND_PID 2>/dev/null || true
sleep 1
echo "✅ 服务已停止"
rm -f /tmp/scoring_pids
exit 0
}
trap cleanup INT TERM
# 等待
wait