0
点赞
收藏
分享

微信扫一扫

Jenkins教程:使用python获取jenkins构建过程中的日志


要使用Python获取Jenkins构建过程中的实时日志,您可以使用Jenkins API和Python的requests库来实现。下面是一个基本示例:

import time
import requests

def get_build_console_log(job_name, build_number, jenkins_url, username, password):
    # 构建的URL
    build_url = f"{jenkins_url}/job/{job_name}/{build_number}/consoleText/api/json"

    # 发送HTTP请求获取日志
    response = requests.get(build_url, auth=(username, password), stream=True)

    # 检查请求是否成功
    if response.status_code == 200:
        # 逐行读取日志
        for line in response.iter_lines(decode_unicode=True):
            if line:
                # 输出日志行
                print(line)

                # 延迟一段时间,模拟实时读取
                time.sleep(0.1)
    else:
        print(f"Failed to get build console log. Status code: {response.status_code}")

# 示例用法
job_name = "your_job_name"
build_number = 123
jenkins_url = "http://your_jenkins_url"
username = "your_username"
password = "your_password"

get_build_console_log(job_name, build_number, jenkins_url, username, password)

在上述示例中,get_build_console_log 函数使用Jenkins API获取构建的控制台日志。它接受以下参数:

  • job_name: Jenkins作业(Job)的名称。
  • build_number: 构建号码。
  • jenkins_url: Jenkins服务器的URL。
  • username: 登录Jenkins所需的用户名。
  • password: 登录Jenkins所需的密码。

函数发送HTTP GET请求到Jenkins的API端点,并使用stream=True参数以流的方式逐行读取日志。然后,它逐行打印日志行,并通过time.sleep函数添加了一些延迟,以模拟实时读取的效果。

您需要将示例中的参数替换为实际的值,包括Jenkins作业名称、构建号码、Jenkins服务器的URL以及登录所需的用户名和密码。


举报

相关推荐

0 条评论