jenkins构建触发器之Build whenever a snapshot dependency is built
整合项目上线时,运维大哥创建好Jenkins任务后,发现在构建BOSS开工、智能出行、整合这三个项目其中一个Jenkins任务时,会同时构建其他的Jenkins任务。
先介绍一下大背景儿:整合项目是一个新项目。整合项目是将BOSS开工、智能出行两个业务线系统所具有的公共的业务功能整合到一起,减轻运营工作量和技术维护成本。这样,系统间的逻辑结构变成了BOSS开工、智能出行会依赖整合系统的一部分接口,整合系统会依赖BOSS开工、智能出行的一部分接口。这些局域网系统是用dubbo实现rpc调用,所以,项目间会相互依赖彼此的接口契约jar。
如下图,三个构建任务test_omsbase-rpcapi-module、test_bosskg-interface-module、test_car-pub-module-interface所构建的是三个项目的接口契约module,通过构建只是maven install到Jenkins服务器的本地仓库,给这三个项目的应用服务程序提供jar依赖。
整合之前发版时构建BOSS开工、智能出行的任务时都很正常。为什么加上整合项目的Jenkins任务后,会出现这种“构建乱象”呢?
如下是任务构建时出现的“乱象”:
解决办法:
在Jenkins任务配置的“构建触发器”里,去掉勾选Build whenever a snapshot dependency is built。
原来,BOSS开工、智能出行、整合这三个项目的artifact的版本都是snapshot(IDEA新建工程时,pom文件默认指定的项目版本是1.0.1-SNAPSHOT),这个选项的意思是:只要快照依赖任务被构建,就构建当前任务。
就是说,[P1]项目依赖[P2]项目的一个快照版本的module[M],如果[P1]和[M]都有Jenkins构建任务时,那么,当[M]任务构建时,就会触发[P1]任务的构建。
所以,就不难理解上文的“构建乱象”了。
如果不需要这样,那解决办法,自然是不启用这一项了。当然,把项目版本变更成release也未尝不可。
附Jenkins几种构建触发器(Build Triggers)解释:
Build whenever a snapshot dependency is built
当job依赖的快照版本被build时,执行本job。
Build after other projects are built
当本job依赖的job被build时,执行本job
Build periodically
隔一段时间build一次,不管版本库代码是否发生变化。
Poll SCM
隔一段时间比较一次源代码如果发生变更,那么就build。否则,不进行build。
whenever
英 [wenˈevə(r)] 美 [wenˈevər]
conj.
在任何…的时候;无论何时;在任何…的情况下;每当;每次;别的什么时候(也可以);任何时间(都行)
当看到一些不好的代码时,会发现我还算优秀;当看到优秀的代码时,也才意识到持续学习的重要!--buguge
本文来自博客园,转载请注明原文链接:https://www.cnblogs.com/buguge/p/12874411.html