IoT Application Server

Objective

Our goal in this lab is to develop an application server that can be used for processing and visualizing IOT data with open source software. The application server can be used with data from any source that supports the ability to output data to an MQTT stream.

alt text

Getting Started

These instructions will take you through setting up a Node-RED dashboard.

Note: Windows and Debian Linux were used to develop and validate this project. The same applications can be deployed on other Linux distributions, potentially, with some minor modifications.

In this lab you will

  1. Set Up the MQTT Data Flow
  2. Format the Data
  3. Create a Basic Dashboard

You will need:

  • Linux or Windows Host
  • Node.js
  • Node-RED
  • Mosquitto
  • MQTT

Node-RED Set Up

Installation

  1. Install the latest LTS version of Node.js
    1. To verify whether this was installed properly run node -v and npm -v (the system should display what node and npm version is installed on your system)
  2. Install Node-RED locally with npm

Check

  1. Check whether you installed it correctly by running node-red in your terminal
  2. Navigate to http://localhost:1880/ which should automatically direct you to your flow (unless you changed the port number in configuration)

Security

Follow this tutorial on setting up a username and password to secure your Node-RED flows.

MQTT Set Up

Moquitto Installation

  1. Install Mosquitto
    1. Use this link for Windows
    2. Use this link for Linux
  2. Make sure it is installed correctly by running mosquitto -h in your mosquitto folder
    1. Another way to check is by running netstat -na and looking for a listener on port 1883 (unless you changed it from the default in your configuration file)

Mosquitto Configuration

Configure your Mosquitto MQTT broker with username and password here

Mosquitto Validation

Validate and troubleshoot Mosquitto connectivity and authenication issues here

Setting Up Your Node-RED Flow

  1. Set up your publishing flow like this

alt text

  1. Set up your subscribing flow like this

alt text

  1. Configure your MQTT nodes by making sure that they have the same topic and are on the same server

    1. If you set up a username and password, make sure you enter that information into the security tab when you edit the MQTT server
  2. You should be able to see the timestamp in your debug window if you press on the inject node

alt text

Formatting the Data

Right now, our timestamp is in a number format, but we want to convert it into a Date. Here we use a function node to format our data.

Your subscribing flow should look like this

alt text

Making a Dashboard

Attach a text node and make a new dashboard group and tab to contain it. After clicking on the inject node, your dashboard (at the URL http://localhost:1880/ui/) should look like this.

alt text

Your Node-RED flow should look like this

alt text

Conclusion

In this lab, you learned how to set up and install Node-RED and Mosquitto (an MQTT broker). You formatted data from the MQTT data stream and created a basic dashboard for people to view.

Next Steps

Check out some extensions to this basic app server

View code on GitHub

Code Exchange Community

Get help, share code, and collaborate with other developers in the Code Exchange community.View Community
Disclaimer:
Cisco provides Code Exchange for convenience and informational purposes only, with no support of any kind. This page contains information and links from third-party websites that are governed by their own separate terms. Reference to a project or contributor on this page does not imply any affiliation with or endorsement by Cisco.