在Azure DevOps版本的多作业管道中检索特定生成任务的日志文件

问题描述

我们有Azure DevOps扩展,其中我们用来从发布生成日志中获取数据的构建任务之一显示在发布摘要选项卡中。 这个构建任务非常适合单个Agent Job管道,但是我们遇到了一个场景,即有多个Agent任务可用,并且一旦将构建任务添加到第二个或更高版本的Agent任务中,我们就无法检索数据。

enter image description here

下面是我们如何从任务日志中获取数据。但是,此方法仅迭代第一项工作,而不会访问第二项。 我们正在使用VSS SDK中“ ReleaseManagement / Core / RestClient”中的发布管理客户端

   //getting list of tasks
    var t = await rmClient.getTasks(VSS.getWebContext().project.id,release.id,environment.id);
    // iterate trough task list until required task found
    for (var i = 0; i < t.length; i++) {
        var currentTask = t[i];               
        
        var logData = await rmClient.getLog(VSS.getWebContext().project.id,environment.id,currentTask.id,environment.deploySteps.length);  

        // Identify task based on data in it
        break;
    }

根据SDK的实现,有两种方法可用于检索日志getlog,getlog以字符串形式返回任务日志(我们现在使用的一种),而getLogs以ArrayBuffer形式返回所有日志

/**
     * [Preview API] Gets logs
     *
     * @param {string} project - Project ID or project name
     * @param {number} releaseId - Id of the release.
     * @param {number} environmentId - Id of release environment.
     * @param {number} taskId - ReleaseTask Id for the log.
     * @param {number} attemptId - Id of the attempt.
     * @return IPromise<string>
     */
    getLog(project: string,releaseId: number,environmentId: number,taskId: number,attemptId?: number): IPromise<string>;
    /**
     * [Preview API] Get logs for a release Id.
     *
     * @param {string} project - Project ID or project name
     * @param {number} releaseId - Id of the release.
     * @return IPromise<ArrayBuffer>
     */
    getLogs(project: string,releaseId: number): IPromise<ArrayBuffer>;

如您所见,在这方法中没有位置指定代理作业。

如果有人对此有经验,

  1. 是否可以从发布管道中的第二个或更高版本的作业获取日志数据?样本/文档会很有帮助。
  2. 我试图从数组缓冲区中获取数据,但是当我尝试将ArrayBuffer转换为字符串时,它最终超出了边界错误

任何想法,请高度赞赏?

解决方法

要从“代理作业”获取任务日志,您还需要releaseDeployPhaseId。检查以下api:

https://docs.microsoft.com/en-us/rest/api/azure/devops/release/releases/get%20task%20log?view=azure-devops-rest-6.0

GET https://vsrm.dev.azure.com/{organization}/{project}/_apis/release/releases/{releaseId}/environments/{environmentId}/deployPhases/{releaseDeployPhaseId}/tasks/{taskId}/logs?api-version=6.0-preview.2

如本文档所述,您可以从扩展程序中调用REST API:

https://docs.microsoft.com/en-us/azure/devops/extend/develop/auth?view=azure-devops#calling-rest-apis-from-your-extension

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...