最近在工作中需要用到在后台代码中触发 Jenkins 任务的构建,于是想到 Jenkins 是否有一些已经封装好的 API 类库提供,用于处理跟 Jenkins 相关的操作。下面就简单介绍下我的发现。

Linux Curl

首先找到的是 Jenkins 官网的 wiki:https://wiki.jenkins-ci.org/display/JENKINS/Remote+access+API

在官网首页就有关于触发 job 的方法:

Linux Curl调用Jenkins Api

个人尝试了下,该方式是通过命令行直接调 curl 去发 POST 请求的方式来触发 job 的构建。对于用 openid 管理的 Jenkins,需要带上参数--user USER:PASSWORD,其中的 USER 和 PASSWORD 不是你的 openID 登录的账号密码,而是登录后显示在 Jenkins 中的 User Id 和 API Token,它们的的查看方式如下:

用 openID 登录 jenkins —> 点击右上角的用户名,进入用户个人页面 —> 点击左边的设置,打开设置页面 —> API Token,Show Api Token...

如果需要参数化构建 job,则要加上--data-urlencode json='{"parameter": [{"name":"param_name1","value":"param_value1"}, {"name":"param_name2","value":"param_value2"}]}'

显然,这种方式比较繁琐,很容易出现因格式不正确导致触发任务失败,而且这种方式不能帮助我们获取更多的关于 job 的信息以便于我们后续对 job 的状态进行跟踪。

Python-Jenkins

继续寻找,然后我在 Jenkins 官网上找到了 Python-Jenkins API,仔细阅读后发现,它几乎涵盖了大部分 Jenkins 的操作,大大方便了我们在后台进行对 Jenkins 的一些列操作。

Python-Jenkins 官网: https://pypi.python.org/pypi/python-jenkins/

Python-Jenkins Doc:http://python-jenkins.readthedocs.io/en/latest/index.html

下面简单介绍下如何使用 Python-Jenkins:

sudo pip install python-jenkins

import jenkins

#定义远程的jenkins master server的url,以及port

jenkins_server_url='xxxx:xxxx'

#定义用户的User Id 和 API Token,获取方式同上文

user_id='xxxx'

api_token='xxxx'

#实例化jenkins对象,连接远程的jenkins master server

server=jenkins.Jenkins(jenkins_server_url, username=user_id, password=api_token)

#构建job名为job_name的job(不带构建参数)

server.build_job(job_name)

#String参数化构建job名为job_name的job, 参数param_dict为字典形式,如:param_dict= {"param1":“value1”, “param2”:“value2”} 

server.build_job(job_name, parameters=param_dict)

#获取job名为job_name的job的相关信息

server.get_job_info(job_name)

#获取job名为job_name的job的最后次构建号

server.get_job_info(job_name)['lastBuild']['number']

#获取job名为job_name的job的某次构建的执行结果状态

server.get_build_info(job_name,build_number)['result']     

#判断job名为job_name的job的某次构建是否还在构建中

server.get_build_info(job_name,build_number)['building']


↙↙↙阅读原文可查看相关链接,并与作者交流