투케이2K

183. (Aws/Amazon) [Aws Iot Core] 특정 Job 원격 작업 상세 정보 확인 토픽 설명 - $aws/things/thingName/jobs/jobId/get 본문

Aws (Amazon)

183. (Aws/Amazon) [Aws Iot Core] 특정 Job 원격 작업 상세 정보 확인 토픽 설명 - $aws/things/thingName/jobs/jobId/get

투케이2K 2026. 2. 12. 20:17
728x90
반응형

[개발 환경 설정]

개발 환경 : Aws / Amazon Web Services

 

[설명 정리]

// --------------------------------------------------------------------------------------
[개발 및 환경]
// --------------------------------------------------------------------------------------

- 인프라 : Aws / Amazon Web Services


- 기술 구분 : Aws / Aws Iot Core / Job / OTA


- 사전) Aws Iot Core 간단 설명 : 

  >> AWS IoT 는 IoT 디바이스를 다른 디바이스 및 AWS 클라우드 서비스에 연결하는 클라우드 서비스를 제공합니다.

  >> 디바이스가에 연결할 수 있는 경우 AWS IoT는 AWS 가 제공하는 클라우드 서비스에 디바이스를 AWS IoT 연결할 수 있습니다.

  >> AWS IoT Core 메시지 브로커는 MQTT 및 MQTT over WSS 프로토콜을 사용하여 메시지를 게시하고 구독하는 디바이스 및 클라이언트를 지원합니다. 
  
    - HTTPS 프로토콜을 사용하여 메시지를 게시하는 디바이스와 클라이언트도 지원합니다.


- 사전) AWS Iot Core Job 간략 설명 : 

  >> AWS 원격 작업 이란 작업자 또는 기술자의 물리적 존재 없이 원격으로 수행할 수 있는 업데이트 작업입니다 (무선 업데이트 (OTA) 수행)

  >> AWS IoT 작업 서비스는 AWS IoT 에 연결 되는 하나 이상의 디바이스로 전송 된 후 실행 되는 원격 작업 세트를 정의하는데 사용됩니다

    - 주목적 : 소프트웨어 및 펌웨어 업데이트를 디바이스 기기에게 알리는데 사용 (기기에게 작업 문서 전송)

    - 작업 문서 : AWS IoT Job 생성 시 대상이 되는 디바이스로 전송 되는 문서 (펌웨어 다운로드 URL 정보 등 포함)

// --------------------------------------------------------------------------------------






// --------------------------------------------------------------------------------------
[설 명] 
// --------------------------------------------------------------------------------------

1. AWS IoT Core 에서는 /jobs/jobId/get 토픽을 사용해 '특정 Job 원격 작업 상세 정보' 를 확인할 수 있습니다

  >> Publish 요청 토픽 : $aws/things/{thingName}/jobs/{jobId}/get

    - 디바이스는 이 토픽에 메시지를 publish 하면 AWS IoT Jobs 가 특정 Job의 상태 + Job Document를 /accepted 토픽으로 응답합니다

  >> accepted 구독 토픽 (성공 응답) : $aws/things/{thingName}/jobs/{jobId}/get/accepted

  >> rejected 구독 토픽 (실패 응답) : $aws/things/{thingName}/jobs/{jobId}/get/rejected

  >> thingName 설명 참고 사항 : <thingName> 는 Aws Iot Core 에 등록 된 특정 ThingName 사물 명칭입니다

  >> jobId 설명 참고 사항 : <jobId> 는 Aws Iot Core 에 생성 된 특정 원격 작업 아이디입니다


2. /jobs/jobId/get 토픽 호출 시 DescribeJobExecution 요청을 수행하며, 특정 Job(jobId)에 대한 현재 상태를 확인할 수 있습니다


3. ✅ /jobs/jobId/get 토픽 호출 사용 목적 : 

  >> 특정 Job(jobId)에 대한 현재 상태 확인

  >> Job 문서(Job Document) 내용 확인

  >> 실행해야 할 작업 내용 확인

  >> 변경된 Job 업데이트가 있는지 여부 확인 등


4. ✅ /jobs/jobId/get 토픽 호출 후 accepted 응답 예시 : 


  >> 응답 JSON 샘플
  
  {
    "execution": {
      "jobId": "myJob123",
      "thingName": "MyDevice01",
      "status": "IN_PROGRESS",
      "statusDetails": {},
      "queuedAt": 1500000000,
      "lastUpdatedAt": 1500000500,
      "versionNumber": 1,
      "executionNumber": 1,
      "jobDocument": {
        "operation": "firmware_update",
        "fwVersion": "1.0.2"
      }
    },
    "clientToken": "abcd-1234"
  }


5. ✅ /jobs/jobId/get 토픽 호출 후 rejected 응답 예시 : 

  >> 응답 JSON 샘플
    
  {
    "code": "ResourceNotFoundException",
    "message": "Job execution does not exist",
    "clientToken": "abcd-1234"
  }


6. /jobs/jobId/get 토픽 사용 되는 시점 : 

  >> 디바이스 부팅 시현재 할당된 특정 Job 의 상태를 다시 조회

  >> 작업 도중 Job 문서 (Job Document) 가 필요할 때 : 실제 실행 내용(JSON) 가져오기

  >> Job 상태가 업데이트되었는지 확인 : 실행 중 다른 디바이스가 상태를 업데이트했을 가능성이 있을 때

  >> Job 처리 재시도 : 중단된 Job 을 다시 조회

// --------------------------------------------------------------------------------------






// --------------------------------------------------------------------------------------
[참고 사이트]
// --------------------------------------------------------------------------------------

[Aws Iot Core] 원격 작업 무선 업데이트 (OTA) job 개념 학습 및 펌웨어 업데이트 프로세스 정리

https://kkh0977.tistory.com/8133

https://blog.naver.com/kkh0977/223926549194?trackingCode=blog_bloghome_searchlist


[Aws Iot Core] AWS 원격 펌웨어 업데이트 job 알림 수신 jobs/notify 토픽과 jobs/notify-next 토픽 차이점 정리

https://kkh0977.tistory.com/8178

https://blog.naver.com/kkh0977/223954213087?trackingCode=blog_bloghome_searchlist


[Aws Iot Core] AWS 펌웨어 업데이트 Job Execution Rollout 설정 값 snapshot 과 continuous 차이점 정리

https://blog.naver.com/kkh0977/223960153729?trackingCode=blog_bloghome_searchlist


[Aws Iot Core] AWS 원격 펌웨어 업데이트 OTA 수동 job 생성 및 특정 사물 notify 펌웨어 업데이트 요청 방법 정리

https://blog.naver.com/kkh0977/223944636139?trackingCode=blog_bloghome_searchlist


[안드로이드 AWS Iot Core 원격 업데이트 Job 리스트 목록 확인]

https://blog.naver.com/kkh0977/223926528254?trackingCode=blog_bloghome_searchlist


[업무 이슈] Aws Iot Core 에서 Job 원격 펌웨어 업데이트 요청 시 상태가 완료 로 처리 되지 않는 이슈 발생

https://blog.naver.com/kkh0977/223944640508?trackingCode=blog_bloghome_searchlist


[업무 이슈] AWS Job 디바이스 펌웨어 업데이트 파일 순차 업데이트 미동작 이슈 - IN_PROGRESS, QUEUED 배열 펌웨어 처리

https://blog.naver.com/kkh0977/223955019266?trackingCode=blog_bloghome_searchlist


[업무 이슈] AWS Job 디바이스 펌웨어 업데이트 시 동일 버전 펌웨어 버전 체크 및 업데이트 진행 미완료 표시 - publish status

https://blog.naver.com/kkh0977/223955010876?trackingCode=blog_bloghome_searchlist


[업무 이슈] 디바이스 Aws Job OTA 펌웨어 업데이트 시 STS 임시 자격 증명 S3 Presigned URL 프리 사인 주소 파싱 문제 발생

https://blog.naver.com/kkh0977/223951554000?trackingCode=blog_bloghome_searchlist

// --------------------------------------------------------------------------------------
 
728x90
반응형
Comments