微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决在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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?