4.0 KiB
温度を公開する - 仮想IoTハードウェアとRaspberry Pi
このレッスンのこの部分では、Raspberry Piまたは仮想IoTデバイスで検出された温度値をMQTTを介して公開し、後でGDDを計算するために使用できるようにします。
温度を公開する
温度が読み取られたら、それをMQTTを介して「サーバー」コードに公開できます。このコードは値を読み取り、GDD計算に使用するために保存します。
タスク - 温度を公開する
デバイスをプログラムして温度データを公開します。
-
temperature-sensor
アプリプロジェクトがまだ開いていない場合は開きます。 -
レッスン4で行った手順を繰り返して、MQTTに接続し、テレメトリを送信します。同じ公開Mosquittoブローカーを使用します。
この手順は以下の通りです:
- MQTTのpipパッケージを追加する
- MQTTブローカーに接続するコードを追加する
- テレメトリを公開するコードを追加する
⚠️ 必要に応じて、MQTTに接続する手順およびテレメトリを送信する手順を参照してください(レッスン4)。
-
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 を使用して翻訳されています。正確性を追求しておりますが、自動翻訳には誤りや不正確な部分が含まれる可能性があります。元の言語で記載された文書を正式な情報源としてお考えください。重要な情報については、専門の人間による翻訳を推奨します。この翻訳の使用に起因する誤解や誤解釈について、当社は責任を負いません。