![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=1739237927-uOnACHsqnZlqQu4ZuvRt7my1aGzaBGXv-0-d93cc1412f59caf8536ea547311c2db3)
• checkoutToSubdirectory:Jenkins从版本控制库拉取源码时,默认检出到工作空间的根目录中,此选项可以指定检出到工作空间的子目录中。示例如下:
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/36_2.jpg?sign=1739237927-2CaOSqpLVSuoFUyzpiyWV1WJRwqUfuJY-0-762d922be481949d271c50bf4bee4c5d)
• disableConcurrentBuilds:同一个pipeline,Jenkins默认是可以同时执行多次的,如图3-2所示。此选项是为了禁止pipeline同时执行。示例如下:
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/36_3.jpg?sign=1739237927-J9vwsfV1RQmkl8WaMxnPoKh1I9JPoPlm-0-19332c9e8d20b5f307e17a4a0e8e5812)
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_1.jpg?sign=1739237927-h358ike7zxJLTx6yaNZCyIiDDjgLzsr6-0-852769fe716cc62e9c62551d269cc382)
图3-2 设置disableConcurrentBuilds选项前
在某些pipeline存在抢占资源或调用冲突的场景下,此选项非常有用。设置此选项后,如图3-3所示。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_2.jpg?sign=1739237927-jyJrHDxy6SS3oAfLwXFRgWLMHd3ZoHsA-0-f834a2e951ef7e3c70488e6f7cc3f7dd)
图3-3 设置disableConcurrentBuilds选项后
• newContainerPerStage:当agent为docker或dockerfile时,指定在同一个Jenkins节点上,每个stage都分别运行在一个新的容器中,而不是所有stage都运行在同一个容器中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/37_3.jpg?sign=1739237927-HK56U1AyAHTc6KWl3kgEtM5MvfgwBmYl-0-faf29407cf7ced2f65931a7d54879467)
• retry:当发生失败时进行重试,可以指定整个pipeline的重试次数。需要注意的是,这个次数是指总次数,包括第1次失败。以下例子总共会执行4次。当使用retry选项时,options可以被放在stage块中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/38_1.jpg?sign=1739237927-Vz3CqHU921E3hPY3PN3yR4uTEgo52Hiq-0-8ab133ae03b5ae5b4c529fa0f301dd56)
• timeout:如果 pipeline 执行时间过长,超出了我们设置的 timeout 时间,Jenkins 将中止pipeline。以下例子中以小时为单位,还可以以 SECONDS(秒)、MINUTES(分钟)为单位。当使用timeout选项时,options可以被放在stage块中。
![](https://epubservercos.yuewen.com/29EDEB/13898202705417506/epubprivate/OEBPS/Images/38_2.jpg?sign=1739237927-jI7VXZhfSPl3RPCRQQYrzHk6laK4puWk-0-24d579dca32c07d289eaa6ddac6715d7)
设置此选项后,强迫团队去处理执行时间过长的pipeline,从而优化pipeline的反馈周期。通常将timeout设置为10分钟就可以了。