You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
3.2 KiB
74 lines
3.2 KiB
<!--
|
|
CO_OP_TRANSLATOR_METADATA:
|
|
{
|
|
"original_hash": "1226517aae5f5b6f904434670394c688",
|
|
"translation_date": "2025-08-28T03:31:59+00:00",
|
|
"source_file": "1-getting-started/lessons/4-connect-internet/single-board-computer-telemetry.md",
|
|
"language_code": "br"
|
|
}
|
|
-->
|
|
# Controle sua luz noturna pela Internet - Hardware IoT Virtual e Raspberry Pi
|
|
|
|
Nesta parte da lição, você enviará telemetria com níveis de luz do seu Raspberry Pi ou dispositivo IoT virtual para um broker MQTT.
|
|
|
|
## Publicar telemetria
|
|
|
|
O próximo passo é criar um documento JSON com telemetria e enviá-lo para o broker MQTT.
|
|
|
|
### Tarefa
|
|
|
|
Publique telemetria no broker MQTT.
|
|
|
|
1. Abra o projeto da luz noturna no VS Code.
|
|
|
|
1. Se você estiver usando um dispositivo IoT virtual, certifique-se de que o terminal está executando o ambiente virtual. Se estiver usando um Raspberry Pi, você não utilizará um ambiente virtual.
|
|
|
|
1. Adicione a seguinte importação no topo do arquivo `app.py`:
|
|
|
|
```python
|
|
import json
|
|
```
|
|
|
|
A biblioteca `json` é usada para codificar a telemetria como um documento JSON.
|
|
|
|
1. Adicione o seguinte após a declaração de `client_name`:
|
|
|
|
```python
|
|
client_telemetry_topic = id + '/telemetry'
|
|
```
|
|
|
|
O `client_telemetry_topic` é o tópico MQTT onde o dispositivo publicará os níveis de luz.
|
|
|
|
1. Substitua o conteúdo do loop `while True:` no final do arquivo pelo seguinte:
|
|
|
|
```python
|
|
while True:
|
|
light = light_sensor.light
|
|
telemetry = json.dumps({'light' : light})
|
|
|
|
print("Sending telemetry ", telemetry)
|
|
|
|
mqtt_client.publish(client_telemetry_topic, telemetry)
|
|
|
|
time.sleep(5)
|
|
```
|
|
|
|
Este código empacota o nível de luz em um documento JSON e o publica no broker MQTT. Em seguida, ele entra em modo de espera para reduzir a frequência com que as mensagens são enviadas.
|
|
|
|
1. Execute o código da mesma forma que você executou o código na parte anterior da tarefa. Se estiver usando um dispositivo IoT virtual, certifique-se de que o aplicativo CounterFit está em execução e que o sensor de luz e o LED foram criados nos pinos corretos.
|
|
|
|
```output
|
|
(.venv) ➜ nightlight python app.py
|
|
MQTT connected!
|
|
Sending telemetry {"light": 0}
|
|
Sending telemetry {"light": 0}
|
|
```
|
|
|
|
> 💁 Você pode encontrar este código na pasta [code-telemetry/virtual-device](../../../../../1-getting-started/lessons/4-connect-internet/code-telemetry/virtual-device) ou na pasta [code-telemetry/pi](../../../../../1-getting-started/lessons/4-connect-internet/code-telemetry/pi).
|
|
|
|
😀 Você enviou telemetria com sucesso a partir do seu dispositivo.
|
|
|
|
---
|
|
|
|
**Aviso Legal**:
|
|
Este documento foi traduzido utilizando o serviço de tradução por IA [Co-op Translator](https://github.com/Azure/co-op-translator). Embora nos esforcemos para garantir a precisão, esteja ciente de que traduções automatizadas podem conter erros ou imprecisões. O documento original em seu idioma nativo deve ser considerado a fonte autoritativa. Para informações críticas, recomenda-se a tradução profissional realizada por humanos. Não nos responsabilizamos por quaisquer mal-entendidos ou interpretações equivocadas decorrentes do uso desta tradução. |