Jenkins在slave节点中构建日志

时间:2018-06-13 07:35:45

标签: jenkins jenkins-plugins jenkins-slave jenkins-groovy

我正在尝试将我们的jenkins构建日志推送到S3。 我在构建阶段

中使用了Groovy插件和以下脚本
// This script should be run in a system groovy script build step.

// The FilePath class understands what node a path is on, not just the path.
import hudson.FilePath

// Get path to console log file on master.
logFile = build.getLogFile()

// Turn this into a FilePath object.
logFilePathOnMaster = new FilePath(logFile)

logFileName = build.envVars["JOB_BASE_NAME"] + build.envVars["RT_RELEASE_STAGING_VERSION"]  + '.txt'

// Create remote file path obj to build agent.
remoteLogFile = new FilePath(build.workspace, logFileName)

// Copy contents of master's console log to file on build agent.
remoteLogFile.copyFrom(logFilePathOnMaster)

然后我使用S3插件将.txt文件推送到S3。

但是此脚本从主节点获取构建日志文件。 构建日志如何从从节点传输到主节点? 我是否可以访问我的从属节点上的构建日志文件而无需主人参与?

从属节点在构建某个地方时必须保留构建日志吗?我似乎无法找到它。

1 个答案:

答案 0 :(得分:0)

我对Groovy不太熟悉,但这是使用Shell脚本为我工作的解决方案。 我正在使用Jenkins的“节点和标签参数插件”在从属节点上运行我们的java进程。使用“ Build >> Execute Shell”选项触发作业。日志收集到如下文件中:

    sudo java  -jar xxx.jar | sudo tee -a ${JOB_NAME}/${BUILD_NUMBER}.log 2>&1

然后将该日志文件推送到S3:

    sudo aws --region ap-south-1  s3  cp ${JOB_NAME}/${BUILD_NUMBER}.log  s3://bucket/JenkinsLogs/${JOB_NAME}/${BUILD_NUMBER}.log

它非常适合我们。希望它对您也有帮助。