![Jenkins 2.x实践指南](https://wfqqreader-1252317822.image.myqcloud.com/cover/830/25449830/b_25449830.jpg)
3.5 配置pipeline本身
options指令用于配置整个Jenkins pipeline本身的选项。根据具体的选项不同,可以将其放在pipeline块或stage块中。以下例子若没有特别说明,options被放在pipeline块中。
(本节内容,初学者可跳过。)
接下来我们介绍常用的几个选项。
• buildDiscarder:保存最近历史构建记录的数量。当pipeline执行完成后,会在硬盘上保存制品和构建执行日志,如果长时间不清理会占用大量空间,设置此选项后会自动清理。此选项只能在pipeline下的options中使用。示例如下:
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/36_1.jpg?sign=1739683895-3tm4kDUwi7JrfCmdwRc1oZtP1UVFjmNl-0-e3017c258f37d83857c5e39550621027)
• checkoutToSubdirectory:Jenkins从版本控制库拉取源码时,默认检出到工作空间的根目录中,此选项可以指定检出到工作空间的子目录中。示例如下:
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/36_2.jpg?sign=1739683895-qi6fGq4kR62ajhr65TDtDjWMr7Tz424S-0-2843f9926c6f8df5c4aa2847a80888f6)
• disableConcurrentBuilds:同一个pipeline,Jenkins默认是可以同时执行多次的,如图3-2所示。此选项是为了禁止pipeline同时执行。示例如下:
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/36_3.jpg?sign=1739683895-zg81ivhyXr1aMMvqzjS99c5AjkME7Fix-0-d69f14fdbbc1d7650e91c46c38216f23)
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_1.jpg?sign=1739683895-258MDpSd1pnpOfvAKQg06Shh6LUprCJo-0-302272a83de5a71350fc27b62ba5e496)
图3-2 设置disableConcurrentBuilds选项前
在某些pipeline存在抢占资源或调用冲突的场景下,此选项非常有用。设置此选项后,如图3-3所示。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_2.jpg?sign=1739683895-sFNdFDxvQTiemI1XyIxlAoh53yDrLv9O-0-15a5f5814264ba688fa1055cf71c2dd0)
图3-3 设置disableConcurrentBuilds选项后
• newContainerPerStage:当agent为docker或dockerfile时,指定在同一个Jenkins节点上,每个stage都分别运行在一个新的容器中,而不是所有stage都运行在同一个容器中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_3.jpg?sign=1739683895-9S3UUNouitjMyfe780Q1YxUH4gfxk2W3-0-46273b42e13ed4276062c6616dc213b2)
• retry:当发生失败时进行重试,可以指定整个pipeline的重试次数。需要注意的是,这个次数是指总次数,包括第1次失败。以下例子总共会执行4次。当使用retry选项时,options可以被放在stage块中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/38_1.jpg?sign=1739683895-BoX4BbCHK6k7yBVRuyCvunarXnCor2Kg-0-1258f2fded157ccee86314a956eb1b5d)
• timeout:如果 pipeline 执行时间过长,超出了我们设置的 timeout 时间,Jenkins 将中止pipeline。以下例子中以小时为单位,还可以以 SECONDS(秒)、MINUTES(分钟)为单位。当使用timeout选项时,options可以被放在stage块中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/38_2.jpg?sign=1739683895-r2xXkBcBrUrlvNIwOxyeIh4fVxGBJHaV-0-b38744d9416d08afa35c461d911d9b6e)
设置此选项后,强迫团队去处理执行时间过长的pipeline,从而优化pipeline的反馈周期。通常将timeout设置为10分钟就可以了。