本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
Job物件包含了工作的詳細資訊。語法如下列範例所示。
{
    "jobArn": "string", 
    "jobId": "string", 
    "status": "IN_PROGRESS|CANCELED|SUCCEEDED", 
    "forceCanceled": boolean,
    "targetSelection": "CONTINUOUS|SNAPSHOT",
    "comment": "string",
    "targets": ["string"], 
    "description": "string",
    "createdAt": timestamp,
    "lastUpdatedAt": timestamp,
    "completedAt": timestamp,
    "jobProcessDetails": {
        "processingTargets": ["string"],
        "numberOfCanceledThings": long, 
        "numberOfSucceededThings": long, 
        "numberOfFailedThings": long,
        "numberOfRejectedThings": long, 
        "numberOfQueuedThings": long, 
        "numberOfInProgressThings": long, 
        "numberOfRemovedThings": long, 
        "numberOfTimedOutThings": long
    }, 
    "presignedUrlConfig": {
        "expiresInSec": number, 
        "roleArn": "string"
    }, 
    "jobExecutionsRolloutConfig": { 
        "exponentialRate": { 
           "baseRatePerMinute": integer,
           "incrementFactor": integer,
           "rateIncreaseCriteria": { 
              "numberOfNotifiedThings": integer, // Set one or the other
              "numberOfSucceededThings": integer // of these two values.
           },
           "maximumPerMinute": integer
      }
    },    
    "abortConfig": { 
       "criteriaList": [ 
          { 
             "action": "string",
             "failureType": "string",
             "minNumberOfExecutedThings": integer,
             "thresholdPercentage": integer
          }
       ]
    },
    "SchedulingConfig": { 
      "startTime": string
      "endTime": string
      "timeZone": string
      "endTimeBehavior": string
   },
    "timeoutConfig": {
        "inProgressTimeoutInMinutes": long
    }
}
如需詳細資訊,請參閱 Job 或 job 。
JobSummary物件包含了工作摘要。語法如下列範例所示。
{
    "jobArn": "string", 
    "jobId": "string",
    "status": "IN_PROGRESS|CANCELED|SUCCEEDED|SCHEDULED", 
    "targetSelection": "CONTINUOUS|SNAPSHOT",
    "thingGroupId": "string",
    "createdAt": timestamp, 
    "lastUpdatedAt": timestamp, 
    "completedAt": timestamp
}
如需詳細資訊,請參閱 JobSummary 或 job-summary 。
JobExecution 物件代表在裝置上執行任務。語法如下列範例所示。
{
    "approximateSecondsBeforeTimedOut": 50,
    "executionNumber": 1234567890,
    "forceCanceled": true|false,
    "jobId": "string",
    "lastUpdatedAt": timestamp, 
    "queuedAt": timestamp,
    "startedAt": timestamp,
    "status": "QUEUED|IN_PROGRESS|FAILED|SUCCEEDED|CANCELED|TIMED_OUT|REJECTED|REMOVED",
    "forceCanceled": boolean,
    "statusDetails": {
        "detailsMap": { 
            "string": "string" ...
        },
        "status": "string"
    }, 
    "thingArn": "string", 
    "versionNumber": 123
}
如需詳細資訊,請參閱 JobExecution 或 job-execution 。
JobExecutionSummary 物件包含了任務執行摘要的資訊。語法如下列範例所示。
{
    "executionNumber": 1234567890,
    "queuedAt": timestamp,
    "lastUpdatedAt": timestamp,
    "startedAt": timestamp,
    "status": "QUEUED|IN_PROGRESS|FAILED|SUCCEEDED|CANCELED|TIMED_OUT|REJECTED|REMOVED"
}
如需詳細資訊,請參閱 JobExecutionSummary 或 job-execution-summary 。
JobExecutionSummaryForJob物件包含了關於特定工作之工作執行的資訊摘要。語法如下列範例所示。
{
    "executionSummaries": [
        {
            "thingArn": "arn:aws:iot:us-west-2:123456789012:thing/MyThing", 
            "jobExecutionSummary": {
                "status": "IN_PROGRESS", 
                "lastUpdatedAt": 1549395301.389, 
                "queuedAt": 1541526002.609, 
                "executionNumber": 1
            }
        }, 
        ...
    ]
}
如需詳細資訊,請參閱 JobExecutionSummaryForJob 或 job-execution-summary-for-job 。
JobExecutionSummaryForThing物件包含了關於特定物件之工作執行的資訊摘要。語法如下列範例所示:
{
    "executionSummaries": [
        {
            "jobExecutionSummary": {
                "status": "IN_PROGRESS", 
                "lastUpdatedAt": 1549395301.389, 
                "queuedAt": 1541526002.609, 
                "executionNumber": 1
            }, 
            "jobId": "MyThingJob"
        },
        ...
    ]
}
如需詳細資訊,請參閱 JobExecutionSummaryForThing 或 job-execution-summary-for-thing 。
將群組與持續性任務建立關聯。必須符合以下條件:
                     - HTTPS request
- POST /jobs/- jobId/targets
 
{ 
"targets": [ "string" ],
"comment": "string"
}
 - 如需詳細資訊,請參閱- AssociateTargetsWithJob。
 
- CLI syntax
- aws iot  associate-targets-with-job \
--targets <value> \
--job-id <value> \
[--comment <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"targets": [
"string"
],
"jobId": "string",
"comment": "string"
}
 - 如需詳細資訊,請參閱- associate-targets-with-job。
 
取消任務。
                     - HTTPS request
- PUT /jobs/- jobId/cancel
 
{ 
"force": boolean,
"comment": "string",
"reasonCode": "string"
}
 - 如需詳細資訊,請參閱- CancelJob。
 
- CLI syntax
- 
                            aws iot cancel-job \
    --job-id <value> \
    [--force <value>]  \
    [--comment <value>]  \
    [--reasonCode <value>]  \
    [--cli-input-json <value>] \
    [--generate-cli-skeleton]
  cli-input-json格式:
 {
    "jobId": "string",
    "force": boolean,
    "comment": "string"
}
 如需詳細資訊,請參閱cancel-job。
 
取消裝置上的任務執行。
                     - HTTPS request
- PUT /things/- thingName/jobs/- jobId/cancel
 
{ 
"force": boolean,
"expectedVersion": "string",
"statusDetails": {
    "string": "string"
    ...
}
}
 - 如需詳細資訊,請參閱- CancelJobExecution。
 
- CLI syntax
- aws iot cancel-job-execution \
--job-id <value> \
--thing-name <value> \
[--force | --no-force] \
[--expected-version <value>] \
[--status-details <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"jobId": "string",
"thingName": "string",
"force": boolean,
"expectedVersion": long,
"statusDetails": {
"string": "string"
}
}
 - 如需詳細資訊,請參閱- cancel-job-execution。
 
建立任務。您可以將 Amazon S3 儲存貯體 (documentSource 參數) 或請求本文 (document 參數) 中的檔案連結提供給任務文件。
您可以將選用 targetSelection 參數設定為 CONTINUOUS (預設為 SNAPSHOT) 以讓任務「持續」執行。持續任務可以用來在新增至群組時加入或升級裝置,因為它會持續執行,並在新增的項目上啟動。即使在建立任務時群組中的物件已完成任務之後,仍可能發生這種情況。
任務可以有一個選用 TimeoutConfig,其會設定進行中計時器的值。進行中計時器無法更新,並會套用到任務的所有執行。
以下驗證會在 CreateJobAPI 的引數上執行:
                      
                      
                      
                      
                      
                 - 
                         targets引數必須是有效物件或物件群組 ARN 的清單。所有物件和物件群組都必須位於您的 中 AWS 帳戶。
 
- 
                         documentSource引數必須是連結至任務文件的有效 Amazon S3 URL。Amazon S3 URL 的格式為:https://s3.amazonaws.com/bucketName/objectName
。
 
- 
                         由 documentSource引數指定存放文件的 URL 必須是 UTF-8 編碼的 JSON 文件。
 
- 
                         由於 MQTT 訊息大小限制 (128 KB) 與加密因素,因此工作文件的大小限制為 32 KB。 
- 
                         在您的 中jobId必須是唯一的 AWS 帳戶。
 
 
                     - HTTPS request
- PUT /jobs/- jobId{
"targets": [ "string" ],
"document": "string",
"documentSource": "string",
"description": "string",
"jobTemplateArn": "string",
"presignedUrlConfigData": {
    "roleArn": "string", 
    "expiresInSec": "integer" 
},
"targetSelection": "CONTINUOUS|SNAPSHOT",
"jobExecutionsRolloutConfig": { 
    "exponentialRate": { 
       "baseRatePerMinute": integer,
       "incrementFactor": integer,
       "rateIncreaseCriteria": { 
          "numberOfNotifiedThings": integer, // Set one or the other
          "numberOfSucceededThings": integer // of these two values.
       },
       "maximumPerMinute": integer
  }
},
"abortConfig": { 
   "criteriaList": [ 
      { 
         "action": "string",
         "failureType": "string",
         "minNumberOfExecutedThings": integer,
         "thresholdPercentage": integer
      }
   ]
},
"SchedulingConfig": { 
    "startTime": string
    "endTime": string
    "timeZone": string
    "endTimeBehavior": string
   }
"timeoutConfig": { 
  "inProgressTimeoutInMinutes": long
}
}
 - 如需詳細資訊,請參閱- CreateJob。
 
- CLI syntax
- aws iot create-job \
    --job-id <value> \
    --targets <value> \
    [--document-source <value>] \
    [--document <value>] \
    [--description <value>] \
    [--job-template-arn <value>] \
    [--presigned-url-config <value>] \
    [--target-selection <value>] \
    [--job-executions-rollout-config <value>] \
    [--abort-config <value>] \
    [--timeout-config <value>] \
    [--document-parameters <value>]  \
    [--cli-input-json <value>] \
    [--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
    "jobId": "string",
    "targets": [ "string" ],
    "documentSource": "string",
    "document": "string",
    "description": "string",
    "jobTemplateArn": "string",
    "presignedUrlConfig": {
        "roleArn": "string",
        "expiresInSec": long
     },
    "targetSelection": "string",
    "jobExecutionsRolloutConfig": { 
          "exponentialRate": { 
              "baseRatePerMinute": integer,
              "incrementFactor": integer,
              "rateIncreaseCriteria": { 
                 "numberOfNotifiedThings": integer, // Set one or the other
                 "numberOfSucceededThings": integer // of these two values.
              },
      "maximumPerMinute": integer
      }
    }, 
    "abortConfig": { 
    "criteriaList": [ 
        { 
           "action": "string",
           "failureType": "string",
           "minNumberOfExecutedThings": integer,
           "thresholdPercentage": integer
         }
      ]
    },
    "timeoutConfig": { 
          "inProgressTimeoutInMinutes": long
    },
    "documentParameters": {
    "string": "string"
    }
}
 - 如需詳細資訊,請參閱- create-job。
 
刪除任務及其相關的任務執行。
刪除任務可能會需要時間,根據為任務與各種其他因素所建立的任務執行數量而定。雖然任務被刪除,任務狀態將顯示為「DELETION_IN_PROGRESS」。嘗試刪除或取消狀態已為「DELETION_IN_PROGRESS」的任務將會導致錯誤。
                     - HTTPS request
- DELETE /jobs/- jobId?force=- force
 - 如需詳細資訊,請參閱- DeleteJob。
 
- CLI syntax
- aws iot  delete-job \
--job-id <value> \
[--force | --no-force]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"jobId": "string",
"force": boolean
}
 - 如需詳細資訊,請參閱- delete-job。
 
刪除任務執行。
                     - HTTPS request
- DELETE /things/- thingName/jobs/- jobId/executionNumber/- executionNumber?force=- force
 - 如需詳細資訊,請參閱- DeleteJobExecution。
 
- CLI syntax
- aws iot  delete-job-execution \
--job-id <value> \
--thing-name <value> \
--execution-number <value> \
[--force | --no-force]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"jobId": "string",
"thingName": "string",
"executionNumber": long,
"force": boolean
}
 - 如需詳細資訊,請參閱- delete-job-execution。
 
取得任務執行的詳細資訊。
                     - HTTPS request
- GET /jobs/- jobId
 - 如需詳細資訊,請參閱- DescribeJob。
 
- CLI syntax
-  aws iot describe-job \
--job-id <value>  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
  cli-input-json格式:
 {
"jobId": "string"
}
 如需詳細資訊,請參閱describe-job。
 
取得工作執行的詳細資訊。任務的執行狀態必須為 SUCCEEDED或 FAILED。
                     - HTTPS request
- GET /things/- thingName/jobs/- jobId?executionNumber=- executionNumber
 - 如需詳細資訊,請參閱- DescribeJobExecution。
 
- CLI syntax
-  aws iot  describe-job-execution \
--job-id <value> \
--thing-name <value> \
[--execution-number <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
  cli-input-json格式:
 {
"jobId": "string",
"thingName": "string",
"executionNumber": long
}
 如需詳細資訊,請參閱describe-job-execution。
 
取得工作的工作文件。
在傳回的文件中,預留位置 URL 不會被預先簽章的 Amazon S3 URL 取代。只有在 AWS IoT Jobs 服務透過 MQTT 收到請求時,才會產生預先簽章URLs。
                     - HTTPS request
- GET /jobs/- jobId/job-document
 - 如需詳細資訊,請參閱- GetJobDocument。
 
- CLI syntax
-  aws iot get-job-document \
--job-id <value>  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
  cli-input-json格式:
 {
"jobId": "string"
}
 如需詳細資訊,請參閱get-job-document。
 
取得工作的工作執行清單。
                     - HTTPS request
-  GET /jobs/jobId/things?status=status&maxResults=maxResults&nextToken=nextToken
 如需詳細資訊,請參閱ListJobExecutionsForJob。
 
- CLI syntax
- aws iot  list-job-executions-for-job \
--job-id <value> \
[--status <value>] \
[--max-results <value>] \
[--next-token <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"jobId": "string",
"status": "string",
"maxResults": "integer",
"nextToken": "string"
}
 - 如需詳細資訊,請參閱- list-job-executions-for-job。
 
取得物件的工作執行清單。
                     - HTTPS request
- GET /things/- thingName/jobs?status=- status&maxResults=- maxResults&nextToken=- nextToken
 - 如需詳細資訊,請參閱- ListJobExecutionsForThing。
 
- CLI syntax
- aws iot list-job-executions-for-thing \
--thing-name <value> \
[--status <value>] \
[--max-results <value>] \
[--next-token <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"thingName": "string",
"status": "string",
"maxResults": "integer",
"nextToken": "string"
}
 - 如需詳細資訊,請參閱- list-job-executions-for-thing。
 
取得 中任務的清單 AWS 帳戶。
                     - HTTPS request
- GET /jobs?status=- status&targetSelection=- targetSelection&thingGroupName=- thingGroupName&thingGroupId=- thingGroupId&maxResults=- maxResults&nextToken=- nextToken
 - 如需詳細資訊,請參閱- ListJobs。
 
- CLI syntax
- aws iot list-jobs \
[--status <value>] \
[--target-selection <value>] \
[--max-results <value>] \
[--next-token <value>] \
[--thing-group-name <value>] \
[--thing-group-id <value>]  \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
 -  - cli-input-json格式:
 - {
"status": "string",
"targetSelection": "string",
"maxResults": "integer",
"nextToken": "string",
"thingGroupName": "string",
"thingGroupId": "string"
}
 - 如需詳細資訊,請參閱- list-jobs。
 
更新指定任務的支援欄位。timeoutConfig 的更新值僅對新進行中的啟動生效。目前,進行中的啟動會繼續以先前的逾時組態啟動。
                     - HTTPS request
- PATCH /jobs/- jobId{
"description": "string",
"presignedUrlConfig": { 
  "expiresInSec": number,
  "roleArn": "string"
},
"jobExecutionsRolloutConfig": { 
  "exponentialRate": { 
     "baseRatePerMinute": number,
     "incrementFactor": number,
     "rateIncreaseCriteria": { 
        "numberOfNotifiedThings": number,
        "numberOfSucceededThings": number
     }, 
  "maximumPerMinute": number
  },
"abortConfig": { 
  "criteriaList": [ 
     { 
        "action": "string",
        "failureType": "string",
        "minNumberOfExecutedThings": number,
        "thresholdPercentage": number
     }
  ]
},
"timeoutConfig": { 
  "inProgressTimeoutInMinutes": number
}
}
 - 如需詳細資訊,請參閱- UpdateJob。
 
- CLI syntax
-  aws iot  update-job \
--job-id <value> \
[--description <value>] \
[--presigned-url-config <value>] \
[--job-executions-rollout-config <value>] \
[--abort-config <value>] \
[--timeout-config <value>] \
[--cli-input-json <value>] \
[--generate-cli-skeleton]
  cli-input-json格式:
 {
"description": "string",
"presignedUrlConfig": { 
  "expiresInSec": number,
  "roleArn": "string"
},
"jobExecutionsRolloutConfig": { 
  "exponentialRate": { 
     "baseRatePerMinute": number,
     "incrementFactor": number,
     "rateIncreaseCriteria": { 
        "numberOfNotifiedThings": number,
        "numberOfSucceededThings": number
     }
  },
  "maximumPerMinute": number
},
"abortConfig": { 
  "criteriaList": [ 
     { 
        "action": "string",
        "failureType": "string",
        "minNumberOfExecutedThings": number,
        "thresholdPercentage": number
     }
  ]
},
"timeoutConfig": { 
  "inProgressTimeoutInMinutes": number
}
}
 如需詳細資訊,請參閱update-job。