不論結束代碼為何,工作完成之後就會發出此事件。 此事件可用來判斷工作的持續時間、工作執行位置,以及是否重試。
下列範例顯示工作完成事件的主體。
{
"jobId": "myJob",
"id": "myTask",
"taskType": "User",
"systemTaskVersion": 0,
"requiredSlots": 1,
"nodeInfo": {
"poolId": "pool-001",
"nodeId": "tvm-257509324_1-20160908t162728z"
},
"multiInstanceSettings": {
"numberOfInstances": 1
},
"constraints": {
"maxTaskRetryCount": 2
},
"executionInfo": {
"startTime": "2016-09-08T16:32:23.799Z",
"endTime": "2016-09-08T16:34:00.666Z",
"exitCode": 0,
"retryCount": 0,
"requeueCount": 0
}
}
| 元素名稱 | 類型 | 註釋 |
|---|---|---|
jobId |
繩子 | 包含工作的作業標識碼。 |
id |
繩子 | 工作識別碼。 |
taskType |
繩子 | 工作的型別。 這可以是 『JobManager』,指出它是作業管理員工作,或指出它不是作業管理員工作的 『User』。 請注意,此事件不會針對作業準備工作、作業發行工作或啟動工作發出。 |
systemTaskVersion |
Int32 | 工作上的內部重試計數器。 在內部,Batch 服務可以重試工作以考慮暫時性問題。 這些問題可能包括內部排程錯誤,或嘗試從處於不良狀態的計算節點復原。 |
requiredSlots |
Int32 | 執行工作所需的位置。 |
nodeInfo |
複雜類型 | 包含工作執行所在的計算節點相關信息。 |
multiInstanceSettings |
複雜類型 | 指定工作是需要多個計算節點的多實例工作。 如需詳細資訊,請參閱 multiInstanceSettings。 |
constraints |
複雜類型 | 套用至此工作的執行條件約束。 |
executionInfo |
複雜類型 | 包含工作執行的相關信息。 |
nodeInfo
| 元素名稱 | 類型 | 註釋 |
|---|---|---|
poolId |
繩子 | 工作執行所在的集區標識碼。 |
nodeId |
繩子 | 工作執行所在的節點識別碼。 |
multiInstanceSettings
| 元素名稱 | 類型 | 註釋 |
|---|---|---|
numberOfInstances |
Int32 | 工作所需的計算節點數目。 |
限制式
| 元素名稱 | 類型 | 註釋 |
|---|---|---|
maxTaskRetryCount |
Int32 | 重試工作的最大次數。 如果 Batch 服務結束代碼為非零,則會重試工作。 這個值會特別控制重試次數。 Batch 服務會嘗試工作一次,然後可能會重試到此限制。 例如,如果重試計數上限為 3,Batch 會嘗試工作最多 4 次(一次初始嘗試,3 次重試)。 如果重試計數上限為0,Batch服務就不會重試工作。 如果重試計數上限為 -1,Batch 服務會重試沒有限制的工作。 預設值為 0(沒有重試)。 |
executionInfo
| 元素名稱 | 類型 | 註釋 |
|---|---|---|
startTime |
日期時間 | 工作開始執行的時間。 「執行中」對應至 執行 中狀態,因此如果工作指定資源檔或應用程式套件,則開始時間會反映工作開始下載或部署這些項目的時間。 如果工作重新啟動或重試,這是工作開始執行的最新時間。 |
endTime |
日期時間 | 工作完成的時間。 |
exitCode |
Int32 | 工作的結束代碼。 |
retryCount |
Int32 | Batch 服務重試工作的次數。 如果工作以非零結束代碼結束,則工作會重試,最多到指定的 MaxTaskRetryCount。 |
requeueCount |
Int32 | 由於使用者要求,Batch 服務會重新排入佇列工作的次數。 當您從集區中移除節點(藉由調整或壓縮節點)或停用作業時,您可以選擇在這些節點上重新排入執行中的工作佇列。 此計數會追蹤工作因這些原因重新排入佇列的次數。 |