首页 > 解决方案 > 如何在使用 Python 脚本执行期间读取 Jenkins 管道控制台输出?

问题描述

我需要在管道执行期间读取前一阶段(管道)的控制台输出。上一阶段的控制台输出将输入到我在下一阶段运行的 python 脚本。请建议

标签: pythonjenkins-pipeline

解决方案


如果您使用 Blue Ocean 插件,您可以使用Blue Ocean REST API检索阶段式控制台输出。

当您单击该阶段时,Blue Ocean URL 中的阶段由节点号表示。例如,在 URL.../blue/organizations/jenkins/<job_name>/detail/<job_name>/<build_number>/pipeline/24中,节点号是24。对于给定管道中的特定阶段,此值保持不变。

假设您的作业具有匿名读取权限,在您的下游管道阶段,您可以调用 Python 脚本来读取任何前一阶段的控制台输出。

示例 Python 脚本:

import os
import requests
import urllib3
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)

current_build_num = os.environ['BUILD_NUMBER']
stage_url = 'https://<jenkins_base_url>/cdf/blue/rest/organizations/jenkins/pipelines/<job_name>/runs/{0}/nodes/<node_number>/log/'.format(current_build_num)
stage_log = requests.get(stage_url, verify=False).content
print(stage_log)

推荐阅读