buguge - Keep it simple,stupid

知识就是力量,但更重要的,是运用知识的能力why buguge?

导航

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.
在任何…的时候;无论何时;在任何…的情况下;每当;每次;别的什么时候(也可以);任何时间(都行)

posted on 2020-05-12 10:01  buguge  阅读(5613)  评论(0编辑  收藏  举报