使用Python脚本执行期间如何读取Jenkins管道控制台输出?

时间:2019-09-02 05:32:59

标签: python jenkins-pipeline

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

1 个答案:

答案 0 :(得分:1)

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

在Blue Ocean URL中的一个阶段,当您单击该阶段时,将以节点号表示。例如,在URL 24中,节点号为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) 。在给定管道的特定阶段,该值保持不变。

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

示例Python脚本:

Skill,Fighter,Thief,Rogue
Armor-Heavy,2,4,3
Armor-Light,1,2,1
Armor-Medium,2,3,2