jenkins api_接触Jenkins(Hudson)API,第1部分

jenkins api

哪一个-哈德森还是詹金斯?

都。 几个月前,我开始使用Hudson v1.395来从事这个小项目,在出现巨大分歧之后又回到了这个项目。 我以此为契机,看我将来选择永久搬到詹金斯时是否会遇到任何重大问题。 出现了一些麻烦-最值得注意的是,新的CLI jar不能立即使用,但是Jenkins的整体v1.401在切换后按预期工作。 好消息是旧版本的CLI jar仍然可以使用,因此此示例实际上是使用混合代码来完成工作。 无论如何,该软件非常出色,并且值得称赞的有余。

API

Jenkins / Hudson有一个便捷的远程API,其中包含有关您的构建的信息,并支持一组丰富的功能来远程控制它们以及整个服务器。 可以触发构建,复制作业,停止服务器,甚至远程安装插件。 与服务器的API交互时,可以选择XML,JSON或Python。 而且,正如内置文档中所述,您可以在以下位置的相对路径中找到所需的功能:

“ /.../api/,其中“ ...”部分是您要访问的对象”。

如果您在浏览器中导航到该页面,它将显示一个简短的文档页面,如果您将所需的格式添加为路径的最后一部分,则将返回结果。 例如,要加载有关运行本地托管Jenkins服务器的计算机的信息,对此URL的get请求将以JSON格式返回结果:http:// localhost:8080 / computer / api / json。

{'busyExecutors': 0,'displayName': 'nodes','computer': [{'idle': true,'executors': [{},{}],'actions': [],'temporarilyOffline': false,'loadStatistics': {},'displayName': 'master','oneOffExecutors': [],'manualLaunchAllowed': true,'offline': false,'launchSupported': true,'icon': 'computer.png','monitorData': {'hudson.node_monitors.ResponseTimeMonitor': {'average': 111},'hudson.node_monitors.ClockMonitor': {'diff': 0},'hudson.node_monitors.TemporarySpaceMonitor': {'size': 58392846336},'hudson.node_monitors.SwapSpaceMonitor': null,'hudson.node_monitors.DiskSpaceMonitor': {'size': 58392846336},'hudson.node_monitors.ArchitectureMonitor': 'Mac OS X (x86_64)'},'offlineCause': null,'numExecutors': 2,'jnlpAgent': false}],'totalExecutors': 2
}

这是使用GraphViz渲染的同一棵树。

此功能从服务器的根开始在树中扩展,您可以通过在URL上提供“ depth”参数来控制从任何特定分支加载的树的数量。 请注意您指定此变量的高度。 在人口众多,运行时间较长的构建服务器(数十个具有数千个作业执行的构建)上进行了四个负载深度的测试,从而为我定期超时。 为了让您有个想法,这里是api根深3处的域的非常粗略的可视化。

从服务器中取出数据非常简单,但是远程触发服务器上的活动的能力更加有趣。 为了触发名为“ test”的作业的构建,http:// localhost:8080 / job / test / build上的POST执行了该作业。 使用可用的设施,很容易做到:

  • 加载作业的配置文件,对其进行修改并通过发布新的config.xml文件来创建新作业
  • 将作业从一台构建机器移至另一台
  • 建立计划的构建概述

CLI Jar

还有另一种方法可以在与服务器一起分发的CLI jar中远程驱动构建服务器。 这个jar提供了用于在构建服务器上远程执行某些命令的简单工具。 值得注意的是,这使远程安装插件和执行远程Groovy Shell成为可能。 我将这个功能与CLI罐公开的主类的非常薄的包装程序结合在一起,如下一个代码示例所示。

/*** Drive the CLI with multiple arguments to execute.* Optionally accepts streams for input, output and err, all of which* are set by default to System unless otherwise specified.* @param rootUrl* @param args* @param input* @param output* @param err* @return*/
def runCliCommand(String rootUrl, List<String> args, InputStream input = System.in,OutputStream output = System.out, OutputStream err = System.err)
{def CLI cli = new CLI(rootUrl.toURI().toURL())cli.execute(args, input, output, err)cli.close()
}

这是一个简单的测试,展示了如何执行Groovy脚本以加载有关作业的信息,类似于您可以从服务器上内置的Groovy脚本控制台执行的操作,该操作可在http:/本地安装的部署中找到。 / localhost:8080 / script。

def 'should be able to query hudson object through a groovy script'()
{final ByteArrayOutputStream output = new ByteArrayOutputStream()when:api.runCliCommand(rootUrl, ['groovysh', 'for(item in hudson.model.Hudson.instance.items) { println('job $item.name')}'],System.in, output, System.err)then:println output.toString()output.toString().split('\n')[0].startsWith('job')
}

如果您想了解更多信息,下面是一些有关CLI的文章链接:

  • 哈德逊CLI Wikidoc
  • Jenkins CLI Wikidoc
  • Jenkins上PHP作业的模板
  • 川口浩辅的文章
  • 一个不错的教程

HTTPBuilder

如今 ,当针对HTTP API进行编程时, HTTPBuilder是我选择的工具。 用法非常简单,我只能使用两种方法来支持到达整个API:一种用于GET,一种用于POST。 这是GET方法,足以执行请求,解析JSON响应并完成(尽管很幼稚)错误处理。

/*** Load info from a particular rootUrl+path, optionally specifying a 'depth' query* parameter(default depth = 0)** @param rootUrl the base url to access* @param path  the api path to append to the rootUrl* @param depth the depth query parameter to send to the api, defaults to 0* @return parsed json(as a map) or xml(as GPathResult)*/
def get(String rootUrl, String path, int depth = 0)
{def statusHTTPBuilder http = new HTTPBuilder(rootUrl)http.handler.failure = { resp ->println 'Unexpected failure on $rootUrl$path: ${resp.statusLine} ${resp.status}'status = resp.status}def infohttp.get(path: path, query: [depth: depth]) { resp, json ->info = jsonstatus = resp.status}info ?: status
}

调用它来获取数据是一个内衬,因为唯一的真正区别是调用API时使用的“路径”变量。

private final GetRequestSupport requestSupport = new GetRequestSupport()...
/*** Display the job api for a particular Hudson job.* @param rootUrl the url for a particular build* @return job info in json format*/
def inspectJob(String rootUrl, int depth = 0)
{requestSupport.get(rootUrl, API_JSON, depth)
}

从技术上讲,这里没有什么可以将其限制为仅JSON。 HTTPBuilder的一大优点是,它将很高兴地尝试对响应进行正确的处理。 如果返回的数据为JSON格式(如以下示例所示),则将其解析为JSONObject。 另一方面,如果数据是XML,则将其解析为Groovy GPathResult。 尽管导航对象图的语法不同,但它们都很容易导航。

你能做什么呢?

探索Hudson / Jenkins API的主要动机是了解如何使管理多台服务器变得更加容易。 目前,我每天处理四台构建服务器和另一台从属计算机,并支持各种不同版本的分支。 这包括单元测试套件和功能测试套件的混合,以及连续部署的作业,该作业定期将更改推送到与我们支持的平台矩阵匹配的测试机上,因此,不幸的是,事情并没有分支时复制单个作业那么简单。 确实,以自动或至少半自动的方式为新功能分支创建构建基础结构确实很有吸引力,尤其是因为正在计划扩展构建自动化。 对于最近的555天项目,我利用API层构建了Grails应用程序,该应用程序既可以作为跨服务器构建的辐射器,又可以用作服务器管理的中央设施。 此概念证明能够连接到多个构建服务器,并可视化作业数据以及特定的系统配置,触发构建,并直接链接到每个连接的服务器,以允许进一步钻取。 这是几个样机,几乎可以显示图片。

只是一个非常酷的应用程序,用于安装Jenkins

这只是非常间接的关系,但是我遇到了一个非常漂亮且简单的Griffon应用程序,称为Jenkins-Assembler ,它简化了构建服务器的准备工作。 它为您提供了一系列插件,让您选择并选择,然后下载并将它们组合成一个可部署的战争。

足够多的讨论–代码在哪里???

与本文相关的源代码可在github上找到 。 这些测试更多地是对实时API的探索,而不是对该项目中代码的实际测试。 它们在使用Gradle Jetty插件启动的本地服务器上运行。 最后,这是一些适合您的漂亮图片。
[以幻灯片显示]
[使用PicLens查看]

继续第2部分 。

参考:在The Kaptain on…博客上,从我们的JCG合作伙伴 Kelly Robinson接触到Jenkins(Hudson)API 。


翻译自: https://www.javacodegeeks.com/2012/08/hooking-into-jenkins-hudson-api-part-1.html

jenkins api

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/353852.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux下面调试C、C++

(1)写好makefile文件&#xff08;支持debug&#xff09; objects Main.o Satellite.o TimeSystem.o SRPPara:$(objects) g -g -o SRPPara $(objects)Main.o:SRPPara.h Satellite.h TimeSystem.h g -c -g Main.cppSatellite.o:Satellite.h TimeSystem.h g -c -g Satellite.cpp…

Swing应用程序中的JavaFX 8 DatePicker

1.概述 本文显示了一个使用JavaFX 8 DatePicker控件的Java SE 8 Swing应用程序的示例。 DatePicker控件允许用户以文本形式输入日期或从日历弹出窗口中选择日期。 本示例使用其中带有FX控件的Swing JFrame 。 为了将FX内容嵌入Swing应用程序中&#xff0c; javafx.embed.swing…

java 中的override overload 比较

java 中的override & overload 比较 很久没看Java&#xff0c;忘记override和overload的区别了。百度了一下&#xff0c;把一个小弟的文章抄下来&#xff0c;备用。 方法的重写&#xff08;Overiding&#xff09;和重载&#xff08;Overloading&#xff09;是Java多态性的…

Apache Bench安装与使用

转载&#xff1a;ApacheBench&#xff08;ab&#xff09;使用详解 一、Apache Bench简介 ApacheBench 是 Apache 服务器自带的一个web压力测试工具&#xff0c;简称ab。ab又是一个命令行工具&#xff0c;对发起负载的本机要求很低&#xff0c;根据ab命令可以创建很多的并发访问…

[virtualenvwrapper] 命令小结

创建环境 mkvirtualenv env1mkvirtualenv env2环境创建之后&#xff0c;会自动进入该目录&#xff0c;并激活该环境。 切换环境 workon env1workon env2列出已有环境 workon退出环境 deactivate删除环境 rmvirtualenv创建project 项目将创建到PROJECT_HOME目录下&#xff0c;实…

轻松搭建一个Windows SVN服务器

轻松搭建一个Windows SVN服务器 前文所述SVN客户端使用的时候&#xff0c;用的SVN服务器通常为外部&#xff0c;例如Google Code的服务器&#xff0c;不过&#xff0c;做为一个程序开发人员&#xff0c;就算自己一个人写程序&#xff0c;也应该有一个SVN版本控制系统&#xff0…

cobertura覆盖率_Cobertura和Maven:集成和单元测试的代码覆盖率

cobertura覆盖率在姜黄项目中&#xff0c;我们每晚维护一个仪表板。 在仪表板上&#xff0c;我们收集有关项目的统计信息&#xff0c;包括代码覆盖率&#xff0c;findbugs分析和其他指标。 我们一直在使用Maven EMMA插件来提供代码覆盖&#xff0c;但是遇到了EMMA问题。 在对类…

人工智能常用 API

人工智能常用 API 转载 2016年07月13日 19:17:272047机器学习与预测 1、AlchemyAPI 在把数据由非结构化向结构化的转化中运用得较多。用于社交媒体监控、商业智能、内容推荐、金融交易和定向广告等。2、Alina一个加入了Alina的混搭网站展示了这一API在使用基因算法和人工神经…

TortoiseSVN使用帮助和下载

TortoiseSVN使用帮助和下载 随着应用软件的开发规模及复杂程度日趋大型化&#xff0c;使得软件开发模式从早期的个人作坊式渐渐转变为团队协作开发方式&#xff0c;在这种团队协作的开发模式&#xff0c;为了管理好开发项目&#xff0c;就离不开版本控制软件&#xff0c;在开发…

Spring框架中的内容协商

1.简介 使用BeanNameViewResolver完成的工作就是&#xff0c;我们刚刚在Spring上下文中创建了多个bean视图以生成预期的输出。 Spring很快引入了内容协商策略 &#xff0c;该策略可以使用传统的RESTful ResponseBody方法和HTTP消息转换器&#xff0c;以JSON或XML返回所需的输出…

对npm的认识

npm由三个不同的组件组成&#xff1a;1&#xff0c;网站 2.命令行界面&#xff08;CLI&#xff09;3.注册表 需要在网站注册 命令行界面用来进行交互 注册表来进行保存 安装本地软件包 npm install 包名 更新本地软件包 npm update 包名 卸载本地软件包 npm uninstall …

Ubuntu中安装Eclipse的SVN插件——subclipse

Ubuntu中安装Eclipse的SVN插件——subclipse (2010-07-01 18:38)分类&#xff1a; Linux安装好Eclipse以后 进入菜单Help->Install new Software...->add...地址选择&#xff0c;如果安装的Eclipse版本是3.2以上 恐怕没人装旧版的了&#xff0c;那么使用如下地址http://s…

logging配置

settings.py # Django的日志配置项BASE_LOG_DIR os.path.join(BASE_DIR, "log")LOGGING {version: 1, # 保留字disable_existing_loggers: False, # 禁用已经存在的logger实例# 日志文件的格式formatters: {# 详细的日志格式standard: {format: [%(asctime)s][%(…

定制Spring Data JPA存储库

Spring Data是一个非常方便的库。 但是&#xff0c;由于该项目是一个相当新的项目&#xff0c;因此功能不佳。 默认情况下&#xff0c;Spring Data JPA将基于SimpleJpaRepository提供DAO的实现。 在最近的项目中&#xff0c;我开发了一个定制的存储库基类&#xff0c;以便可以在…

ubuntu+eclipse+svn

ubuntueclipsesvn 2010-06-23 16:02:32| 分类&#xff1a; 默认分类 |字号 订阅 昨天装了一天的CVS,但是始终无法启动CVSD&#xff0c;防火墙也没有开&#xff0c;不知道是什么原因&#xff0c;无奈之下只好转向了SVN&#xff0c;也当是学习一下&#xff5e;&#xff5e;&…

Log4j 2.x XSD的描述不完整

在博客文章JAXB和Log4j XML配置文件中 &#xff0c;我讨论了“与使用JAXB通过Java类处理[Log4j 1.x和Log4j 2.x] XML配置文件相关的细微差别。” 在本文中&#xff0c;我将探讨另一个与通过Log4j 2.x XML Schema文件Log4j-config.xsd生成的JAXB对象生成Log4j 2.x配置XML相关的挑…

Protobuf学习笔记

Protobuf学习笔记 Posted by iamxhuon 2012/05/22 Leave a comment (0)Go to commentsProtocol buffers是什么&#xff1f; 首先了解一下Protocol Buffers(简称ProtoBuf)是什么&#xff1f;官网对它的定义如下&#xff1a; Protocol buffers are Google’s language-neutral, …

如何掌握Java内存(并保存程序)

通过AppDynamics解决应用程序问题的速度提高了10倍–以最小的开销在代码级深度监视生产应用程序。 开始免费试用&#xff01; 您花了无数小时来研究Java应用程序中的错误并在需要的地方获得其性能。 在测试期间&#xff0c;您注意到应用程序随着时间的推移逐渐变慢&#xff0c…

程序集版本号

程序集版本号分为4段&#xff0c;例如1.0.4.23。 第一段为主版本号&#xff0c;项目一但启动则不会更改。 第二段为次版本号&#xff0c;在项目功能做较大调整时增加&#xff0c;增量为1。 第三段为修订版本号&#xff0c;通常在解决缺陷或者细微功能变化时增加&#xff0c;增量…

py-kms使用方法

搭建py-kms服务器,先下载py-kms https://github.com/myanaloglife/py-kms 启动py-kms服务(需要服务器安装有python): python server.py 这样py-kms服务就启动好了,如果需要后台运行可以制作deamon脚本。 py-kms可以激活企业/专业版vl windows系统和vol版本的office软件: window…