feat: 添加 Jenkins CI/CD 配置和部署脚本
- 添加 Jenkinsfile 支持智能增量构建 - 添加 Docker 多阶段构建模板 - 添加 Docker Compose 配置(连接 1Panel 中间件) - 添加部署、回滚、清理脚本 - 添加环境变量配置模板
This commit is contained in:
81
scripts/cleanup.sh
Normal file
81
scripts/cleanup.sh
Normal file
@@ -0,0 +1,81 @@
|
||||
#!/bin/bash
|
||||
|
||||
# ============================================
|
||||
# AIOT Platform - 清理脚本
|
||||
# 清理旧镜像和容器,释放存储空间
|
||||
# ============================================
|
||||
|
||||
set -e
|
||||
|
||||
# 颜色输出
|
||||
GREEN='\033[0;32m'
|
||||
YELLOW='\033[1;33m'
|
||||
NC='\033[0m'
|
||||
|
||||
log_info() {
|
||||
echo -e "${GREEN}[INFO]${NC} $1"
|
||||
}
|
||||
|
||||
log_warn() {
|
||||
echo -e "${YELLOW}[WARN]${NC} $1"
|
||||
}
|
||||
|
||||
log_info "========================================="
|
||||
log_info "AIOT Platform 清理开始"
|
||||
log_info "========================================="
|
||||
|
||||
# 显示当前磁盘使用情况
|
||||
log_info "当前磁盘使用情况:"
|
||||
df -h | grep -E "Filesystem|/$"
|
||||
echo ""
|
||||
log_info "当前 Docker 磁盘使用:"
|
||||
docker system df
|
||||
echo ""
|
||||
|
||||
# 清理停止的容器
|
||||
log_info "清理停止的容器..."
|
||||
docker container prune -f
|
||||
|
||||
# 清理悬空镜像
|
||||
log_info "清理悬空镜像..."
|
||||
docker image prune -f
|
||||
|
||||
# 清理旧版本镜像(保留最近 3 个版本)
|
||||
log_info "清理旧版本镜像(保留最近 3 个版本)..."
|
||||
|
||||
SERVICES="viewsh-gateway viewsh-module-system-server viewsh-module-infra-server viewsh-module-iot-server viewsh-module-iot-gateway viewsh-module-ops-server"
|
||||
|
||||
for service in $SERVICES; do
|
||||
log_info "处理服务: ${service}"
|
||||
|
||||
# 获取所有镜像,按时间排序,删除除了最新 3 个之外的所有镜像
|
||||
docker images "localhost:5000/${service}" --format "{{.ID}} {{.Tag}}" | \
|
||||
grep -v "latest" | \
|
||||
tail -n +4 | \
|
||||
awk '{print $1}' | \
|
||||
xargs -r docker rmi -f 2>/dev/null || true
|
||||
done
|
||||
|
||||
# 清理未使用的卷(谨慎使用)
|
||||
log_warn "是否清理未使用的卷? (y/N)"
|
||||
read -r response
|
||||
if [ "$response" = "y" ] || [ "$response" = "Y" ]; then
|
||||
log_info "清理未使用的卷..."
|
||||
docker volume prune -f
|
||||
fi
|
||||
|
||||
# 清理构建缓存
|
||||
log_info "清理 Docker 构建缓存..."
|
||||
docker builder prune -f --filter "until=24h"
|
||||
|
||||
# 显示清理后的磁盘使用情况
|
||||
echo ""
|
||||
log_info "========================================="
|
||||
log_info "清理完成"
|
||||
log_info "========================================="
|
||||
echo ""
|
||||
log_info "清理后磁盘使用情况:"
|
||||
df -h | grep -E "Filesystem|/$"
|
||||
echo ""
|
||||
log_info "清理后 Docker 磁盘使用:"
|
||||
docker system df
|
||||
230
scripts/deploy.sh
Normal file
230
scripts/deploy.sh
Normal file
@@ -0,0 +1,230 @@
|
||||
#!/bin/bash
|
||||
|
||||
# ============================================
|
||||
# AIOT Platform - 部署脚本
|
||||
# 滚动更新部署,支持健康检查和自动回滚
|
||||
# ============================================
|
||||
|
||||
set -e
|
||||
|
||||
# 颜色输出
|
||||
RED='\033[0;31m'
|
||||
GREEN='\033[0;32m'
|
||||
YELLOW='\033[1;33m'
|
||||
NC='\033[0m' # No Color
|
||||
|
||||
# 配置
|
||||
COMPOSE_FILE="docker-compose.core.yml"
|
||||
REGISTRY="localhost:5000"
|
||||
HEALTH_CHECK_TIMEOUT=120
|
||||
HEALTH_CHECK_INTERVAL=5
|
||||
|
||||
# 日志函数
|
||||
log_info() {
|
||||
echo -e "${GREEN}[INFO]${NC} $1"
|
||||
}
|
||||
|
||||
log_warn() {
|
||||
echo -e "${YELLOW}[WARN]${NC} $1"
|
||||
}
|
||||
|
||||
log_error() {
|
||||
echo -e "${RED}[ERROR]${NC} $1"
|
||||
}
|
||||
|
||||
# 检查服务健康状态
|
||||
check_health() {
|
||||
local service=$1
|
||||
local container_name="aiot-${service}"
|
||||
local elapsed=0
|
||||
|
||||
log_info "等待 ${service} 健康检查..."
|
||||
|
||||
while [ $elapsed -lt $HEALTH_CHECK_TIMEOUT ]; do
|
||||
if docker inspect --format='{{.State.Health.Status}}' "$container_name" 2>/dev/null | grep -q "healthy"; then
|
||||
log_info "${service} 健康检查通过 ✓"
|
||||
return 0
|
||||
fi
|
||||
|
||||
sleep $HEALTH_CHECK_INTERVAL
|
||||
elapsed=$((elapsed + HEALTH_CHECK_INTERVAL))
|
||||
echo -n "."
|
||||
done
|
||||
|
||||
echo ""
|
||||
log_error "${service} 健康检查超时 ✗"
|
||||
return 1
|
||||
}
|
||||
|
||||
# 备份当前运行的镜像标签
|
||||
backup_current_tags() {
|
||||
log_info "备份当前镜像标签..."
|
||||
|
||||
docker-compose -f "$COMPOSE_FILE" config --services | while read service; do
|
||||
local current_image=$(docker inspect "aiot-${service}" --format='{{.Config.Image}}' 2>/dev/null || echo "")
|
||||
if [ -n "$current_image" ]; then
|
||||
echo "${service}=${current_image}" >> .deploy_backup
|
||||
fi
|
||||
done
|
||||
|
||||
log_info "备份完成: .deploy_backup"
|
||||
}
|
||||
|
||||
# 部署单个服务
|
||||
deploy_service() {
|
||||
local service=$1
|
||||
|
||||
log_info "========================================="
|
||||
log_info "部署服务: ${service}"
|
||||
log_info "========================================="
|
||||
|
||||
# 拉取最新镜像
|
||||
log_info "拉取最新镜像..."
|
||||
if ! docker-compose -f "$COMPOSE_FILE" pull "$service"; then
|
||||
log_error "拉取镜像失败"
|
||||
return 1
|
||||
fi
|
||||
|
||||
# 启动新容器
|
||||
log_info "启动新容器..."
|
||||
if ! docker-compose -f "$COMPOSE_FILE" up -d "$service"; then
|
||||
log_error "启动容器失败"
|
||||
return 1
|
||||
fi
|
||||
|
||||
# 健康检查
|
||||
if ! check_health "$service"; then
|
||||
log_error "${service} 部署失败,准备回滚..."
|
||||
return 1
|
||||
fi
|
||||
|
||||
log_info "${service} 部署成功 ✓"
|
||||
return 0
|
||||
}
|
||||
|
||||
# 回滚服务
|
||||
rollback_service() {
|
||||
local service=$1
|
||||
|
||||
log_warn "回滚服务: ${service}"
|
||||
|
||||
# 从备份文件读取之前的镜像
|
||||
if [ -f .deploy_backup ]; then
|
||||
local backup_image=$(grep "^${service}=" .deploy_backup | cut -d'=' -f2)
|
||||
|
||||
if [ -n "$backup_image" ]; then
|
||||
log_info "回滚到镜像: ${backup_image}"
|
||||
|
||||
docker-compose -f "$COMPOSE_FILE" stop "$service"
|
||||
docker tag "$backup_image" "${REGISTRY}/${service}:latest"
|
||||
docker-compose -f "$COMPOSE_FILE" up -d "$service"
|
||||
|
||||
if check_health "$service"; then
|
||||
log_info "${service} 回滚成功 ✓"
|
||||
return 0
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
log_error "${service} 回滚失败 ✗"
|
||||
return 1
|
||||
}
|
||||
|
||||
# 主部署流程
|
||||
main() {
|
||||
log_info "========================================="
|
||||
log_info "AIOT Platform 部署开始"
|
||||
log_info "========================================="
|
||||
|
||||
# 检查 .env 文件
|
||||
if [ ! -f .env ]; then
|
||||
log_error ".env 文件不存在,请先复制 .env.example 并配置"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 加载环境变量
|
||||
source .env
|
||||
|
||||
# 备份当前状态
|
||||
rm -f .deploy_backup
|
||||
backup_current_tags
|
||||
|
||||
# 获取要部署的服务列表
|
||||
local services_to_deploy=""
|
||||
|
||||
if [ $# -eq 0 ]; then
|
||||
# 部署所有核心服务
|
||||
services_to_deploy=$(docker-compose -f "$COMPOSE_FILE" config --services | grep -v -E "mysql|redis|nacos|rocketmq")
|
||||
else
|
||||
# 部署指定服务
|
||||
services_to_deploy="$@"
|
||||
fi
|
||||
|
||||
log_info "待部署服务: ${services_to_deploy}"
|
||||
|
||||
# 部署服务
|
||||
local failed_services=""
|
||||
|
||||
for service in $services_to_deploy; do
|
||||
if ! deploy_service "$service"; then
|
||||
failed_services="${failed_services} ${service}"
|
||||
|
||||
# 尝试回滚
|
||||
rollback_service "$service"
|
||||
fi
|
||||
done
|
||||
|
||||
# 清理旧镜像
|
||||
log_info "清理悬空镜像..."
|
||||
docker image prune -f
|
||||
|
||||
# 部署结果
|
||||
echo ""
|
||||
log_info "========================================="
|
||||
if [ -z "$failed_services" ]; then
|
||||
log_info "所有服务部署成功 ✓"
|
||||
log_info "========================================="
|
||||
rm -f .deploy_backup
|
||||
exit 0
|
||||
else
|
||||
log_error "以下服务部署失败: ${failed_services}"
|
||||
log_error "========================================="
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 显示帮助
|
||||
show_help() {
|
||||
cat << EOF
|
||||
用法: $0 [服务名...]
|
||||
|
||||
部署 AIOT Platform 服务到生产环境
|
||||
|
||||
参数:
|
||||
无参数 部署所有应用服务
|
||||
服务名... 部署指定的服务
|
||||
|
||||
示例:
|
||||
$0 # 部署所有服务
|
||||
$0 viewsh-gateway # 仅部署 gateway
|
||||
$0 viewsh-module-iot-server viewsh-module-iot-gateway # 部署多个服务
|
||||
|
||||
服务列表:
|
||||
- viewsh-gateway
|
||||
- viewsh-module-system-server
|
||||
- viewsh-module-infra-server
|
||||
- viewsh-module-iot-server
|
||||
- viewsh-module-iot-gateway
|
||||
- viewsh-module-ops-server
|
||||
|
||||
EOF
|
||||
}
|
||||
|
||||
# 参数处理
|
||||
if [ "$1" = "-h" ] || [ "$1" = "--help" ]; then
|
||||
show_help
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# 执行主流程
|
||||
main "$@"
|
||||
48
scripts/rollback.sh
Normal file
48
scripts/rollback.sh
Normal file
@@ -0,0 +1,48 @@
|
||||
#!/bin/bash
|
||||
|
||||
# ============================================
|
||||
# AIOT Platform - 回滚脚本
|
||||
# 快速回滚到上一个版本
|
||||
# ============================================
|
||||
|
||||
set -e
|
||||
|
||||
# 颜色输出
|
||||
RED='\033[0;31m'
|
||||
GREEN='\033[0;32m'
|
||||
YELLOW='\033[1;33m'
|
||||
NC='\033[0m'
|
||||
|
||||
log_info() {
|
||||
echo -e "${GREEN}[INFO]${NC} $1"
|
||||
}
|
||||
|
||||
log_error() {
|
||||
echo -e "${RED}[ERROR]${NC} $1"
|
||||
}
|
||||
|
||||
# 检查备份文件
|
||||
if [ ! -f .deploy_backup ]; then
|
||||
log_error "未找到备份文件 .deploy_backup"
|
||||
log_error "无法执行回滚操作"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
log_info "========================================="
|
||||
log_info "AIOT Platform 回滚开始"
|
||||
log_info "========================================="
|
||||
|
||||
# 读取备份并回滚
|
||||
while IFS='=' read -r service image; do
|
||||
log_info "回滚服务: ${service} -> ${image}"
|
||||
|
||||
docker-compose -f docker-compose.core.yml stop "$service"
|
||||
docker tag "$image" "localhost:5000/${service}:latest"
|
||||
docker-compose -f docker-compose.core.yml up -d "$service"
|
||||
|
||||
log_info "${service} 回滚完成 ✓"
|
||||
done < .deploy_backup
|
||||
|
||||
log_info "========================================="
|
||||
log_info "回滚完成"
|
||||
log_info "========================================="
|
||||
Reference in New Issue
Block a user