Python-Jenkins 在 Jenkins 中的应用

Python-Jenkins 在 Jenkins 中的应用_第1张图片

Author:rab

Python 版本:3.9

Jenkins 版本:2.409

官方文档:https://python-jenkins.readthedocs.io/en/latest/


目录

    • 前言
    • 一、案例
      • 1.1 管理 Jenkins Version
      • 1.2 管理 Jenkins Job
        • 1.2.1 普通创建 Job
        • 1.2.2 获取当前用户的所有 Job
        • 1.2.3 获取指定的 Job 配置信息
        • 1.2.4 构建指定的 Job
        • 1.2.5 禁用指定的 Job
        • 1.2.6 复制指定的 Job
        • 1.2.7 启用指定的 Job
        • 1.2.8 重置指定的 Job
        • 1.2.9 删除指定的 Job
        • 1.2.10 获取指定 Job 最后一次构建信息
        • 1.2.11 获取视图中的所有 Job
      • 1.3 管理 Jenkins view
        • 1.3.1 创建视图(自定义)
        • 1.3.2 获取指定视图配置信息
        • 1.3.3 获取所有视图列表
        • 1.3.4 删除指定视图
      • 1.4 管理 Jenkins 插件
    • 二、总结
    • FAQ


前言

Python-Jenkins 是一个用于与 Jenkins CI(持续集成)服务器进行交互的 Python 三方包。它提供了一组功能丰富的 API,使开发人员能够通过 Python 脚本与 Jenkins 进行通信和操作。

Python-Jenkins 插件的主要用途包括:

  1. 自动化构建和部署:通过 Python-Jenkins,编写脚本来触发 Jenkins Jobs 的构建和部署过程。
  2. 监控和管理 Jenkins 作业:Python-Jenkins 能够获取有关 Jenkins Jobs 的信息,如构建状态、构建日志等。
  3. 配置管理:同时 Python-Jenkins 还可以创建、修改和删除 Jenkins Jobs、视图、节点等。

简单理解就是,Python-Jenkins 工具为开发/运维等技术人员提供了一种方便的方式来与 Jenkins CI 服务器进行交互,从而实现自动化构建、部署和管理 Jenkins 作业的目的。

接下来,列举该工具一些常见的使用案例。

一、案例

1.1 管理 Jenkins Version

1、创建虚拟环境

mkvirtualenv myenv

2、安装 Python-Jenkins 包

pip install python-jenkins

Python-Jenkins 在 Jenkins 中的应用_第2张图片

3、编写代码

import jenkins

server = jenkins.Jenkins('http://192.168.56.142:8888', username='admin', password='zhurs@123')
user = server.get_whoami()
version = server.get_version()
print('当前登录用户为:%s \nJenkins版本为:%s' % (user['fullName'], version))

4、执行结果

image-20230915145418959

1.2 管理 Jenkins Job

1.2.1 普通创建 Job

server.create_job('newjob', jenkins.EMPTY_CONFIG_XML)

# 通过create_job()方法创建newjob工程(且默认配置为空的XML配置)

1.2.2 获取当前用户的所有 Job

jobs = server.get_jobs()

# 通过get_jobs()方法获取当前用户所有工程(作业)

1.2.3 获取指定的 Job 配置信息

我 jenkins 原本就已经创建了一个 test 的工程,那此时我们就可以通过 get_job_config() 方法来获取这个 job 的配置信息。

my_job = server.get_job_config('test')

# 通过get_job_config()方法来获取test这个job的配置信息

1.2.4 构建指定的 Job

server.build_job('newjob')

# 通过build_job()方法来构建newjob这个job

我们也可以在构建时向 job 传递指定的参数:

server.build_job('param-test', {'param1': 'first param value', 'param2': 'second param value'})

# 在job中我们就可以使用param1、param2这两个参数对应的值了

1.2.5 禁用指定的 Job

server.disable_job('newjob')

# 通过disable_job()来禁用newjob这个job

1.2.6 复制指定的 Job

server.copy_job('newjob', 'newjob_copy')

# 通过copy_job()方法,将newjob工程复制并命名为newjob_copy

1.2.7 启用指定的 Job

server.enable_job('newjob_copy')

# 通过enable_job()函数来启用newjob_copy这个job

1.2.8 重置指定的 Job

server.reconfig_job('newjob_copy', jenkins.RECONFIG_XML)

# 通过reconfig_job()方法将newjob_copy重置配置

1.2.9 删除指定的 Job

删除就不演示了,你也看不见效果。

server.delete_job('newjob')
server.delete_job('newjob_copy')

# 通过delete_job()方法删除newjob和newjob_copy

以上片段代码整合如下:

import jenkins

server = jenkins.Jenkins('http://192.168.56.142:8888', username='admin', password='zhurs@123')
user = server.get_whoami()
version = server.get_version()
print('当前登录用户为:%s \nJenkins版本为:%s' % (user['fullName'], version))

server.create_job('newjob', jenkins.EMPTY_CONFIG_XML)
jobs = server.get_jobs()
print("当前账户的所有job列表:\n", jobs)
my_job = server.get_job_config('test')
print("test工程的配置信息为:\n", my_job)
server.build_job('newjob')
server.disable_job('newjob')
server.copy_job('newjob', 'newjob_copy')
server.enable_job('newjob_copy')
server.reconfig_job('newjob_copy', jenkins.RECONFIG_XML)

先来看看效果:

  • Linux 控制台输出

    Python-Jenkins 在 Jenkins 中的应用_第3张图片

  • Jenkins 控制台输出

    Python-Jenkins 在 Jenkins 中的应用_第4张图片

1.2.10 获取指定 Job 最后一次构建信息

last_build_number = server.get_job_info('test')['lastCompletedBuild']['number']
build_info = server.get_build_info('test', last_build_number)
print(build_info)

# 通过build_job()方法来获取test这个job最后一次的构建信息
# 其内容包括构建用户、构建ID、构建URL等

image-20230915160258112

1.2.11 获取视图中的所有 Job

jobs = server.get_jobs(view_name='dev')
print(jobs)

# 通过get_job()方法来获取指定的试图下的所有job信息

先看看我 jenkins 中有哪些视图,及视图下有哪些 job

可见,dev 视图下有一个名为 test 的 job

Python-Jenkins 在 Jenkins 中的应用_第5张图片

最后来验证是否正确获取到指定视图下的内容

内容正确获取并打印到标准输出

image-20230915161436645

1.3 管理 Jenkins view

1.3.1 创建视图(自定义)

server.create_view('devops', jenkins.EMPTY_VIEW_CONFIG_XML)

# 通过create_view()方法来创建自定义视图(且为一个空的视图配置)

Python-Jenkins 在 Jenkins 中的应用_第6张图片

1.3.2 获取指定视图配置信息

view_config = server.get_view_config('devops')
print(view_config)

Python-Jenkins 在 Jenkins 中的应用_第7张图片

1.3.3 获取所有视图列表

image-20230915163115593

1.3.4 删除指定视图

server.delete_view('devops')

# 删除名为devops的视图

Python-Jenkins 在 Jenkins 中的应用_第8张图片

1.4 管理 Jenkins 插件

plugins = server.get_plugins_info()
print(plugins)

# 通过get_plugins_info()方法来获取当前jenkins安装的所有插件

下图为部分截图

Python-Jenkins 在 Jenkins 中的应用_第9张图片

二、总结

  1. Python-Jenkins 是一个用于与 Jenkins CI(持续集成)服务器进行交互的 Python 三方工具包;
  2. 以上案例只是其中的一部分,作为一个简单的入门理解,想要了解更多内容,可以查看其官方文档或 Jenkins 的 REST API;
  3. 我认为这作为日常 API 调用时是很方便的,想要实现完整的 Pipeline,还是得学好 Pipeline 语法/Groovy 语法

FAQ

urllib3 包所需 ssl 模块 openssl 版本过低

提示需要 openssl 1.1.1+ 以上,但是当前为 1.0.2,有两种方法:

  • 升级 openssl 版本

    pip install openssl@1.1
    
  • 降低 urllib3 版本(我采用的是这种方法)

    pip install urllib3==1.26.6
    

注意:这个 openssl 不是你的宿主机的 openssl 而是你的 Python 环境中的 openssl。

你可能感兴趣的:(CICD,python,jenkins)