Dela via


Loggningskommandon

Azure DevOps Services | Azure DevOps Server 2022 – Azure DevOps Server 2019

Loggningskommandon är hur uppgifter och skript kommunicerar med agenten. De omfattar åtgärder som att skapa nya variabler, markera ett steg som misslyckat och ladda upp artefakter. Loggningskommandon är användbara när du felsöker en pipeline.

Viktigt!

Vi gör ett försök att maskera hemligheter från att visas i Azure Pipelines-utdata, men du måste fortfarande vidta försiktighetsåtgärder. Upprepa aldrig hemligheter som utdata. Vissa operativsystem loggar kommandoradsargument. Skicka aldrig hemligheter på kommandoraden. I stället föreslår vi att du mappar dina hemligheter till miljövariabler.

Vi maskerar aldrig understrängar av hemligheter. Om till exempel "abc123" anges som en hemlighet maskeras inte "abc" från loggarna. Detta är för att undvika maskering av hemligheter på en för detaljerad nivå, vilket gör loggarna olästa. Därför bör hemligheter inte innehålla strukturerade data. Om till exempel "{ "foo": "bar" }" har angetts som en hemlighet maskeras inte "bar" från loggarna.

Typ Kommandon
Uppgiftskommandon AddAttachment, Complete, LogDetail, LogIssue, PrependPath, SetEndpoint, SetProgress, SetVariable, SetSecret, UploadFile, UploadSummary
Artefaktkommandon Associera, ladda upp
Skapa kommandon AddBuildTag, UpdateBuildNumber, UploadLog
Versionskommandon UpdateReleaseName

Loggningskommandoformat

Det allmänna formatet för ett loggningskommando är:

##vso[area.action property1=value;property2=value;...]message

Det finns också några formateringskommandon med en något annorlunda syntax:

##[command]message

Om du vill anropa ett loggningskommando upprepar du kommandot via standardutdata.

#!/bin/bash
echo "##vso[task.setvariable variable=testvar;]testvalue"

Filsökvägar bör anges som absoluta sökvägar: rotade på en enhet i Windows eller från och med / i Linux och macOS.

Kommentar

Observera att du inte kan använda set -x kommandot före ett loggningskommando när du använder Linux eller macOS. Se felsökning för att lära dig hur du inaktiverar set -x tillfälligt för Bash.

Formateringskommandon

Kommentar

Använd UTF-8-kodning för loggningskommandon.

Dessa kommandon är meddelanden till loggformaterare i Azure Pipelines. De markerar specifika loggrader som fel, varningar, hopfällbara avsnitt och så vidare.

Formateringskommandona är:

##[group]Beginning of a group
##[warning]Warning message
##[error]Error message
##[section]Start of a section
##[debug]Debug text
##[command]Command-line being run
##[endgroup]

Du kan använda formateringskommandona i en bash- eller PowerShell-uppgift.

steps:
- bash: |
    echo "##[group]Beginning of a group"
    echo "##[warning]Warning message"
    echo "##[error]Error message"
    echo "##[section]Start of a section"
    echo "##[debug]Debug text"
    echo "##[command]Command-line being run"
    echo "##[endgroup]"

Dessa kommandon återges i loggarna så här:

Skärmbild av loggar med anpassade formateringsalternativ

Det här kommandoblocket kan också komprimeras och ser ut så här:

Skärmbild av komprimerat avsnitt av loggar

Uppgiftskommandon

LogIssue: Logga ett fel eller en varning

##vso[task.logissue]error/warning message

Förbrukning

Logga ett fel eller varningsmeddelande i tidslinjeposten för den aktuella aktiviteten.

Egenskaper

  • type = error eller warning (krävs)
  • sourcepath = källfilplats
  • linenumber = radnummer
  • columnnumber = kolumnnummer
  • code = fel- eller varningskod

Exempel: Logga ett fel

#!/bin/bash
echo "##vso[task.logissue type=error]Something went very wrong."
exit 1

Dricks

exit 1 är valfritt, men är ofta ett kommando som du kommer att utfärda strax efter att ett fel har loggats. Om du väljer Kontrollalternativ: Fortsätt vid felexit 1 resulterar det i en delvis lyckad version i stället för en misslyckad version. Du kan också använda task.logissue type=error.

Exempel: Logga en varning om en specifik plats i en fil

#!/bin/bash
echo "##vso[task.logissue type=warning;sourcepath=consoleapp/main.cs;linenumber=1;columnnumber=1;code=100;]Found something that could be a problem."

SetProgress: Visa att procentandelen har slutförts

##vso[task.setprogress]current operation

Förbrukning

Ange förlopp och aktuell åtgärd för den aktuella aktiviteten.

Egenskaper

  • value = procent av slutförande

Exempel

echo "Begin a lengthy process..."
for i in {0..100..10}
do
   sleep 1
   echo "##vso[task.setprogress value=$i;]Sample Progress Indicator"
done
echo "Lengthy process is complete."

Om du vill se hur det ser ut sparar du och köar bygget och tittar sedan på byggkörningen. Observera att en förloppsindikator ändras när aktiviteten kör det här skriptet.

Slutför: Tidslinje för slutförd

##vso[task.complete]current operation

Förbrukning

Slutför tidslinjeposten för den aktuella aktiviteten, ange aktivitetsresultat och aktuell åtgärd. När resultatet inte har angetts anger du resultatet till lyckades.

Egenskaper

  • result =
    • Succeeded Uppgiften lyckades.
    • SucceededWithIssues Uppgiften stötte på problem. Bygget slutförs i bästa möjliga mån som delvis slutfört.
    • Failed Bygget slutförs som misslyckat. (Om Kontrollalternativ: Alternativet Fortsätt vid fel har valts. Bygget slutförs i bästa fall som delvis slutfört.)

Exempel

Logga en uppgift som slutförd.

##vso[task.complete result=Succeeded;]DONE

Ange en aktivitet som misslyckad. Du kan också använda exit 1.

- bash: |
    if [ -z "$SOLUTION" ]; then
      echo "##vso[task.logissue type=error;]Missing template parameter \"solution\""
      echo "##vso[task.complete result=Failed;]"
    fi

LogDetail: Skapa eller uppdatera en tidslinjepost för en uppgift

##vso[task.logdetail]current operation

Förbrukning

Skapar och uppdaterar tidslinjeposter. Detta används främst internt av Azure Pipelines för att rapportera om steg, jobb och steg. Kunder kan lägga till poster i tidslinjen, men de visas vanligtvis inte i användargränssnittet.

Första gången vi ser ##vso[task.detail] under ett steg skapar vi en "detaljerad tidslinje"-post för steget. Vi kan skapa och uppdatera kapslade tidslinjeposter som bygger på id och parentid.

Uppgiftsförfattare måste komma ihåg vilket GUID de använde för varje tidslinjepost. Loggningssystemet håller reda på GUID för varje tidslinjepost, så alla nya GUID resulterar i en ny tidslinjepost.

Egenskaper

  • id = Tidslinjepostens GUID (krävs)
  • parentid = GUID för överordnad tidslinjepost
  • type = Posttyp (krävs för första gången, kan inte skriva över)
  • name = Postnamn (krävs för första gången, kan inte skriva över)
  • order = Ordningen på tidslinjeposten (krävs för första gången, kan inte skriva över)
  • starttime = Datetime
  • finishtime = Datetime
  • progress = procent av slutförande
  • state = Unknown | Initialized | InProgress | Completed
  • result = Succeeded | SucceededWithIssues | Failed

Exempel

Skapa en ny post för rottidslinjen:

##vso[task.logdetail id=new guid;name=project1;type=build;order=1]create new timeline record

Skapa ny kapslad tidslinjepost:

##vso[task.logdetail id=new guid;parentid=exist timeline record guid;name=project1;type=build;order=1]create new nested timeline record

Uppdatering finns tidslinjepost:

##vso[task.logdetail id=existing timeline record guid;progress=15;state=InProgress;]update timeline record

SetVariable: Initiera eller ändra värdet för en variabel

##vso[task.setvariable]value

Förbrukning

Anger en variabel i variabeltjänsten för taskcontext. Den första aktiviteten kan ange en variabel och följande aktiviteter kan använda variabeln. Variabeln exponeras för följande uppgifter som en miljövariabel.

När isSecret är inställt på truesparas värdet för variabeln som hemlighet och maskeras från loggen. Hemliga variabler skickas inte till aktiviteter som miljövariabler och måste i stället skickas som indata.

När isOutput är inställt true på syntaxen för att referera till den angivna variabeln varierar beroende på om du kommer åt variabeln i samma jobb, ett framtida jobb eller en framtida fas. Om är inställt isOutput på syntaxen för att använda variabeln inom samma jobb är dessutom false distinkt. Se nivåer av utdatavariabler för att fastställa lämplig syntax för varje användningsfall.

Mer information finns i ange variabler i skript och definiera variabler .

Egenskaper

  • variable = variabelnamn (obligatoriskt)
  • isSecret = booleskt värde (valfritt, standardvärdet falskt)
  • isOutput = booleskt värde (valfritt, standardvärdet falskt)
  • isReadOnly = booleskt värde (valfritt, standardvärdet falskt)

Exempel

Ange variabler:

- bash: |
    echo "##vso[task.setvariable variable=sauce;]crushed tomatoes"
    echo "##vso[task.setvariable variable=secretSauce;isSecret=true]crushed tomatoes with garlic"
    echo "##vso[task.setvariable variable=outputSauce;isOutput=true]canned goods"
  name: SetVars

Läs variablerna:

- bash: |
    echo "Non-secrets automatically mapped in, sauce is $SAUCE"
    echo "Secrets are not automatically mapped in, secretSauce is $SECRETSAUCE"
    echo "You can use macro replacement to get secrets, and they'll be masked in the log: $(secretSauce)"

Konsolutdata:

Non-secrets automatically mapped in, sauce is crushed tomatoes
Secrets are not automatically mapped in, secretSauce is 
You can use macro replacement to get secrets, and they'll be masked in the log: ***
Future jobs can also see canned goods
Future jobs can also see canned goods

SetSecret: Registrera ett värde som en hemlighet

##vso[task.setsecret]value

Förbrukning

Värdet registreras som en hemlighet under hela jobbet. Värdet maskeras från loggarna från och med nu. Det här kommandot är användbart när en hemlighet transformeras (t.ex. base64-kodad) eller härledd.

Obs! Tidigare förekomster av det hemliga värdet maskeras inte.

Exempel

Ange variabler:

- bash: |
    NEWSECRET=$(echo $OLDSECRET|base64)
    echo "##vso[task.setsecret]$NEWSECRET"
  name: SetSecret
  env:
    OLDSECRET: "SeCrEtVaLuE"

Läs variablerna:

- bash: |
    echo "Transformed and derived secrets will be masked: $(echo $OLDSECRET|base64)"
  env:
    OLDSECRET: "SeCrEtVaLuE"

Konsolutdata:

Transformed and derived secrets will be masked: ***

SetEndpoint: Ändra ett tjänstanslutningsfält

##vso[task.setendpoint]value

Förbrukning

Ange ett tjänstanslutningsfält med angivet värde. Värdet som uppdateras behålls i slutpunkten för efterföljande aktiviteter som körs inom samma jobb.

Egenskaper

  • id = tjänstanslutnings-ID (krävs)
  • field = fälttyp, en av authParameter, dataParametereller url (krävs)
  • key = nyckel (krävs, om inte field = url)

Exempel

##vso[task.setendpoint id=000-0000-0000;field=authParameter;key=AccessToken]testvalue
##vso[task.setendpoint id=000-0000-0000;field=dataParameter;key=userVariable]testvalue
##vso[task.setendpoint id=000-0000-0000;field=url]https://example.com/service

AddAttachment: Bifoga en fil till bygget

##vso[task.addattachment]value

Förbrukning

Ladda upp och bifoga den bifogade filen till den aktuella tidslinjeposten. Dessa filer är inte tillgängliga för nedladdning med loggar. Dessa kan endast refereras till av tillägg med hjälp av typ- eller namnvärdena.

Egenskaper

  • type = typ av bifogad fil (krävs)
  • name = namn på bifogad fil (krävs)

Exempel

##vso[task.addattachment type=myattachmenttype;name=myattachmentname;]c:\myattachment.txt

UploadSummary: Lägg till lite Markdown-innehåll i byggsammanfattningen

##vso[task.uploadsummary]local file path

Förbrukning

Ladda upp och bifoga sammanfattning markdown från en .md-fil på lagringsplatsen till den aktuella tidslinjeposten. Den här sammanfattningen ska läggas till i bygg-/versionssammanfattningen och inte vara tillgänglig för nedladdning med loggar. Sammanfattningen ska vara i UTF-8- eller ASCII-format. Sammanfattningen visas på fliken Tillägg i pipelinekörningen. Markdown-rendering på fliken Tillägg skiljer sig från Azure DevOps wiki-rendering. Mer information om Markdown-syntax finns i Markdown-guiden.

Exempel

##vso[task.uploadsummary]$(System.DefaultWorkingDirectory)/testsummary.md

Det är ett kort formulär för kommandot

##vso[task.addattachment type=Distributedtask.Core.Summary;name=testsummaryname;]c:\testsummary.md

UploadFile: Ladda upp en fil som kan laddas ned med aktivitetsloggar

##vso[task.uploadfile]local file path

Förbrukning

Ladda upp användarintresserad fil som ytterligare logginformation till den aktuella tidslinjeposten. Filen ska vara tillgänglig för nedladdning tillsammans med uppgiftsloggar.

Exempel

##vso[task.uploadfile]c:\additionalfile.log

PrependPath: Förbered en sökväg till PATH-miljövariabeln

##vso[task.prependpath]local file path

Förbrukning

Uppdatera PATH-miljövariabeln genom att vänta till PATH. Den uppdaterade miljövariabeln återspeglas i efterföljande uppgifter.

Exempel

##vso[task.prependpath]c:\my\directory\path

Artefaktkommandon

Associera: Initiera en artefakt

##vso[artifact.associate]artifact location

Förbrukning

Skapa en länk till en befintlig artefakt. Artefaktplatsen måste vara en filcontainersökväg, VC-sökväg eller UNC-resurssökväg.

Egenskaper

  • artifactname = artefaktnamn (krävs)
  • type = artefakttyp (krävs) container | filepath | versioncontrol | gitref | tfvclabel

Exempel

  • behållare

    ##vso[artifact.associate type=container;artifactname=MyServerDrop]#/1/build
    
  • filepath

    ##vso[artifact.associate type=filepath;artifactname=MyFileShareDrop]\\MyShare\MyDropLocation
    
  • versioncontrol

    ##vso[artifact.associate type=versioncontrol;artifactname=MyTfvcPath]$/MyTeamProj/MyFolder
    
  • gitref

    ##vso[artifact.associate type=gitref;artifactname=MyTag]refs/tags/MyGitTag
    
  • tfvclabel

    ##vso[artifact.associate type=tfvclabel;artifactname=MyTag]MyTfvcLabel
    
  • Anpassad artefakt

    ##vso[artifact.associate artifactname=myDrop;artifacttype=myartifacttype]https://downloads.visualstudio.com/foo/bar/package.zip
    

Ladda upp: Ladda upp en artefakt

##vso[artifact.upload]local file path

Förbrukning

Ladda upp en lokal fil till en filcontainermapp och publicera en artefakt som artifactname.

Egenskaper

  • containerfolder = mapp som filen laddas upp till, skapas mappen om det behövs.
  • artifactname = artefaktnamn. (Obligatoriskt)

Exempel

##vso[artifact.upload containerfolder=testresult;artifactname=uploadedresult]c:\testresult.trx

Kommentar

Skillnaden mellan Artifact.associate och Artifact.upload är att den första kan användas för att skapa en länk till en befintlig artefakt, medan den senare kan användas för att ladda upp/publicera en ny artefakt.

Skapa kommandon

UploadLog: Ladda upp en logg

##vso[build.uploadlog]local file path

Förbrukning

Ladda upp användarintresserad logg för att skapa containermappen .logs\tool

Exempel

##vso[build.uploadlog]c:\msbuild.log

UpdateBuildNumber: Åsidosätt det automatiskt genererade versionsnumret

##vso[build.updatebuildnumber]build number

Förbrukning

Du kan automatiskt generera ett versionsnummer från token som du anger i pipelinealternativen. Men om du vill använda din egen logik för att ange versionsnumret kan du använda det här loggningskommandot.

Exempel

##vso[build.updatebuildnumber]my-new-build-number

AddBuildTag: Lägg till en tagg i versionen

##vso[build.addbuildtag]build tag

Förbrukning

Lägg till en tagg för aktuell version. Du kan expandera taggen med en fördefinierad eller användardefinierad variabel. Här läggs till exempel en ny tagg i en Bash-uppgift med värdet last_scanned-$(currentDate). Du kan inte använda ett kolon med AddBuildTag.

Exempel

- task: Bash@3
    inputs:
    targetType: 'inline'
    script: |
        last_scanned="last_scanned-$(currentDate)"
        echo "##vso[build.addbuildtag]$last_scanned"
    displayName: 'Apply last scanned tag'

Versionskommandon

UpdateReleaseName: Byt namn på aktuell version

##vso[release.updatereleasename]release name

Förbrukning

Uppdatera versionsnamnet för den version som körs.

Kommentar

Stöds i Azure DevOps och Azure DevOps Server från och med version 2020.

Exempel

##vso[release.updatereleasename]my-new-release-name