From fdb8e3995f3bc6abe3073a4c4c95f70434ea4eba Mon Sep 17 00:00:00 2001 From: dxin <1554389441@qq.com> Date: Sun, 26 Oct 2025 19:30:22 +0800 Subject: [PATCH] =?UTF-8?q?1.=20=E4=BF=AE=E6=94=B9=20SCM/build=5Fimage=5Fl?= =?UTF-8?q?essie=5Fsourcing=5Fagents.groovy=EF=BC=8C=E6=96=B0=E5=A2=9E?= =?UTF-8?q?=E8=87=AA=E5=AE=9A=E4=B9=89=E9=95=9C=E5=83=8FTag=E5=8A=9F?= =?UTF-8?q?=E8=83=BD=E5=B9=B6=E4=BC=98=E5=8C=96=E6=A0=87=E7=AD=BE=E7=94=9F?= =?UTF-8?q?=E6=88=90=E9=80=BB=E8=BE=91=EF=BC=9A=E6=B7=BB=E5=8A=A0CUSTOM=5F?= =?UTF-8?q?TAG=E5=8F=82=E6=95=B0=E8=BE=93=E5=85=A5=E6=A1=86=E5=8F=8A?= =?UTF-8?q?=E6=A0=A1=E9=AA=8C=E8=A7=84=E5=88=99=EF=BC=9B=E5=AE=9E=E7=8E=B0?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E4=BA=A4=E4=BA=92=E7=A1=AE=E8=AE=A4=E6=9C=BA?= =?UTF-8?q?=E5=88=B6=E5=A4=84=E7=90=86=E9=9D=9E=E6=B3=95Tag=E6=83=85?= =?UTF-8?q?=E5=86=B5=EF=BC=9B=E5=AE=8C=E5=96=84=E9=BB=98=E8=AE=A4Tag?= =?UTF-8?q?=E8=87=AA=E5=8A=A8=E7=94=9F=E6=88=90=E7=AD=96=E7=95=A5=E4=B8=8E?= =?UTF-8?q?=E6=8F=90=E7=A4=BA=E4=BF=A1=E6=81=AF=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- SCM/build_image_lessie_sourcing_agents.groovy | 71 ++++++++++++++----- 1 file changed, 53 insertions(+), 18 deletions(-) diff --git a/SCM/build_image_lessie_sourcing_agents.groovy b/SCM/build_image_lessie_sourcing_agents.groovy index 8370e6c..4f4124c 100644 --- a/SCM/build_image_lessie_sourcing_agents.groovy +++ b/SCM/build_image_lessie_sourcing_agents.groovy @@ -17,7 +17,12 @@ pipeline { choice( name: 'BUILD_env', choices: ['sit', 'test', 'prod'], - description: '选择构建的环境配置:' + description: '选择存放镜像的仓库命名空间:' + ) + string( + name: 'CUSTOM_TAG', + defaultValue: '', + description: '可选:自定义镜像 Tag (字母、数字、点、下划线、短横线), 留空则自动生成 “ v+构建次数_分支名_短哈希_构建时间 ”' ) } environment { @@ -40,26 +45,56 @@ pipeline { stage('获取提交信息') { steps { script { - // 获取最近一次提交的哈希值(短格式,前8位) - env.GIT_COMMIT_SHORT = sh(script: 'git rev-parse --short HEAD',returnStdout: true).trim() - // 获取最近一次提交的作者 - env.GIT_AUTHOR = sh(script: 'git log -1 --pretty=format:%an',returnStdout: true).trim() - // 获取最近一次提交的时间(格式化) - env.GIT_COMMIT_TIME = sh( - script: 'git log -1 --pretty=format:%ct | xargs -I {} date -d @{} +%Y%m%d-%H%M%S', - returnStdout: true - ).trim() - // 获取最近一次提交的备注信息(转义特殊字符,避免构建失败) + env.GIT_COMMIT_SHORT = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim() + env.GIT_AUTHOR = sh(script: 'git log -1 --pretty=format:%an', returnStdout: true).trim() + env.GIT_COMMIT_TIME = sh(script: 'git log -1 --pretty=format:%ct | xargs -I {} date -d @{} +%Y%m%d-%H%M%S', returnStdout: true).trim() env.GIT_COMMIT_MSG = sh(script: 'git log -1 --pretty=format:%s | sed -e \'s/"/\\"/g\'', returnStdout: true).trim() - // Jenkins构建次数 - def buildNumber = env.BUILD_NUMBER // Jenkins内置变量,直接获取当前Job的构建序号 - // 当前分支名(处理/为-,如feature/docker_1015 → feature-docker_1015) + + def buildNumber = env.BUILD_NUMBER def branchName = sh(script: 'git rev-parse --abbrev-ref HEAD', returnStdout: true).trim() - def formattedBranch = branchName.replace('/', '-').replace('_', '-') // 替换分支名中的/和_为- - // 构建时间(格式:202510181215,年-月-日-时-分,无分隔符) + def formattedBranch = branchName.replace('/', '-').replace('_', '-') def buildTime = sh(script: 'date +%Y%m%d%H%M', returnStdout: true).trim() - // 最终Tag(格式:v+构建次数_分支名_短哈希_构建时间) - env.IMAGE_TAG = "v${buildNumber}_${formattedBranch}_${GIT_COMMIT_SHORT}_${buildTime}" + def defaultTag = "v${buildNumber}_${formattedBranch}_${GIT_COMMIT_SHORT}_${buildTime}" + + def customTag = params.CUSTOM_TAG?.trim() + def tagPattern = ~/^[a-zA-Z0-9._-]+$/ + + if (customTag && customTag ==~ tagPattern) { + echo "✅ 使用自定义镜像 Tag: ${customTag}" + env.IMAGE_TAG = customTag + } else if (customTag) { + echo "⚠️ 自定义 Tag '${customTag}' 不符合规范,将使用默认生成的 Tag: ${defaultTag}" + + def confirmed = true + timeout(time: 1, unit: 'MINUTES') { + try { + input( + message: """⚠️ Tag 命名不规范: + ${customTag} + + 将使用自动生成的 Tag: + ${defaultTag} + + 是否继续构建?""", + ok: '确认' + ) + } catch (err) { + // 用户点击“取消”或中断 + echo "🚫 用户取消构建" + confirmed = false + } + } + + if (confirmed) { + echo "✅ 用户确认使用自动生成的 Tag:${defaultTag}" + env.IMAGE_TAG = defaultTag + } else { + error("流水线已终止。") + } + } else { + env.IMAGE_TAG = defaultTag + echo "未输入自定义 Tag, 使用自动生成规则: ${env.IMAGE_TAG}" + } } } }