[作者:Surpassme]本篇主要介绍日常使用Jenkins过程中一些比较实用的功能。
[作者:Surpassme]假设在一个Jenkins中有两个彼此独立的任务,但随着迭代不断更新,两个彼此独立的任务需要相互调用。这时候我们可以在一个任务中,添加另一个任务的步骤。除这种方法,还有没有其他的办法呢?
[作者:Surpassme]既然在Jenkins存在参数化的pipeline,则应该是可以支持在一个pipeline中调用另一个pipeline。而要实现这个功能,在pipeline中可以使用build步骤来实现。看起来是不是与upsteam非常相似,主要区别如下所示:
[作者:Surpassme]build 使用用法示例如下所示:
steps{
build(
job:"jobName",
parameters:[
paramsType(name:"name",value:"value")
],
propagate:true,
quietPeriod:3,
wait:true
)
}
[作者:Surpassme]build 步骤的两个基本参数如下所示:
必填参数,目标任务的名称可选参数,目标任务的传入参数列表,使用方法与参数化命令parameters类似。可选参数,布尔类型。若值为true,则只有当下游pipeline的运行结果状态为SUCCESS时,上游pipeline才算成功,若值为false,则忽略下游pipeline的运行结果状态,上游pipeline都忽略。默认为true可选参数,整型。触发下游pipeline后,下游pipeline等待多久执行。如果不设置,则等待时长由下游pipeline确定,单位为秒可选参数,布尔类型,是否等待下游pipeline运行完成。默认为truechoice类型的参数没有对应的传参方法,使用
string传参方法代替
[作者:Surpassme]假设现在有两个job,分别为SurpassA和SurpassB,上游为SurpassA,下游为SurpassB
pipeline{
agent any
options{
timestamps()
}
parameters{
string(
name:"stringDemo",
defaultValue:"job string SurpassB",
description:"job SurpassB string demo"
)
text(
name:"textDemo",
defaultValue:"job text SurpassA\njob text SurpassB\njob text SurpassC",
description:"job SurpassB text demo"
)
booleanParam(
name:"booleanDemo",
defaultValue:true,
description:"job SurpassB boolean demo"
)
choice(
name:"choiceDemo",
choices:["SurpassA","SurpassB","SurpassC"],
description:"job SurpassB choice demo"
)
password(
name:"passwdDemo",
defaultValue:"job passwd SurpassB",
description:"job SurpassB password demo"
)
}
stages{
stage("job SurpassB demo"){
steps{
echo "job SurpassB demo"
}
}
}
}
pipeline{
agent any
options{
timestamps()
}
stages{
stage("call inner jobs demo"){
steps{
echo "call inner job SurpassB"
build(
job:"39-SurpassB",
parameters:[
string(name:"stringDemo",value:"input text by SurpassA"),
text(name:"textDemo",value:"input text by SurpassB"),
booleanParam(name:"booleanDemo",value:false),
string(name:"choiceDemo",value:"SurpassB"),
password(name:"passwdDemo",value:"Surpass")
]
)
}
}
}
}
最终运行结果如下所示:

[作者:Surpassme]前面演示的在同一个Jenkins,内部相互调用不同任务的pipeline,那如果是两个不同服务节点的Jenkins有没有相互调用呢?答案是可以的。
通过远程Jekins调用本地Jenkins,演示的环境如下所示:
| Jenkins Server | 描述信息 |
|---|---|
| 192.168.188.133 | 本地Jenkins |
| 192.168.188.132 | 远程Jenkins |
操作步骤如下所示:
触发远程构建,并设置相应的Token,如下所示:


运行结果如下所示:

pipeline{
agent any
options{
timestamps()
}
stages{
stage("remote call pipeline demo"){
steps{
script{
def url="Surpass:110313acfb17c8b2058f9816d5b6062455@192.168.188.133:9090/job/39-SurpassB/buildWithParameters?token=surpass-local&stringDemo=SurpassRemote&textDemo=SurpassRemote&booleanDemo=true&choiceDemo=SurpassB&passwdDemo=SurpassRemote"
sh(
script:"curl -X POST \'${url}\'",
returnStatus:true
)
}
}
}
}
}
[作者:Surpassme]运行结果如下所示:

[作者:Surpassme]Jenkins 的所有数据都是存放在文件中。因此Jenkins备份也就是备份JENKINS_HOME目录。其目录结构大致如下所示:
其中jobs的文件目录结构如下所示:
jobName: 以Jenkins 项目名称做为文件夹名称
- config.xml: 该项目对应的配置文件,里面存储有相应的pipeline
- nextBuildNumber:存放下一次构建的构建号,为文本文件
- builds:每次构建内容
[作者:Surpassme]并不是所有内容都需要备份,一般来讲,只需要备份jobs和plugins目录即可。
原文地址:https://www.jianshu.com/p/56aeeaa39fa4
本文同步在微信订阅号上发布,如各位小伙伴们喜欢我的文章,也可以关注我的微信订阅号:woaitest,或扫描下面的二维码添加关注:

很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
只是想确保我理解了事情。据我目前收集到的信息,Cucumber只是一个“包装器”,或者是一种通过将事物分类为功能和步骤来组织测试的好方法,其中实际的单元测试处于步骤阶段。它允许您根据事物的工作方式组织您的测试。对吗? 最佳答案 有点。它是一种组织测试的方式,但不仅如此。它的行为就像最初的Rails集成测试一样,但更易于使用。这里最大的好处是您的session在整个Scenario中保持透明。关于Cucumber的另一件事是您(应该)从使用您的代码的浏览器或客户端的角度进行测试。如果您愿意,您可以使用步骤来构建对象和设置状态,但通常您
我需要一些关于TDD概念的帮助。假设我有以下代码defexecute(command)casecommandwhen"c"create_new_characterwhen"i"display_inventoryendenddefcreate_new_character#dostufftocreatenewcharacterenddefdisplay_inventory#dostufftodisplayinventoryend现在我不确定要为什么编写单元测试。如果我为execute方法编写单元测试,那不是几乎涵盖了我对create_new_character和display_invent
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
导读:随着叮咚买菜业务的发展,不同的业务场景对数据分析提出了不同的需求,他们希望引入一款实时OLAP数据库,构建一个灵活的多维实时查询和分析的平台,统一数据的接入和查询方案,解决各业务线对数据高效实时查询和精细化运营的需求。经过调研选型,最终引入ApacheDoris作为最终的OLAP分析引擎,Doris作为核心的OLAP引擎支持复杂地分析操作、提供多维的数据视图,在叮咚买菜数十个业务场景中广泛应用。作者|叮咚买菜资深数据工程师韩青叮咚买菜创立于2017年5月,是一家专注美好食物的创业公司。叮咚买菜专注吃的事业,为满足更多人“想吃什么”而努力,通过美好食材的供应、美好滋味的开发以及美食品牌的孵
运行bundleinstall后出现此错误:Gem::Package::FormatError:nometadatafoundin/Users/jeanosorio/.rvm/gems/ruby-1.9.3-p286/cache/libv8-3.11.8.13-x86_64-darwin-12.gemAnerroroccurredwhileinstallinglibv8(3.11.8.13),andBundlercannotcontinue.Makesurethat`geminstalllibv8-v'3.11.8.13'`succeedsbeforebundling.我试试gemin
我从Ubuntu服务器上的RVM转移到rbenv。当我使用RVM时,使用bundle没有问题。转移到rbenv后,我在Jenkins的执行shell中收到“找不到命令”错误。我内爆并删除了RVM,并从~/.bashrc'中删除了所有与RVM相关的行。使用后我仍然收到此错误:rvmimploderm~/.rvm-rfrm~/.rvmrcgeminstallbundlerecho'exportPATH="$HOME/.rbenv/bin:$PATH"'>>~/.bashrcecho'eval"$(rbenvinit-)"'>>~/.bashrc.~/.bashrcrbenvversions
前置步骤我们都操作完了,这篇开始介绍jenkins的集成。话不多说,看操作1、登录进入jenkins后会让你选择安装插件,选择第一个默认的就行。安装完成后设置账号密码,重新登录。2、配置JDK和Git都需要执行路径,所以需要先把执行路径找到,先进入服务器的docker容器,2.1JDK的路径root@69eef9ee86cf:/usr/bin#echo$JAVA_HOME/usr/local/openjdk-82.2Git的路径root@69eef9ee86cf:/#whichgit/usr/bin/git3、先配置JDK和Git。点击:ManageJenkins>>GlobalToolCon