파이프라인 기간 추세 샘플 보고서

Azure DevOps Services | Azure DevOps Server 2022 | Azure DevOps Server 2020

이 문서에서는 파이프라인이 정상적으로 완료되는 데 일반적으로 걸리는 시간을 보여 주는 보고서를 만드는 방법을 보여 줍니다. 파이프라인 기간 보고서의 일일 추세는 파이프라인 통과율 보고서의 파이프라인 속도 추세 차트와 유사합니다.

다음 이미지는 기간 추세 보고서의 예를 보여줍니다.

Power BI Pipelines 기간 추세 보고서의 스크린샷.

Important

Analytics Service의 OData 피드대한 Power BI 통합 및 액세스는 일반적으로 Azure DevOps Services 및 Azure DevOps Server 2020 이상 버전에서 사용할 수 있습니다. 이 문서에서 제공하는 샘플 쿼리는 Azure DevOps Server 2020 이상 버전에 대해서만 유효하며 v3.0 미리 보기 이상 버전에 따라 달라집니다. 이러한 쿼리를 사용하고 피드백을 제공하는 것이 좋습니다.

필수 조건

  • 분석 데이터를 보고 서비스를 쿼리하려면 기본 액세스 이상의 프로젝트 멤버여야 합니다. 기본적으로 모든 프로젝트 멤버에는 분석을 쿼리하고 분석 뷰를 정의할 수 있는 권한이 부여됩니다.
  • 서비스 및 기능 사용 및 일반 데이터 추적 활동과 관련된 다른 필수 구성 요소에 대해 알아보려면 분석에 액세스하기 위한 사용 권한 및 필수 구성 요소를 참조 하세요.

참고 항목

이 문서에서는 OData 쿼리를 사용하여 샘플 보고서 개요를 읽었 으며 Power BI에 대한 기본적인 이해를 가지고 있다고 가정합니다 .

샘플 쿼리

엔터티 집합의 PipelineRuns 다음 쿼리를 사용하여 서로 다르지만 유사한 파이프라인 기간 추세 보고서를 만들 수 있습니다.

참고 항목

필터 또는 보고서 용도로 사용 가능한 속성을 확인하려면 Azure Pipelines에 대한 메타데이터 참조를 참조 하세요. 에서 사용할 수 있는 값 또는 아래 값을 Property 사용하여 쿼리를 EntityType 필터링하거나 NavigationPropertyBinding Path 속성을 반환할 수 있습니다 EntitySet. 각각 EntitySet 은 .에 EntityType해당합니다. 각 값의 데이터 형식에 대해 자세히 알아보려면 해당 EntityType값에 대해 제공된 메타데이터를 검토합니다.

지정된 파이프라인에 대한 80번째 백분위수 기간 추세 가져오기

아래에 나열된 Power BI 쿼리를 데이터> 비어 있는 쿼리 가져오기 창에 직접 붙여넣을 수 있습니다. 자세한 내용은 OData 쿼리를 사용하는 샘플 보고서의 개요를 검토 하세요.

let
   Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/PipelineRuns?"
        &"$apply=filter( "
                &"Pipeline/PipelineName eq '{pipelinename}' "
                &"and CompletedDate ge {startdate} "
                &"and (SucceededCount eq 1 or PartiallySucceededCount eq 1) "
        &") "
        &"/compute( "
            &"percentile_cont(TotalDurationSeconds, 0.8,CompletedDateSK) as Duration80thPercentileInSeconds) "
                &"/groupby( "
                &"(Duration80thPercentileInSeconds, CompletedOn/Date)) "
            &"&$orderby=CompletedOn/Date asc "
    ,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4]) 
in
    Source

대체 문자열 및 쿼리 분석

다음 문자열을 값으로 바꿉니다. 대괄호를 대체에 {} 포함하지 마세요. 예를 들어 조직 이름이 "Fabrikam"{organization}Fabrikam{Fabrikam}인 경우 .

  • {organization} - 조직 이름
  • {project} - 팀 프로젝트 이름
  • {pipelinename} - 파이프라인 이름입니다. 예: Fabrikam hourly build pipeline
  • {startdate} - 보고서를 시작할 날짜입니다. 형식: YYYY-MM-DDZ. 예: 2021-09-01Z 2021년 9월 1일을 나타냅니다. 따옴표나 대괄호로 묶지 말고 월과 날짜 둘 다에 두 숫자를 사용합니다.

쿼리 분석

다음 표에서는 쿼리의 각 부분을 설명합니다.

쿼리 파트

설명


$apply=filter(

Start filter() 절입니다.

Pipeline/PipelineName eq '{pipelinename}'

지정된 파이프라인에 대한 파이프라인 실행을 반환합니다.

and CompletedDate ge {startdate}

반환 파이프라인은 지정된 날짜 또는 그 이후에 실행됩니다.

and (SucceededCount eq 1 or PartiallySucceededCount eq 1)

성공 또는 부분적으로 성공한 실행만 반환합니다.

)

Close filter() 절입니다.

/compute(

Start compute() 절입니다.

percentile_cont(TotalDurationSeconds, 0.8,CompletedDateSK) as Duration80thPercentileInSeconds)

필터 조건과 일치하는 모든 파이프라인 실행의 파이프라인 기간의 80번째 백분위수 계산

/groupby(

groupby() 시작

(Duration80thPercentileInSeconds, CompletedOn/Date))

파이프라인 실행 완료 날짜 및 계산된 일별 80번째 백분위수 파이프라인 기간을 기준으로 그룹화합니다.

&$orderby=CompletedOn/Date asc

완료 날짜별로 응답을 정렬합니다.

파이프라인 이름이 아닌 파이프라인 ID로 필터링

파이프라인의 이름을 바꿀 수 있습니다. 파이프라인 이름이 변경될 때 Power BI 보고서가 중단되지 않도록 하려면 파이프라인 이름 대신 파이프라인 ID를 사용합니다. 파이프라인 실행 페이지의 URL에서 파이프라인 ID를 가져올 수 있습니다.

https://dev.azure.com/{organization}/{project}/_build?definitionId= `{pipelineid}`

아래에 나열된 Power BI 쿼리를 데이터> 비어 있는 쿼리 가져오기 창에 직접 붙여넣을 수 있습니다. 자세한 내용은 OData 쿼리를 사용하는 샘플 보고서의 개요를 검토 하세요.

let
   Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/PipelineRuns?"
        &"$apply=filter( "
                &"PipelineId eq {pipelineId} "
                &"and CompletedDate ge {startdate} "
                &"and (SucceededCount eq 1 or PartiallySucceededCount eq 1) "
        &") "
        &"/compute( "
            &"percentile_cont(TotalDurationSeconds, 0.8,CompletedDateSK) as Duration80thPercentileInSeconds) "
                &"/groupby( "
                &"(Duration80thPercentileInSeconds, CompletedOn/Date)) "
            &"&$orderby=CompletedOn/Date asc "
    ,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4]) 
in
    Source

80번째 백분위수 기간 추세와 함께 50번째 및 90번째 백분위수 가져오기

다른 백분위수 값을 사용하여 계산된 기간 추세를 볼 수 있습니다. 다음 쿼리는 80번째 백분위수와 함께 50번째 및 90번째 백분위수 파이프라인 기간을 제공합니다.

아래에 나열된 Power BI 쿼리를 데이터> 비어 있는 쿼리 가져오기 창에 직접 붙여넣을 수 있습니다. 자세한 내용은 OData 쿼리를 사용하는 샘플 보고서의 개요를 검토 하세요.

let
   Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/PipelineRuns?"
        &"$apply=filter( "
                &"Pipeline/PipelineName eq '{pipelinename}' "
                &"and CompletedDate ge {startdate} "
                &"and (SucceededCount eq 1 or PartiallySucceededCount eq 1) "
        &") "
        &"/compute( "
            &"percentile_cont(TotalDurationSeconds, 0.5,CompletedDateSK) as Duration50thPercentileInSeconds, "
                &"percentile_cont(TotalDurationSeconds, 0.8,CompletedDateSK) as Duration80thPercentileInSeconds, "
                &"percentile_cont(TotalDurationSeconds, 0.90,CompletedDateSK) as Duration90thPercentileInSeconds) "
            &"/groupby( "
                &"(Duration50thPercentileInSeconds, Duration80thPercentileInSeconds, Duration90thPercentileInSeconds, CompletedOn/Date)) "
            &"&$orderby=CompletedOn/Date asc "
    ,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4]) 
in
    Source

분기별로 필터링

특정 분기에 대해서만 파이프라인의 기간 추세를 보려면 다음 쿼리를 사용합니다. 보고서를 만들려면 열 데이터 형식 변경 및 꺾은선형 차트 보고서 만들기 섹션에 설명된 내용과 함께 다음 추가 단계를 수행합니다.

  • 로 확장 Branch 합니다 Branch.BranchName.
  • Power BI 시각화 슬라이서를 선택하고 슬라이서의 필드에 추가 Branch.BranchName 합니다.
  • 파이프라인 기간 추세를 확인해야 하는 슬라이서에서 파이프라인을 선택합니다.

아래에 나열된 Power BI 쿼리를 데이터> 비어 있는 쿼리 가져오기 창에 직접 붙여넣을 수 있습니다. 자세한 내용은 OData 쿼리를 사용하는 샘플 보고서의 개요를 검토 하세요.

let
   Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/PipelineRuns?"
        &"$apply=filter( "
                &"Pipeline/PipelineName eq '{pipelinename}' "
                &"and CompletedDate ge {startdate} "
                &"and (SucceededCount eq 1 or PartiallySucceededCount eq 1) "
        &") "
        &"/compute( "
            &"percentile_cont(TotalDurationSeconds, 0.8,BranchSK, CompletedDateSK) as Duration80thPercentileInSeconds) "
                &"/groupby( "
                &"(Duration80thPercentileInSeconds, Branch/BranchName, CompletedOn/Date)) "
            &"&$orderby=CompletedOn/Date asc "
    ,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4]) 
in
    Source

모든 프로젝트 파이프라인의 기간 추세

단일 보고서에서 프로젝트의 모든 파이프라인에 대한 기간 추세를 볼 수 있습니다. 보고서를 만들려면 열 데이터 형식 변경 및 꺾은선형 차트 보고서 만들기 섹션에 설명된 내용과 함께 다음 추가 단계를 수행합니다.

  • 로 확장 Pipeline 합니다 Pipeline.PipelineName.
  • 시각화 창에서 슬라이서를 선택하고 슬라이 Pipeline.PipelineNam 서의 필드에 추가합니다.
  • 파이프라인 통과 속도의 추세를 확인해야 하는 슬라이서에서 파이프라인을 선택합니다.

아래에 나열된 Power BI 쿼리를 데이터> 비어 있는 쿼리 가져오기 창에 직접 붙여넣을 수 있습니다. 자세한 내용은 OData 쿼리를 사용하는 샘플 보고서의 개요를 검토 하세요.

let
   Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/PipelineRuns?"
        &"$apply=filter( "
                &"CompletedDate ge {startdate} "
                &"and (SucceededCount eq 1 or PartiallySucceededCount eq 1) "
                &") "
        &"/compute( "
        &"percentile_cont(TotalDurationSeconds, 0.8,PipelineId, CompletedDateSK) as Duration80thPercentileInSeconds) "
            &"/groupby( "
                &"(Duration80thPercentileInSeconds, Pipeline/PipelineName, CompletedOn/Date)) "
                &"&$orderby=CompletedOn/Date asc "
    ,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4]) 
in
    Source

Power Query 편집기 열 확장

보고서를 만들기 전에 여러 필드가 포함된 레코드를 반환하는 열을 확장해야 합니다. 이 경우 열을 확장 CompletedOn 하여 평면화할 수 있습니다 CompletedOn.Date.
작업 항목을 확장하는 방법을 알아보려면 분석 데이터 변환을 참조 하여 Power BI 보고서를 생성합니다.

열 데이터 형식 변경

변환 메뉴에서 10진수로 데이터 형식을 Duration80thPercentileInSeconds변경합니다. 방법을 알아보려면 열 데이터 형식 변환을 참조 하세요.

(선택 사항) 열 필드 이름 바꾸기

열 필드의 이름을 바꿀 수 있습니다. 예를 들어 열 Pipeline.PipelineNamePipeline Name이름을 로 바꾸거나 TotalCountTotal Count열로 바꿀 수 있습니다. 방법을 알아보려면 열 필드 이름을 바꿉니다.

쿼리를 닫고 변경 내용 적용

모든 데이터 변환을 완료한 후 홈 메뉴에서 닫기 및 적용 을 선택하여 쿼리를 저장하고 Power BI의 보고서 탭으로 돌아갑니다.

Power Query 편집기 닫기 및 적용 옵션의 스크린샷

꺾은선형 차트 보고서 만들기

  1. Power BI의 시각화에서 꺾은선형 차트 보고서를 선택합니다.

    파이프라인에 대한 시각화 필드 선택 영역의 스크린샷은 기간 추세 보고서를 실행합니다.

  2. X축에 추가하고 CompletedOn.Date 마우스 오른쪽 단추로 클릭한 다음 날짜 계층이 아닌 CompletedOn.Date 선택합니다.

  3. Y축에 추가하고 Duration80thPercentileInSeconds 마우스 오른쪽 단추로 클릭하고 합계가 선택되어 있는지 확인합니다.

표시되는 보고서는 다음 이미지와 유사해야 합니다.

Power BI 샘플 파이프라인 기간 추세 보고서의 스크린샷.