[英]Azure Data Factory .NET SDK activity metrics
有誰知道如何(或如果可能)訪問 Azure 門戶中“詳細信息”下顯示的每個活動運行的這些指標?
最初的計划是使用 .NET SDK,但這些指標似乎都沒有包含在內。 這是我迄今為止設法找到的。
var datasliceRunListResponse = client.DataSliceRuns.List(
_resourceGroupName,
dataFactoryName,
Dataset_Destination,
new DataSliceRunListParameters()
{
DataSliceStartTime = PipelineActivePeriodStartTime.ConvertToISO8601DateTimeString()
}
);
foreach (DataSliceRun run in datasliceRunListResponse.DataSliceRuns)
{
Console.WriteLine("Status: \t\t{0}", run.Status);
Console.WriteLine("DataSliceStart: \t{0}", run.DataSliceStart);
Console.WriteLine("DataSliceEnd: \t\t{0}", run.DataSliceEnd);
Console.WriteLine("ActivityId: \t\t{0}", run.ActivityName);
Console.WriteLine("ProcessingStartTime: \t{0}", run.ProcessingStartTime);
Console.WriteLine("ProcessingEndTime: \t{0}", run.ProcessingEndTime);
Console.WriteLine("ErrorMessage: \t{0}", run.ErrorMessage);
Console.WriteLine("Has logse: \t\t{0}", run.HasLogs.ToString());
Console.WriteLine("Id: \t\t\t{0}", run.Id);
Console.WriteLine("Log uri: \t{0}", run.LogUri);
Console.WriteLine("Properties: \t{0}", run.Properties.Count);
}
經過一番挖掘,我在 .NET SDK 中找到了解決方案。 您需要進行“兩步提取”。
獲取切片詳細信息
DateTime PipelineActivePeriodStartTime;
DataSliceRunListResponse sliceList = new DataSliceRunListResponse();
DataSliceRunGetResponse sliceResponse = new DataSliceRunGetResponse();
PipelineActivePeriodStartTime = new DateTime(2017, 3, 20, 07, 00, 0, 0, DateTimeKind.Utc);
DataFactoryManagementClient client = new DataFactoryManagementClient(_aadTokenCredentials, _resourceManagerUri);
sliceList = client.DataSliceRuns.List(
_resourceGroupName,
_dataFactoryName,
_datasetDestination,
new DataSliceRunListParameters()
{
DataSliceStartTime = PipelineActivePeriodStartTime.ConvertToISO8601DateTimeString()
}
);
foreach (DataSliceRun run in sliceList.DataSliceRuns)
{
sliceResponse = client.DataSliceRuns.Get(_resourceGroupName, dataFactoryName, run.Id.ToString());
foreach (KeyValuePair<string, string> entry in sliceResponse.DataSliceRun.Properties)
{
switch (entry.Key.Trim())
{
case "rows":
rows = Convert.ToInt32(entry.Value);
break;
case "dataRead":
dataRead = entry.Value;
break;
case "dataWritten":
dataWritten = entry.Value;
break;
case "throughput":
throughtput = entry.Value;
break;
case "totalDuration":
totalDuration = entry.Value;
break;
default:
break;
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.