根据Gemini建议的优化方案: **Dockerfile修复**: - 修复FROM语句大小写警告 (as -> AS) - 修复Maven settings.xml中的XML标签错误 (<n> -> <name>) - 优化健康检查端点支持Actuator标准 - 统一使用mvnw执行命令 **Jenkinsfile优化**: - 简化Docker buildx命令,移除可能导致网络问题的参数 - 添加备用构建方案:Buildx失败时自动切换到传统Docker构建 - 移除复杂的缓存配置,先确保基本构建正常 - 优化错误处理和重试逻辑 - 减少重试次数避免无谓等待 **工具脚本**: - setup-docker-mirrors.sh: 配置Docker镜像加速器 - test-docker-build.sh: 测试Docker构建环境 - 包含网络优化和构建器验证 **主要解决问题**: - Docker Hub网络超时问题 - Buildx配置复杂性 - 构建失败时的降级策略 下一步建议在服务器运行 scripts/setup-docker-mirrors.sh 配置镜像加速器
60 lines
1.3 KiB
Bash
60 lines
1.3 KiB
Bash
#!/bin/bash
|
|
|
|
# Docker Buildx 测试脚本
|
|
# 用于验证Buildx安装和配置
|
|
|
|
echo "🔍 Docker Buildx 测试脚本"
|
|
echo "========================="
|
|
|
|
# 1. 检查Docker版本
|
|
echo "📦 Docker版本:"
|
|
docker --version
|
|
|
|
# 2. 检查Buildx版本
|
|
echo "🛠️ Buildx版本:"
|
|
docker buildx version
|
|
|
|
# 3. 列出现有构建器
|
|
echo "📋 现有构建器:"
|
|
docker buildx ls
|
|
|
|
# 4. 测试创建简单构建器
|
|
echo "🏗️ 测试创建构建器..."
|
|
if docker buildx create --name test-builder --use --bootstrap; then
|
|
echo "✅ 构建器创建成功"
|
|
|
|
# 检查构建器状态
|
|
echo "📊 构建器详情:"
|
|
docker buildx inspect test-builder
|
|
|
|
# 清理测试构建器
|
|
echo "🧹 清理测试构建器..."
|
|
docker buildx rm test-builder
|
|
echo "✅ 测试完成"
|
|
else
|
|
echo "❌ 构建器创建失败"
|
|
fi
|
|
|
|
# 5. 测试简单构建
|
|
echo "🐳 测试简单Docker构建..."
|
|
mkdir -p /tmp/buildx-test
|
|
cat > /tmp/buildx-test/Dockerfile << 'EOF'
|
|
FROM alpine:latest
|
|
RUN echo "Buildx test successful" > /test.txt
|
|
CMD cat /test.txt
|
|
EOF
|
|
|
|
cd /tmp/buildx-test
|
|
if docker buildx build --platform linux/amd64 -t buildx-test . --load; then
|
|
echo "✅ Buildx构建测试成功"
|
|
docker run --rm buildx-test
|
|
docker rmi buildx-test
|
|
else
|
|
echo "❌ Buildx构建测试失败"
|
|
fi
|
|
|
|
# 清理
|
|
rm -rf /tmp/buildx-test
|
|
|
|
echo "🎉 测试完成!"
|