MICROSOFT AZURE (2): CONNECTING A SIMULATED DEVICE TO AN IoT HUB USING NODE.JS
data:image/s3,"s3://crabby-images/d21d9/d21d9c1c579698411131f8ca1b00f29333b6ec21" alt=""
* This exercise is based on the previous one
1 - Creating a device identity
- CreateDeviceIdentity.js creates a device identity and associated security key to connect a simulated device app.
- Running this console app generates a unique device ID and key that the device can use to identify itself when it sends device-to-cloud messages to IoT Hub.
- New folder:
data:image/s3,"s3://crabby-images/321ec/321ec153f1a7ce15e84a35091e56b2fce07b58cc" alt=""
- Checking that node and npm are correctly installed:
data:image/s3,"s3://crabby-images/96496/96496e61978eaff84a3e5401a4afdeab7fab7afd" alt=""
- npm creates a json package, just accepting the default options:
data:image/s3,"s3://crabby-images/defb9/defb9ea2053fdbe1467b10c20f67aa0454b51a24" alt=""
- Installing the azure-iothub service SDK package:
data:image/s3,"s3://crabby-images/17f1c/17f1cd0d44c4c1d75b6ad2a801d644ad54a2ee1f" alt=""
- Writing the CreateDeviceIdentity.js file:
data:image/s3,"s3://crabby-images/62828/6282889b6fd522213d5de124ee4d7b94d0237c7d" alt=""
data:image/s3,"s3://crabby-images/f416a/f416a78780a05a82bb4c31f6d85a10face05d634" alt=""
- It is important to notice that the variable connection string holds the "connection string - primary key" obtained in the previous exercise:
data:image/s3,"s3://crabby-images/d5e3d/d5e3dfdf708024254ba78e3e0b4547ebadb812e3" alt=""
data:image/s3,"s3://crabby-images/8751c/8751cce535209215fbbed3e656993cce0ad5a56c" alt=""
- Also, the deviceID must be entered:
data:image/s3,"s3://crabby-images/f45b1/f45b1755670a667225e97ac9fa7388bef774315c" alt=""
- Running the program, a new Device key is generated:
data:image/s3,"s3://crabby-images/6397f/6397fdd6028aa7775c9310cfc2213490765d6d75" alt=""
- The Device key is written down or copied and added to the document with all the parameters and keys:
data:image/s3,"s3://crabby-images/23bd8/23bd8e02af77a181e1ce7be816ea25539ff87c24" alt=""
2 - Receive device to cloud messages
- ReadDeviceToCloudMessages.js displays the telemetry sent by the simulated device app, reading device-to-cloud messages from IoT Hub using the AMQP protocol.
- New folder:
data:image/s3,"s3://crabby-images/f2016/f2016fdba6971cde5d5cd4a320f18a7c8666f21c" alt=""
- Creating a new json package file and accepting all the default options:
data:image/s3,"s3://crabby-images/8a146/8a146dda244fda544fe32d961b258458decacba7" alt=""
- Installing azure-event-hubs package and saving it:
data:image/s3,"s3://crabby-images/2f3a1/2f3a17724a3d8276eabaa233e5d87a1e04a25208" alt=""
- Writing the program ReadDeviceToCloudMessages.js:
data:image/s3,"s3://crabby-images/7aaac/7aaac77f24c7b8f7932e4b1aef61575285e75c5d" alt=""
data:image/s3,"s3://crabby-images/b7f67/b7f670fa77f2d44a2131e09678f9ca61573db3fa" alt=""
- As before, it is important to notice that the connection string key must be introduced in the variable connectionString.
3 - Simulated Device
- SimulatedDevice.js connects the IoT hub with the device identity created earlier, and sends a telemetry message every second using the MQTT protocol.
- New folder:
data:image/s3,"s3://crabby-images/65a57/65a57e8192821aa827772b0492189dc9fae4688d" alt=""
- json package:
data:image/s3,"s3://crabby-images/3a1a9/3a1a9e6375094dc2ed398623826d91f3ca3a49b7" alt=""
- Installing azure-iot-device and azure-iot-device-mqtt:
data:image/s3,"s3://crabby-images/24d80/24d802959633662ffe2937f247a09148bd56a795" alt=""
- Writing the program, and using the connectionString variable with the Device key value originated at the section Create a device identity (point 1 of this exercise):
data:image/s3,"s3://crabby-images/452ca/452ca1124c5351d33b41cc129ebdc76a9c439707" alt=""
data:image/s3,"s3://crabby-images/d5f13/d5f133af23f5ffe18a84a505e41378079ca7f74f" alt=""
- All of these parameters must be carefully entered:
data:image/s3,"s3://crabby-images/75d9c/75d9c1c72e9a72305a88ae5b4e4384023e2f0d40" alt=""
data:image/s3,"s3://crabby-images/a3081/a3081e9d55f538e1d69f34821400459c6ed2b837" alt=""
data:image/s3,"s3://crabby-images/bb6e0/bb6e09df7fdbf716999b7dfa8ed1c0726a4d5b3e" alt=""
data:image/s3,"s3://crabby-images/917f9/917f994614b9bb21788144ba4759a1d01aa2008a" alt=""
4 - Running the application
- To run the two applications a separate console must be used, so that the communication between the simulated device and the IoT hub can be displayed.
- Running SimulatedDevice.js to send telemetry data to the IoT hub:
data:image/s3,"s3://crabby-images/98d58/98d587f60f6e0fc4cc4ea935921cf5ab477be93d" alt=""
- Running ReadDeviceToCloudMessages.js to monitor the IoT hub:
data:image/s3,"s3://crabby-images/1d5c2/1d5c29bea4e9470cdd67957a2cd0927200909285" alt=""