• Python-Jenkins 在 Jenkins 中的应用


    original

    Author:rab

    Python 版本:3.9

    Jenkins 版本:2.409

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



    前言

    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
    
    • 1

    2、安装 Python-Jenkins 包

    pip install python-jenkins
    
    • 1

    image-20230915141833839

    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))
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    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
    • 3
    1.2.2 获取当前用户的所有 Job
    jobs = server.get_jobs()
    
    # 通过get_jobs()方法获取当前用户所有工程(作业)
    
    • 1
    • 2
    • 3
    1.2.3 获取指定的 Job 配置信息

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

    my_job = server.get_job_config('test')
    
    # 通过get_job_config()方法来获取test这个job的配置信息
    
    • 1
    • 2
    • 3
    1.2.4 构建指定的 Job
    server.build_job('newjob')
    
    # 通过build_job()方法来构建newjob这个job
    
    • 1
    • 2
    • 3

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

    server.build_job('param-test', {'param1': 'first param value', 'param2': 'second param value'})
    
    # 在job中我们就可以使用param1、param2这两个参数对应的值了
    
    • 1
    • 2
    • 3
    1.2.5 禁用指定的 Job
    server.disable_job('newjob')
    
    # 通过disable_job()来禁用newjob这个job
    
    • 1
    • 2
    • 3
    1.2.6 复制指定的 Job
    server.copy_job('newjob', 'newjob_copy')
    
    # 通过copy_job()方法,将newjob工程复制并命名为newjob_copy
    
    • 1
    • 2
    • 3
    1.2.7 启用指定的 Job
    server.enable_job('newjob_copy')
    
    # 通过enable_job()函数来启用newjob_copy这个job
    
    • 1
    • 2
    • 3
    1.2.8 重置指定的 Job
    server.reconfig_job('newjob_copy', jenkins.RECONFIG_XML)
    
    # 通过reconfig_job()方法将newjob_copy重置配置
    
    • 1
    • 2
    • 3
    1.2.9 删除指定的 Job

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

    server.delete_job('newjob')
    server.delete_job('newjob_copy')
    
    # 通过delete_job()方法删除newjob和newjob_copy
    
    • 1
    • 2
    • 3
    • 4

    以上片段代码整合如下:

    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)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    先来看看效果:

    • Linux 控制台输出

      image-20230915154822525

    • Jenkins 控制台输出

      image-20230915154931687

    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等
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    image-20230915160258112

    1.2.11 获取视图中的所有 Job
    jobs = server.get_jobs(view_name='dev')
    print(jobs)
    
    # 通过get_job()方法来获取指定的试图下的所有job信息
    
    • 1
    • 2
    • 3
    • 4

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

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

    image-20230915161717213

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

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

    image-20230915161436645

    1.3 管理 Jenkins view

    1.3.1 创建视图(自定义)
    server.create_view('devops', jenkins.EMPTY_VIEW_CONFIG_XML)
    
    # 通过create_view()方法来创建自定义视图(且为一个空的视图配置)
    
    • 1
    • 2
    • 3

    image-20230915162724523

    1.3.2 获取指定视图配置信息
    view_config = server.get_view_config('devops')
    print(view_config)
    
    • 1
    • 2

    image-20230915162829315

    1.3.3 获取所有视图列表

    image-20230915163115593

    1.3.4 删除指定视图
    server.delete_view('devops')
    
    # 删除名为devops的视图
    
    • 1
    • 2
    • 3

    image-20230915163428283

    1.4 管理 Jenkins 插件

    plugins = server.get_plugins_info()
    print(plugins)
    
    # 通过get_plugins_info()方法来获取当前jenkins安装的所有插件
    
    • 1
    • 2
    • 3
    • 4

    下图为部分截图

    image-20230915163926339

    二、总结

    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
      
      • 1
    • 降低 urllib3 版本(我采用的是这种方法)

      pip install urllib3==1.26.6
      
      • 1

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

  • 相关阅读:
    WEB开发技能树-PHP-用户登录
    产品思维训练 | 如何让更多人用支付宝点外卖?
    ARM体系结构与汇编语言
    青少年python系列 35.自定义函数
    python内置魔术方法(616)
    买电脑常识——电脑性能
    Dockerfile
    每日五问(java)
    Java项目:ssm实验室设备管理系统
    如何对SQuAD1.1数据集进行预处理「详解版」
  • 原文地址:https://blog.csdn.net/IT_ZRS/article/details/132908985