Jenkinsfile 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. @Library('jenkins-share-library@master')
  2. def qyWechatRobot = new org.devops.notification.QYWechatRobot()
  3. pipeline {
  4. agent {
  5. node {
  6. label 'master'
  7. }
  8. }
  9. // tools { node '' }
  10. // parameters {}
  11. environment {
  12. _fullDisplayName = "幼享乐-Web管理后台"
  13. _qyWechatRobotToken = "a47cb467-8e94-4877-b275-832cc1f0d9af"
  14. _remote = "root@47.97.230.53"
  15. _buildTime = new Date().format('yyyyMMddHHmmss') // 生成当前时间戳
  16. _git_tag = sh(returnStdout: true, script: 'git describe --tags --always').trim()
  17. _git_branch = sh(returnStdout: true, script: 'echo ${GIT_BRANCH#*/}').trim()
  18. _git_commit_email = sh(returnStdout: true, script: 'git --no-pager show -s --format=\'%ae\'').trim()
  19. _git_commit_message = sh (script: 'git log -1 --pretty=%B ${GIT_COMMIT}', returnStdout: true).trim()
  20. _productFileName = "yxl-web-admin-frontend_${_git_branch}_${_buildTime}.tar.gz" // 产物文件名
  21. _productPath = '/app/yxl/admin-frontend' // 产物启动目录
  22. _productBackupPath = '/app/backup/yxl/admin-frontend' // 产物备份目录
  23. }
  24. triggers {
  25. // cron('0 0 * * *') // cron计划任务定期执行构建
  26. // pollSCM('H/1 * * * *') // pollSCM与cron定义类似,但由Jenkins定期检测源码变化
  27. // upstream( // upstream接受逗号分割的工作字符串和阀值。当字符串中的任何作业以最小阀值结束时,流水线被重新触发。
  28. // upstreamProjects: 'job1, job2',
  29. // threshold: hudson.model.Result.SUCCESS
  30. // )
  31. gitlab(
  32. triggerOnPush: true,
  33. triggerOnMergeRequest: true,
  34. triggerOnNoteRequest: true,
  35. branchFilterType: 'All',
  36. secretToken: 'asdfghjkl'
  37. )
  38. }
  39. options {
  40. timestamps() // 添加日志打印时间
  41. // checkoutToSubdirectory('sub') // Jenkins默认拉取源码至工作空间的根目录中,此选项可以指定检出到工作空间的子目录中
  42. disableConcurrentBuilds() // 同一个pipeline,Jenkins默认是可以同时执行多次的,此选项为了禁止pipeline同时执行
  43. // skipDefaultCheckout() // 删除隐式checkuot scm语句
  44. retry(1) // 当发生失败时进行重试(包括第1次失败)
  45. buildDiscarder(
  46. logRotator(
  47. daysToKeepStr: '30', // 构建记录将保存的天数
  48. numToKeepStr: '10', // 最多此数目的构建记录将被保存
  49. artifactDaysToKeepStr: '30', // 比此早的发布包将被删除,但构建的日志、操作历史、报告等将被保留
  50. artifactNumToKeepStr: '10' // 最多此数目的构建将保留他们的发布包
  51. )
  52. )
  53. timeout( // 流水线超时设置
  54. time: 15, // 整型
  55. unit: 'MINUTES', // 时间单位,默认分钟。支持NANOSECONDS,MICROSECONDS,MILLISECONDS,SECONDS,MINUTES(默认),HOURS,DAYS
  56. activity: true // 布尔类型,true时 只有当日志没活动才算真正的超时
  57. )
  58. gitLabConnection('gitlab') // 连接gitlab服务(需要在Jenkins中设置Jenkins -> Configure System)
  59. }
  60. post {
  61. always { // 不论当前完成状态是什么,都执行
  62. cleanWs() // 清理工作空间插件[Workspace Cleanup Plugin](https://plugins.jenkins.io/ws-cleanup)
  63. }
  64. success { // 成功后执行
  65. updateGitlabCommitStatus name: 'build', state: 'success'
  66. script {
  67. qyWechatRobot.endBuild('构建成功😀', _qyWechatRobotToken)
  68. }
  69. }
  70. failure { // 失败后执行
  71. updateGitlabCommitStatus name: 'build', state: 'failed'
  72. script {
  73. qyWechatRobot.endBuild('构建失败🤬', _qyWechatRobotToken)
  74. }
  75. }
  76. aborted { // 取消后执行
  77. script {
  78. qyWechatRobot.endBuild('构建取消🤯', _qyWechatRobotToken)
  79. }
  80. }
  81. }
  82. stages {
  83. stage('Start Notification') {
  84. steps {
  85. script {
  86. qyWechatRobot.startBuild(_qyWechatRobotToken)
  87. }
  88. }
  89. }
  90. stage('Env & Param') {
  91. parallel {
  92. stage('Env') {
  93. steps {
  94. sh 'printenv'
  95. echo "系统当前用户 [${env.USER}]"
  96. echo "JENKINS_URL [${env.JENKINS_URL}]"
  97. echo "WORKSPACE [${env.WORKSPACE}]"
  98. }
  99. }
  100. stage('Job') {
  101. steps {
  102. echo "-------------------- --------------------"
  103. echo "JOB_NAME [${env.JOB_NAME}]"
  104. echo "BUILD_NUMBER [${env.BUILD_NUMBER}]"
  105. echo "BUILD_URL [${env.BUILD_URL}]"
  106. echo "BUILD_NUMBER [${env.BUILD_NUMBER}]"
  107. echo "-------------------- --------------------"
  108. echo "BRANCH_NAME [${env.BRANCH_NAME}]"
  109. echo "GIT_BRANCH [${env.GIT_BRANCH}]"
  110. echo "GIT_COMMIT [${env.GIT_COMMIT}]"
  111. echo "GIT_COMMIT [${env.commit}]"
  112. echo "_git_tag [${_git_tag}]"
  113. echo "_git_branch [${_git_branch}]"
  114. echo "-------------------- --------------------"
  115. echo "产物名称 [${_productFileName}]"
  116. sh "node -v"
  117. sh "npm -v"
  118. }
  119. }
  120. }
  121. }
  122. stage('Install') {
  123. steps {
  124. sh 'npm install'
  125. }
  126. }
  127. stage('Static Check') {
  128. parallel {
  129. stage('eslint') {
  130. steps {
  131. echo 'eslint'
  132. }
  133. }
  134. }
  135. }
  136. stage('Build') {
  137. steps {
  138. sh 'npm run build:prod'
  139. }
  140. }
  141. stage('Product') {
  142. steps {
  143. dir("${env.WORKSPACE}/dist") {
  144. sh "tar -zcvf ${env.WORKSPACE}/${_productFileName} ./"
  145. }
  146. archiveArtifacts(
  147. artifacts: '*.tar.gz', // 字符串类型,需要归档的文件路径,使用的是Ant风格路径表达式。
  148. // excludes: '', // 字符串类型,需要排除的文件路径,使用的也是Ant风格路径表达式。
  149. caseSensitive: true, // 布尔类型,对路径大小写是否敏感。
  150. fingerprint: true, // 布尔类型,是否对归档的文件进行签名。
  151. onlyIfSuccessful: true // 布尔类型,只在构建成功时进行归档。
  152. )
  153. }
  154. }
  155. stage('Pre-Release') {
  156. steps {
  157. script {
  158. if ("${_git_branch}" == 'master') {
  159. echo "当前分支为:[${_git_branch}], 准备发布ing..."
  160. } else {
  161. error("当前分支为:[${_git_branch}], 终止当前发布操作...")
  162. }
  163. }
  164. }
  165. }
  166. stage('Release') {
  167. parallel {
  168. stage('master分支') {
  169. when {
  170. branch 'master' // 仅在多分支Pipeline有效
  171. }
  172. steps {
  173. script {
  174. echo '准备发布ing...'
  175. sh """
  176. ssh ${_remote} "
  177. source /etc/profile
  178. mkdir -pv ${_productBackupPath}
  179. mkdir -pv ${_productPath}
  180. "
  181. """
  182. sh "scp -r ${WORKSPACE}/${_productFileName} ${_remote}:${_productBackupPath}"
  183. sh """
  184. ssh ${_remote} "
  185. source /etc/profile
  186. rm -rf ${_productPath}/*
  187. touch ${_productPath}/${_buildTime}.log
  188. tar -zxvf ${_productBackupPath}/${_productFileName} -C ${_productPath}
  189. "
  190. """
  191. }
  192. }
  193. }
  194. }
  195. }
  196. }
  197. }