fix(deploy): full-reset now only resets data, not rebuild
- Remove image deletion and rebuild steps - Only delete database volumes and restart services - TypeORM synchronize:true handles schema creation - Much faster: no recompilation needed Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
parent
7d9b87ef3c
commit
a54b82cab3
80
deploy.sh
80
deploy.sh
|
|
@ -907,96 +907,64 @@ do_deploy_full() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#===============================================================================
|
#===============================================================================
|
||||||
# 完整重置 (危险操作)
|
# 数据重置 (只删除数据,不重新编译)
|
||||||
#===============================================================================
|
#===============================================================================
|
||||||
do_full_reset() {
|
do_full_reset() {
|
||||||
echo -e "${RED}╔═══════════════════════════════════════════════════════════════════════════════╗${NC}"
|
echo -e "${RED}╔═══════════════════════════════════════════════════════════════════════════════╗${NC}"
|
||||||
echo -e "${RED}║ ⚠️ 警告 ⚠️ ║${NC}"
|
echo -e "${RED}║ ⚠️ 警告 ⚠️ ║${NC}"
|
||||||
echo -e "${RED}║ ║${NC}"
|
echo -e "${RED}║ ║${NC}"
|
||||||
echo -e "${RED}║ 这将删除所有数据并重置系统,包括: ║${NC}"
|
echo -e "${RED}║ 这将删除所有数据库数据,包括: ║${NC}"
|
||||||
echo -e "${RED}║ - PostgreSQL 数据库中的所有数据 ║${NC}"
|
echo -e "${RED}║ - PostgreSQL 数据库中的所有表和数据 ║${NC}"
|
||||||
echo -e "${RED}║ - Redis 缓存数据 ║${NC}"
|
echo -e "${RED}║ - Redis 缓存数据 ║${NC}"
|
||||||
echo -e "${RED}║ - Neo4j 图数据库中的所有数据 ║${NC}"
|
echo -e "${RED}║ - Neo4j 图数据库中的所有数据 ║${NC}"
|
||||||
echo -e "${RED}║ - 所有 Docker 镜像和容器 ║${NC}"
|
|
||||||
echo -e "${RED}║ - 所有构建产物 ║${NC}"
|
|
||||||
echo -e "${RED}║ ║${NC}"
|
echo -e "${RED}║ ║${NC}"
|
||||||
echo -e "${RED}║ SSL 证书将被保留(存储在 /etc/letsencrypt/) ║${NC}"
|
echo -e "${RED}║ 不会删除:Docker镜像、代码、构建产物 ║${NC}"
|
||||||
echo -e "${RED}║ 此操作不可撤销! ║${NC}"
|
echo -e "${RED}║ 此操作不可撤销! ║${NC}"
|
||||||
echo -e "${RED}╚═══════════════════════════════════════════════════════════════════════════════╝${NC}"
|
echo -e "${RED}╚═══════════════════════════════════════════════════════════════════════════════╝${NC}"
|
||||||
echo ""
|
echo ""
|
||||||
read -p "确认要完全重置系统吗?请输入 YES 确认: " confirm
|
read -p "确认要重置所有数据吗?请输入 YES 确认: " confirm
|
||||||
|
|
||||||
if [ "$confirm" != "YES" ]; then
|
if [ "$confirm" != "YES" ]; then
|
||||||
log_info "操作已取消"
|
log_info "操作已取消"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_warning "开始完整重置..."
|
log_warning "开始数据重置..."
|
||||||
|
|
||||||
# 1. 停止所有服务
|
# 1. 停止所有服务 (保留镜像,只删除数据卷)
|
||||||
log_step "停止所有服务..."
|
log_step "停止所有服务..."
|
||||||
$DOCKER_COMPOSE down -v --remove-orphans 2>/dev/null || true
|
$DOCKER_COMPOSE down -v 2>/dev/null || true
|
||||||
log_success "服务已停止"
|
log_success "服务已停止,数据卷已删除"
|
||||||
|
|
||||||
# 2. 清理 Docker 资源
|
# 2. 启动基础设施 (数据库会自动初始化为空)
|
||||||
log_step "清理 Docker 资源..."
|
|
||||||
docker system prune -af --volumes 2>/dev/null || true
|
|
||||||
docker volume prune -f 2>/dev/null || true
|
|
||||||
log_success "Docker 资源已清理"
|
|
||||||
|
|
||||||
# 3. 清理构建产物和依赖
|
|
||||||
log_step "清理构建产物..."
|
|
||||||
rm -rf node_modules 2>/dev/null || true
|
|
||||||
for dir in "${SERVICE_DIRS[@]}"; do
|
|
||||||
rm -rf "$PROJECT_ROOT/$dir/dist" 2>/dev/null || true
|
|
||||||
rm -rf "$PROJECT_ROOT/$dir/node_modules" 2>/dev/null || true
|
|
||||||
done
|
|
||||||
log_success "构建产物已清理"
|
|
||||||
|
|
||||||
# 4. 重新构建所有服务
|
|
||||||
log_step "重新构建所有服务..."
|
|
||||||
do_build all
|
|
||||||
|
|
||||||
# 5. 启动基础设施
|
|
||||||
log_step "启动基础设施..."
|
log_step "启动基础设施..."
|
||||||
do_start infra docker
|
do_start infra docker
|
||||||
|
|
||||||
# 6. 等待数据库就绪
|
# 3. 等待数据库就绪
|
||||||
wait_for_service localhost 5432 "PostgreSQL"
|
wait_for_service localhost 5432 "PostgreSQL"
|
||||||
wait_for_service localhost 6379 "Redis"
|
wait_for_service localhost 6379 "Redis"
|
||||||
wait_for_service localhost 7474 "Neo4j"
|
wait_for_service localhost 7474 "Neo4j"
|
||||||
|
|
||||||
# 7. 执行数据库迁移
|
# 4. 初始化数据库 (创建数据库和用户)
|
||||||
log_step "执行数据库迁移..."
|
log_step "初始化数据库..."
|
||||||
sleep 5 # 等待数据库完全初始化
|
sleep 3
|
||||||
do_db migrate
|
init_database 2>/dev/null || true
|
||||||
|
|
||||||
# 7.1 备用:确保 V2 咨询流程数据库列存在(迁移可能因各种原因失败)
|
# 5. 启动所有后端服务 (TypeORM synchronize:true 会自动创建表)
|
||||||
# 这些 ALTER 语句使用 IF NOT EXISTS,与 TypeORM 迁移保持一致
|
|
||||||
log_step "验证 V2 数据库列..."
|
|
||||||
docker exec -i iconsulting-postgres psql -U postgres -d iconsulting -c "
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS consulting_stage VARCHAR(30) DEFAULT 'greeting';
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS consulting_state JSONB;
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS collected_info JSONB;
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS recommended_programs TEXT[];
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS conversion_path VARCHAR(30);
|
|
||||||
ALTER TABLE conversations ADD COLUMN IF NOT EXISTS device_info JSONB;
|
|
||||||
CREATE INDEX IF NOT EXISTS idx_conversations_consulting_stage ON conversations (consulting_stage);
|
|
||||||
CREATE INDEX IF NOT EXISTS idx_conversations_conversion_path ON conversations (conversion_path);
|
|
||||||
" 2>/dev/null && log_success "V2 数据库列已验证" || log_warning "V2 数据库列验证跳过"
|
|
||||||
|
|
||||||
# 8. 启动所有后端服务
|
|
||||||
log_step "启动后端服务..."
|
log_step "启动后端服务..."
|
||||||
do_start backend docker
|
do_start backend docker
|
||||||
|
|
||||||
# 9. 配置 Kong (如果需要)
|
# 6. 等待服务就绪
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
# 7. 配置 Kong (如果需要)
|
||||||
if docker ps | grep -q kong; then
|
if docker ps | grep -q kong; then
|
||||||
log_step "配置 Kong API 网关..."
|
log_step "配置 Kong API 网关..."
|
||||||
sleep 5
|
sleep 3
|
||||||
do_kong setup 2>/dev/null || log_warning "Kong 配置跳过"
|
do_kong setup 2>/dev/null || log_warning "Kong 配置跳过"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_success "完整重置完成!"
|
log_success "数据重置完成!"
|
||||||
echo ""
|
echo ""
|
||||||
do_status
|
do_status
|
||||||
}
|
}
|
||||||
|
|
@ -1423,7 +1391,7 @@ show_help() {
|
||||||
|
|
||||||
deploy-full 完整部署 (含 SSL 证书自动申请)
|
deploy-full 完整部署 (含 SSL 证书自动申请)
|
||||||
|
|
||||||
full-reset ⚠️ 完整重置 (删除所有数据,重建系统,保留SSL证书)
|
full-reset ⚠️ 数据重置 (只删除数据库数据,不重新编译)
|
||||||
|
|
||||||
ssl <action> SSL 证书管理 (Let's Encrypt)
|
ssl <action> SSL 证书管理 (Let's Encrypt)
|
||||||
action: install - 安装 certbot
|
action: install - 安装 certbot
|
||||||
|
|
@ -1454,7 +1422,7 @@ show_help() {
|
||||||
./deploy.sh restart user docker # 重启用户服务 (Docker)
|
./deploy.sh restart user docker # 重启用户服务 (Docker)
|
||||||
./deploy.sh logs conversation 200 # 查看对话服务最近200行日志
|
./deploy.sh logs conversation 200 # 查看对话服务最近200行日志
|
||||||
./deploy.sh clean all # 清理所有构建产物和依赖
|
./deploy.sh clean all # 清理所有构建产物和依赖
|
||||||
./deploy.sh full-reset # ⚠️ 完整重置系统 (危险操作)
|
./deploy.sh full-reset # ⚠️ 重置所有数据库数据
|
||||||
./deploy.sh db init # 初始化数据库 (首次部署)
|
./deploy.sh db init # 初始化数据库 (首次部署)
|
||||||
./deploy.sh db backup # 备份数据库
|
./deploy.sh db backup # 备份数据库
|
||||||
./deploy.sh db migrate # 执行数据库迁移
|
./deploy.sh db migrate # 执行数据库迁移
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue