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