다음을 통해 공유


디바이스 통신 프로토콜 선택

IoT Hub를 사용하면 디바이스가 디바이스 쪽 통신에 다음 프로토콜을 사용할 수 있습니다.

참고 항목

IoT Hub에서는 MQTT에 대한 기능 지원이 제한됩니다. 솔루션에 MQTT v3.1.1 또는 v5 지원이 필요한 경우 Azure Event Grid MQTT 지원을 참조하세요. 자세한 내용은 IoT Hub 및 Event Grid에서 MQTT 지원 비교를 참조하세요.

이러한 프로토콜이 특정 IoT Hub 기능을 지원하는 방식에 대한 내용은 디바이스-클라우드 통신 지침클라우드-디바이스 통신 지침을 참조하세요.

다음 표에는 선택한 프로토콜에 대한 고급 권장 지침이 나와 있습니다.

프로토콜 이 프로토콜을 선택해야 하는 경우
MQTT
WebSocket을 통한 MQTT
각각에 자체 디바이스별 자격 증명이 있어서 여러 디바이스에 연결할 필요가 없는 모든 디바이스에서 동일한 TLS 연결을 통해 사용합니다.
AMQP
Websocket 통한 AMQP
디바이스 간에 연결 멀티플렉싱을 활용하기 위해 필드 및 클라우드 게이트웨이에서 사용합니다.
HTTPS 다른 프로토콜을 지원할 수 없는 디바이스에 사용됩니다.

디바이스 측 통신용 프로토콜을 선택할 때는 다음 사항을 고려해야 합니다.

  • 클라우드-디바이스 패턴. HTTPS에는 서버 푸시를 구현하는 효율적인 방법이 없습니다. 이와 같이 HTTPS를 사용하는 경우 디바이스는 클라우드-디바이스 메시지에 IoT Hub를 폴링합니다. 이 방법은 디바이스와 IoT Hub 모두에 비효율적입니다. 현재 HTTPS 지침에 따르면 각 디바이스는 25분 이상 간격으로 메시지를 폴링해야 합니다. HTTPS 수신을 더 많이 실행하면 IoT Hub가 요청을 제한할 수 있습니다. MQTT 및 AMQP는 클라우드-디바이스 메시지를 받을 때 서버 푸시를 지원합니다. 따라서 IoT Hub의 메시지가 디바이스에 즉시 푸시될 수 있습니다. 전달 대기 시간이 중요한 경우 MQTT 또는 AMQP는 가장 사용하기 적합한 프로토콜입니다. 드물게 연결되는 디바이스의 경우 HTTPS도 작동합니다.

  • 현장 게이트웨이. MQTT 및 HTTPS는 TLS 연결당 단일 디바이스 ID(디바이스 ID 및 자격 증명)만 지원합니다. 이러한 이유로 이러한 프로토콜은 IoT Hub에 대한 단일 연결 또는 업스트림 연결 풀에서 여러 디바이스 ID를 사용하는 멀티플렉싱 메시지가 필요한 필드 게이트웨이 시나리오에 대해 지원되지 않습니다. 이러한 게이트웨이는 업스트림 트래픽에 대해 연결당 AMQP와 같은 여러 디바이스 ID를 지원하는 프로토콜을 사용할 수 있습니다.

  • 낮은 리소스 디바이스. MQTT 및 HTTPS 라이브러리는 AMQP 라이브러리보다 적은 공간을 차지합니다. 이와 같이 디바이스에 리소스가 제한되어 있으면(예: 1MB RAM보다 작음) 이러한 프로토콜은 사용할 수 있는 유일한 프로토콜 구현일 수도 있습니다.

  • 네트워크 통과. 표준 AMQP 프로토콜은 포트 5671을 사용하고 MQTT는 8883 포트에서 수신 대기합니다. 이러한 포트를 사용하면 비 HTTPS 프로토콜에 근접한 네트워크에서 문제를 일으킬 수 있습니다. 이 시나리오에서 WebSockets를 통한 MQTT, WebSockets를 통한 AMQP 및 HTTPS를 사용합니다.

  • 페이로드 크기. MQTT 및 AMQP는 바이너리 프로토콜로, HTTPS보다 더 많이 압축된 페이로드를 발생합니다.

Warning

HTTPS를 사용하는 경우 각 디바이스는 클라우드-디바이스에 대해 25분마다 2번 이상 폴링합니다. 개발 동안에는 원할 경우 각 디바이스에서 더 자주 폴링할 수 있습니다.

Important

X.509 CA(인증 기관) 인증을 사용하는 디바이스에 대한 다음 기능은 아직 일반 공급되지 않으며 미리 보기 모드를 사용하도록 설정해야 합니다.

  • HTTPS, Websocket을 통한 MQTT 및 Websocket 프로토콜을 통한 AMQP
  • 파일 업로드(모든 프로토콜)

이러한 기능은 일반적으로 X.509 지문 인증을 사용하는 디바이스에서 사용할 수 있습니다. IoT Hub를 사용하는 X.509 인증에 대해 자세히 알아보려면 지원되는 X.509 인증서를 참조하세요.

포트 번호

디바이스는 다양한 프로토콜을 사용하여 Azure에서 IoT Hub와 통신할 수 있습니다. 일반적으로 프로토콜은 솔루션의 특정 요구 사항에 따라 선택됩니다. 다음 표에는 특정 프로토콜을 사용할 수 있는 디바이스에 대해 열려 있어야 하는 아웃바운드 포트가 나와 있습니다.

프로토콜 포트
MQTT 8883
WebSocket을 통한 MQTT 443
AMQP 5671
Websocket 통한 AMQP 443
HTTPS 443

IoT Hub의 IP 주소는 예고 없이 변경될 수 있습니다. IoT 솔루션 및 디바이스에 대한 IoT Hub IP 주소 변경의 영향을 완화하는 방법을 알아보려면 IoT Hub IP 주소모범 사례 섹션을 참조하세요.

다음 단계

IoT Hub가 MQTT 프로토콜을 구현하는 방법에 대한 자세한 내용은 MQTT 프로토콜을 사용하여 IoT 허브와 통신을 참조하세요.