jenkins workpase优化清理

概述

由于jenkins pipline脚本是通用的,可以发布上百个java项目,但是这些微服务执行job时,共用了一个Workspaces路径。

 

就会产生一个问题,当执行微服务a时,正好在执行mvn命令,编译jar包。这个时候,同时执行微服务b时,就会覆盖当前Workspaces的文件。

那么微服务a编译jar包,就会失败。

为了避免这个问题,解决方法就是,每执行一个job时,就创建一个当前build number的子目录,当前这个job就在子目录中运行。

由于build number每次执行时,会自动增加,且是唯一的。

就不会出并发执行job时,产生目录冲突问题。

 

workspaces子目录

修改pipline脚本,在执行每一个steps时,增加dir即可,例如:

stage("Code Preparation") {
  steps {
	dir("$BUILD_NUMBER"){
	  git branch: 'master', credentialsId: credentialsId, url: "http://xxx.git"
	}
  }
}

BUILD_NUMBER,是Jenkins的内置全局变量,表示构建id

 

workpase空间清理

当job执行次数时,比如BUILD_NUMBER,增加到上百上时,此时workpase空间会越来越大,因此需要设置策略,保留最近一段时间的。

 

点击job,进行设置,保留最近30天的,最大保留60个构建记录

勾选Discard old builds

Days to keep builds设置为30

Max # of builds to keep设置为60

 

上面的pipline创建的workpase子目录,这个策略对此不生效。

因此子目录需要用的手段来清理。

 

在pipline的末尾,增加一个步骤,清理workpase子目录

stage("clean workspace") {
	steps {
		dir("$BUILD_NUMBER"){
			cleanWs() // 清理工作空间
		}
		sh "rm -rf ${BUILD_NUMBER}@tmp"
	}
}

这样就可以彻底清理workpase子目录

 

posted @ 2024-08-18 11:04  肖祥  阅读(81)  评论(0编辑  收藏  举报