Visualization W5100S-EVB-Pico MQTT Message Using AWS + Grafana
by Gemma_Lee in Circuits > Raspberry Pi
588 Views, 2 Favorites, 0 Comments
Visualization W5100S-EVB-Pico MQTT Message Using AWS + Grafana
Visualization W5100S-EVB-Pico MQTT Message using AWS IoT Core, Amazon Timestream DB and Grafana.
Supplies
- WIZnet W5100S-EVB-Pico
- Ethernet Cable
- USB cable
- AWS IoT
- Amazon Timestream
- Grafana
W5100S-EVB-Pico + AWS IoT Core
1) Connect components
Connect W5100S-EVB-Pico and ethernet cable. And the board connect to PC using 5 pin USB cable.
2) Setup AWS IoT Core
Please see and follow the link below.
https://docs.aws.amazon.com/iot/latest/developerguide/create-iot-resources.html
3) Setup Connect AWS IoT through MQTT Example
- Git clone
git clone --recurse-submodules https://github.com/Wiznet/RP2040-HAT-AWS-C.git
- Setup SPI port and pin
Settings in the 'w5x00_spi.h' file located in the 'RP2040-HAT-AWS-C/port/ioLibrary_Driver/' directory.
/* SPI */ #define SPI_PORT spi0 #define PIN_SCK 18 #define PIN_MOSI 19 #define PIN_MISO 16 #define PIN_CS 17 #define PIN_RST 20
- Setup network config
Set in the 'aws_iot_mqtt.c' file in the 'RP2040-HAT-AWS-C/examples/aws_iot_mqtt/' directory.
If the board is connected to the router, it is assigned automatically, so there is no need to edit the file.
/* Network */ static wiz_NetInfo g_net_info = { .mac = {0x00, 0x08, 0xDC, 0x12, 0x34, 0x56}, // MAC address .ip = {192, 168, 11, 2}, // IP address .sn = {255, 255, 255, 0}, // Subnet Mask .gw = {192, 168, 11, 1}, // Gateway .dns = {8, 8, 8, 8}, // DNS server .dhcp = NETINFO_DHCP // DHCP enable/disable };
- Setup AWS IoT configuration
MQTT_DOMAIN is AWS IoT Core > setting > device data endpoint.
Replace my_rp2040_thing with the name of the device you created.
Username and password are not set.
/* AWS IoT */ #define MQTT_DOMAIN "account-specific-prefix-ats.iot.ap-northeast-2.amazonaws.com" #define MQTT_PUB_TOPIC "$aws/things/my_rp2040_thing/shadow/update" #define MQTT_SUB_TOPIC "$aws/things/my_rp2040_thing/shadow/update/accepted" #define MQTT_USERNAME NULL #define MQTT_PASSWORD NULL #define MQTT_CLIENT_ID "my_rp2040_thing"
- Setup device certificate and key
Set in the mqtt_certificate.h file in the 'RP2040-HAT-AWS-C/examples/aws_iot_mqtt/' directory.
Insert the authentication key issued when creating a device in AWS. Put the Amazon Root CA1 certificate in root_ca. Put your certificate.pem in client_cert. Put RSA in the private key.
You must enter it according to the input format below. Enclose each line in quotation marks and \r\n.
uint8_t mqtt_root_ca[] = "-----BEGIN CERTIFICATE-----\r\n" "...\r\n" "-----END CERTIFICATE-----\r\n"; uint8_t mqtt_client_cert[] = "-----BEGIN CERTIFICATE-----\r\n" "...\r\n" "-----END CERTIFICATE-----\r\n"; uint8_t mqtt_private_key[] = "-----BEGIN RSA PRIVATE KEY-----\r\n" "...\r\n" "-----END RSA PRIVATE KEY-----\r\n";
- Setting MQTT Message
In RP2040-HAT-AWS-C, in the file examples/aws_iot_mqtt/aws_iot_mqtt.c, change the line 207 code to temperature, humidity and build.
4) Build
When you have finished editing the file, click the build button in vs code or press f7. When the build is completed, the 'aws_iot_mqtt.uf2' file is created in the 'RP2040-HAT-AWS-C/build/examples/aws_iot_mqtt/' directory.
5) Upload and Run
Press the BOOTSEL button of W5100S-EVB-Pico and connect the USB port to mount the RPI-RP2 drive automatically. Copy and paste the 'aws_iot_mqtt.uf2' file in the drive.
- AWS MQTT Test client
Select the Test Client menu in the AWS IoT console. Subscribe to a topic and publish a topic.
AWS IoT Rule + Timestream
1) Setup Amazon Timestream
- Create DB
Enter the Timestream console and create a DB. Select Standard database, set only the DB name and click the Create database button.
- Create Table
Create a table in the DB created above. Set the name, data retention period and click the Create table button.
2) Setup IoT Rule
- Create Rule
AWS IoT Core > Rule > Create
Set rule name.
Set query. Enter the topic set above.
Timestream job configuration.
Set the DB and Table created above, and set the dimension to clientId. ${clientId()} is the value received from the device. There are only Temperature and Humidity in the MQTT message, but if you do this, the clientId is automatically inserted into the table.
Click Create Role and create a new one.
You can set it up by going to the IAM page, but if you set only a name and create a role here, the role is automatically set with permission to write data to Timestream, so it is convenient to create it here.
Also, if a pre-made role is used, even if the role can write to the timestream table, the role has limited privileges only for a specific table, so the operation is not performed properly.
It is recommended to make a new one and use it.
Error actions and tags create rules without separate actions.
- Check Timestream table
Check whether the rule is executed properly through the Query editor in Timestream.
Timestream + Grafana
1) Connect Timestream to Grafana
Setup Data sources.
Enter Grafana - Configuration - Data sources > Amazon Timestream
Timestream settings
Select Access & secret key from Authentication Provider and enter. Default Region is set to the region where Timestream exists. Default Query Macros set Timestream DB and Table. After completing the settings, click the Save & test button below, and if the connection is successful, a message of Connection success appears.
2) Setting Dashboard
Create - Dashboard
New dashboard created. Choose Add a new panel.
Set queries.
Timestream data can be monitored in real time.
Currently, data is passed as a fixed value, but it can be implemented by connecting a sensor to receive the sensor value.
By pressing the Apply button above, you can visualize the MQTT message sent by W5100S-EVB-Pico in real time.