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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值