3.7 KiB
온도 게시 - 가상 IoT 하드웨어와 Raspberry Pi
이 수업의 이 부분에서는 Raspberry Pi 또는 가상 IoT 장치가 감지한 온도 값을 MQTT를 통해 게시하여 나중에 GDD를 계산하는 데 사용할 수 있도록 합니다.
온도 게시하기
온도가 읽힌 후에는 MQTT를 통해 '서버' 코드로 게시할 수 있습니다. 이 서버 코드는 값을 읽고 GDD 계산에 사용할 준비를 합니다.
작업 - 온도 게시하기
장치를 프로그래밍하여 온도 데이터를 게시하세요.
-
temperature-sensor
앱 프로젝트가 열려 있지 않다면 열어주세요. -
MQTT에 연결하고 텔레메트리를 보내는 4번째 수업에서 했던 단계를 반복하세요. 동일한 공개 Mosquitto 브로커를 사용할 것입니다.
이 단계는 다음과 같습니다:
- MQTT pip 패키지 추가
- MQTT 브로커에 연결하는 코드 추가
- 텔레메트리를 게시하는 코드 추가
⚠️ 필요하다면 MQTT 연결 지침과 텔레메트리 전송 지침을 참조하세요.
-
client_name
이 이 프로젝트의 이름을 반영하는지 확인하세요:client_name = id + 'temperature_sensor_client'
-
텔레메트리의 경우, 조도 값을 보내는 대신 DHT 센서에서 읽은 온도 값을 JSON 문서의
temperature
라는 속성으로 보내세요:_, temp = sensor.read() telemetry = json.dumps({'temperature' : temp})
-
온도 값은 자주 읽을 필요가 없습니다. 짧은 시간 안에 크게 변하지 않으므로
time.sleep
을 10분으로 설정하세요:time.sleep(10 * 60);
💁
sleep
함수는 시간을 초 단위로 받습니다. 읽기 쉽게 하기 위해 값은 계산 결과로 전달됩니다. 1분은 60초이므로 10 x (1분의 60초)로 10분 지연을 설정합니다. -
이전 과제의 코드 실행 방식과 동일하게 코드를 실행하세요. 가상 IoT 장치를 사용하는 경우 CounterFit 앱이 실행 중인지 확인하고 습도 및 온도 센서가 올바른 핀에 생성되었는지 확인하세요.
pi@raspberrypi:~/temperature-sensor $ python3 app.py MQTT connected! Sending telemetry {"temperature": 25} Sending telemetry {"temperature": 25}
💁 이 코드는 code-publish-temperature/virtual-device 폴더 또는 code-publish-temperature/pi 폴더에서 찾을 수 있습니다.
😀 장치에서 텔레메트리로 온도를 성공적으로 게시했습니다.
면책 조항:
이 문서는 AI 번역 서비스 Co-op Translator를 사용하여 번역되었습니다. 정확성을 위해 최선을 다하고 있지만, 자동 번역에는 오류나 부정확성이 포함될 수 있습니다. 원본 문서를 해당 언어로 작성된 상태에서 권위 있는 자료로 간주해야 합니다. 중요한 정보의 경우, 전문적인 인간 번역을 권장합니다. 이 번역 사용으로 인해 발생하는 오해나 잘못된 해석에 대해 당사는 책임을 지지 않습니다.