디바이스에 새로운 인증서를 배포하는 방법
- 새로운 인증서 생성 및 등록: 이미 앞서 설명한 것처럼 새로운 인증서를 생성하고 AWS IoT에 등록 및 활성화한다.
- 새로운 인증서와 키 파일 디바이스에 전달: 새로운 인증서와 프라이빗 키 파일을 디바이스에 전달합니다. 이를 위해 여러 가지 방법을 사용할 수 있다.
- 디바이스 소프트웨어 업데이트: 디바이스 소프트웨어를 업데이트하여 새로운 인증서를 사용하도록 구성한다.
1. 새로운 인증서 생성 및 등록
앞서 설명한 방법을 통해 새로운 인증서를 생성하고 AWS IoT에 등록.
2. 새로운 인증서와 키 파일 디바이스에 전달
디바이스에 새로운 인증서와 프라이빗 키 파일을 전달하는 방법
A. 수동 업데이트
디바이스에 물리적으로 접근할 수 있는 경우, USB 드라이브 등을 이용하여 수동으로 파일을 업데이트합니다.
- 파일 복사: 새로운 인증서(newDeviceCert.pem)와 프라이빗 키(newDevicePrivateKey.pem) 파일을 USB 드라이브 등에 복사합니다.
- 디바이스에 연결: USB 드라이브를 디바이스에 연결하고 파일을 디바이스의 적절한 위치에 복사합니다.
B. OTA(Over-The-Air) 업데이트
디바이스가 원격에서 업데이트를 받을 수 있는 경우, OTA 업데이트를 통해 인증서를 배포할 수 있습니다.
- 서버에 파일 업로드: 새로운 인증서와 프라이빗 키 파일을 서버에 업로드합니다.
- 디바이스 소프트웨어 업데이트: 디바이스가 서버로부터 새로운 인증서와 키 파일을 다운로드하고, 이를 적용하도록 소프트웨어를 업데이트합니다.
3. 디바이스 소프트웨어 업데이트
디바이스 소프트웨어를 업데이트하여 새로운 인증서를 사용하도록 구성합니다. 디바이스 소프트웨어가 MQTT를 통해 AWS IoT와 통신하는 경우, 보통 다음과 같은 단계를 따릅니다.
예시: Node.js 기반 디바이스 소프트웨어 업데이트
디바이스 소프트웨어가 Node.js 기반이라고 가정하면, 다음과 같은 코드로 새로운 인증서를 적용할 수 있습니다.
const mqtt = require('mqtt');
const fs = require('fs');
// 인증서 및 키 파일 경로
const KEY = fs.readFileSync('path/to/newDevicePrivateKey.pem');
const CERT = fs.readFileSync('path/to/newDeviceCert.pem');
const CA = fs.readFileSync('path/to/AmazonRootCA1.pem'); // AWS 루트 CA
// MQTT 클라이언트 설정
const options = {
key: KEY,
cert: CERT,
ca: CA,
clientId: 'yourDeviceClientId',
host: 'your-iot-endpoint',
port: 8883,
protocol: 'mqtts'
};
// MQTT 클라이언트 생성
const client = mqtt.connect(options);
client.on('connect', () => {
console.log('Connected to AWS IoT');
// 추가 MQTT 핸들러 코드
});
client.on('error', (err) => {
console.error('Connection error: ', err);
});
예시: C 기반 디바이스 소프트웨어 업데이트
디바이스 소프트웨어가 C 기반이라고 가정하면, 다음과 같이 새로운 인증서를 적용할 수 있습니다.
#include "aws_iot_mqtt_client_interface.h"
// 인증서 및 키 파일 경로
#define AWS_IOT_PRIVATE_KEY_PATH "path/to/newDevicePrivateKey.pem"
#define AWS_IOT_CERTIFICATE_PATH "path/to/newDeviceCert.pem"
#define AWS_IOT_ROOT_CA_PATH "path/to/AmazonRootCA1.pem"
// MQTT 클라이언트 설정
AWS_IoT_Client mqttClient;
IoT_Client_Init_Params mqttInitParams = iotClientInitParamsDefault;
IoT_Client_Connect_Params mqttConnectParams = iotClientConnectParamsDefault;
mqttInitParams.pHostURL = "your-iot-endpoint";
mqttInitParams.port = 8883;
mqttInitParams.pRootCALocation = AWS_IOT_ROOT_CA_PATH;
mqttInitParams.pDeviceCertLocation = AWS_IOT_CERTIFICATE_PATH;
mqttInitParams.pDevicePrivateKeyLocation = AWS_IOT_PRIVATE_KEY_PATH;
// MQTT 클라이언트 초기화 및 연결
rc = aws_iot_mqtt_init(&mqttClient, &mqttInitParams);
if (SUCCESS != rc) {
printf("aws_iot_mqtt_init returned error : %d ", rc);
return rc;
}
rc = aws_iot_mqtt_connect(&mqttClient, &mqttConnectParams);
if (SUCCESS != rc) {
printf("Error(%d) connecting to %s:%d", rc, mqttInitParams.pHostURL, mqttInitParams.port);
return rc;
}
printf("Connected to AWS IoT\n");
// 추가 MQTT 핸들러 코드
결론
디바이스에 새로운 인증서를 배포하는 과정은 디바이스의 특성에 따라 다르지만, 일반적으로 새로운 인증서를 생성하고, 이를 디바이스에 전달한 후, 디바이스 소프트웨어를 업데이트하여 새로운 인증서를 사용하도록 구성하는 방식으로 진행됩니다. OTA 업데이트를 지원하는 경우, 원격으로 인증서를 배포하는 것이 가장 효율적이다.