Jenkinsfile 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. pipeline {
  2. agent any
  3. parameters {
  4. choice(name: 'env', choices: ['dev', 'test', 'prod'], description: '部署环境')
  5. string(name: 'NAMESPACE', defaultValue: 'portal-frontends', description: 'K8s 命名空间')
  6. }
  7. environment {
  8. PROJECT_NAME = 'portal-service-frontend'
  9. NODE_ENV = 'production'
  10. HARBOR_HOST = '8.130.28.21:81'
  11. KUBECONFIG_PATH = '/root/.kube/config'
  12. NODE1_IP = '172.27.73.147'
  13. NODE2_IP = '172.27.73.146'
  14. HARBOR_USER = 'admin'
  15. HARBOR_PASS = 'Hfln@1024'
  16. HARBOR_RETENTION_ID = '1'
  17. }
  18. stages {
  19. stage('🧬 初始化环境') {
  20. steps {
  21. script {
  22. env.HARBOR_PROJECT = params.env
  23. env.IMAGE_TAG = "${env.HARBOR_HOST}/${env.HARBOR_PROJECT}/${env.PROJECT_NAME}:${BUILD_NUMBER}"
  24. echo ">>> 环境:${params.env}, Harbor项目:${env.HARBOR_PROJECT}, K8s命名空间:${params.NAMESPACE}"
  25. echo ">>> IMAGE_TAG = ${env.IMAGE_TAG}"
  26. echo ">>> 请使用以下镜像标签手动创建 Kubernetes 资源:"
  27. echo ">>> ${env.IMAGE_TAG}"
  28. }
  29. }
  30. }
  31. stage('📥 拉取代码') {
  32. steps {
  33. checkout scm
  34. echo "✅ 代码拉取成功"
  35. }
  36. }
  37. stage('🔧 构建 Docker 镜像') {
  38. steps {
  39. script {
  40. sh """
  41. docker login -u ${env.HARBOR_USER} -p ${env.HARBOR_PASS} ${env.HARBOR_HOST}
  42. docker build --build-arg ENV=${params.env} -t ${env.IMAGE_TAG} .
  43. """
  44. echo "✅ 镜像构建成功:${env.IMAGE_TAG}"
  45. }
  46. }
  47. }
  48. stage('🚀 推送镜像到 Harbor') {
  49. steps {
  50. script {
  51. sh """
  52. docker push ${env.IMAGE_TAG}
  53. docker rmi ${env.IMAGE_TAG} || true
  54. """
  55. echo "✅ 镜像推送并本地清理完成"
  56. }
  57. }
  58. }
  59. stage('🔍 测试节点能否拉取镜像') {
  60. steps {
  61. script {
  62. echo ">>> 测试节点能否拉取镜像..."
  63. sh """
  64. ssh root@${env.NODE1_IP} "docker login -u ${env.HARBOR_USER} -p ${env.HARBOR_PASS} ${env.HARBOR_HOST} && docker pull ${env.IMAGE_TAG}" || echo '[❌ 节点 ${env.NODE1_IP} 拉取失败]'
  65. ssh root@${env.NODE2_IP} "docker login -u ${env.HARBOR_USER} -p ${env.HARBOR_PASS} ${env.HARBOR_HOST} && docker pull ${env.IMAGE_TAG}" || echo '[❌ 节点 ${env.NODE2_IP} 拉取失败]'
  66. """
  67. }
  68. }
  69. }
  70. stage('🧹 清理本地旧镜像(保留最新3个)') {
  71. steps {
  72. script {
  73. def baseImage = "${env.HARBOR_HOST}/${env.HARBOR_PROJECT}/${env.PROJECT_NAME}"
  74. sh """
  75. docker images ${baseImage} --format "{{.Repository}}:{{.Tag}}" \\
  76. | grep -v latest \\
  77. | sort -r -t ':' -k2 \\
  78. | tail -n +4 \\
  79. | xargs -r docker rmi || true
  80. """
  81. echo "✅ 本地旧镜像清理完成"
  82. }
  83. }
  84. }
  85. stage('🧼 清理 dangling 镜像') {
  86. steps {
  87. script {
  88. sh """
  89. docker images -f "dangling=true" -q | xargs -r docker rmi || true
  90. """
  91. echo "✅ 悬空镜像(<none>)清理完成"
  92. }
  93. }
  94. }
  95. stage('🔁 触发 Harbor 镜像保留策略(可选)') {
  96. steps {
  97. script {
  98. sh """
  99. curl -u ${env.HARBOR_USER}:${env.HARBOR_PASS} -X POST "http://${env.HARBOR_HOST}/api/v2.0/retentions/${env.HARBOR_RETENTION_ID}/executions" || echo '[retention trigger failed]'
  100. """
  101. echo "✅ Harbor 镜像保留策略已触发(若配置)"
  102. }
  103. }
  104. }
  105. }
  106. post {
  107. success {
  108. echo "✅ 构建 & 推送成功 🎉"
  109. echo ">>> 请手动创建 Kubernetes 资源:"
  110. echo ">>> 1. 创建命名空间:kubectl create ns ${params.NAMESPACE}"
  111. echo ">>> 2. 创建 TLS Secret:kubectl create secret tls portal-tls --cert=/data/cert/radar-power.asia.pem --key=/data/cert/radar-power.asia.key -n ${params.NAMESPACE}"
  112. echo ">>> 3. 应用 YAML 配置:kubectl apply -f k8s-deploy.yaml"
  113. }
  114. failure {
  115. echo "❌ 构建或推送失败,请检查日志"
  116. }
  117. always {
  118. cleanWs()
  119. }
  120. }
  121. }