python jenkins库 api简介

Python Jenkins Guide: https://python-jenkins.readthedocs.io/en/latest/index.html
Python-jenkins: https://pypi.org/project/python-jenkins/
安装: pip install python-jenkins

API 介绍

  • 连接Jenkins服务器

server = jenkins.Jenkins(url, username=None, password=None, timeout=30)

url : 指的是所连接的Jenkins的网络地址
username/password : username/password 默认值是None, 在内网中不传参数也是可以连接成功的,但应该只有读的权限,没有操作权限。所以一般需要用户名和密码。

  • 账户信息

server.get_whoami()

获取连接账户的相关信息, 有关私密信息就不打印出来了

server.get_version()
'2.176.3'

获取连接Jenkins的版本信息

  • 获取job相关信息
    所谓job的话,指的是在Jenkins里面创建的一系列项目
# 获取所有的job信息
server.get_jobs()

# 获取job为name的基本信息
server.get_job_info(name)

#获取job名为name的job的最后次构建号, 不会计算排队中的构建, 
#例如正在构建的number是3, 在排队的有4和5, 那么最后次构建号是3
server.get_job_info(name)['lastBuild']['number']

# 正则匹配到相应job的基本信息
server.get_job_info_regex(pattern)

#判断job是否存在
server.job_exists(name)

#获取所有job的数量
server.jobs_count()
  • 获取build相关信息
    所谓build的话,指的是在Job里面的一次构建
# 获取某次构建信息,举例178, 如果178不存在或者正在排队中, 则会抛出异常
# JenkinsException: job[name] number[178] does not exist
server.get_build_info(name, 178)

# result指构建运行的状态, 构建如果是运行完成返回结果FAILURE/ABORTED/SUCCESS/UNSTABLE等
# 构建如果是正在运行返回结果 None
server.get_build_info(name, 178)['result']
  • 操作
    需要明确该账户在Jenkins中有对应的操作权限,否则在脚本中是无法做相应操作的
# 获取所有排队的build
server.get_queue_info()

# 获取所有正在运行的build
server.get_running_builds()

server.stop_build(name, number) # 停止正在运行的构建

  1. 停止掉queue排队中的构建, 直接抛出异常NotFoundException: Requested item could not be found
  2. 停止掉running运行中的构建, 无返回值, 无报错,在Jenkins页面上显示该构建被XXX 账户停掉了
  3. 停止掉stopped已经停止的构建, 无返回值, 无报错,Jenkins页面无变化

server.cancel_queue(id) # 配合server.get_queue_info()使用,得到排队构建的id, 可以取消该构建

  1. server.get_queue_info() 获取某个排队构建的id, 如123.
  2. 如果该构建排队中直接server.cancel_queue(123), 无返回值, 无报错,Jenkins页面上排队的构建直接被撤销,看不出原来有这么一个排队的构建
  3. 如果等排队的构建到运行状态, 使用server.cancel_queue(123), 无返回值, 无报错, 该构建依旧在运行中
  4. 如果等排队的构建到完成状态, 使用server.cancel_queue(123), 无返回值, 无报错, 该构建依旧为完成结束状态

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值