Open-source IoT Platform

Device management, data collection, processing and visualization
for your IoT projects
Learn about Thingsboard

Wednesday, December 21, 2016

Raspberry Pi GPIO control over MQTT using Thingsboard

Thingsboard is an open-source server-side platform that allows you to monitor and control IoT devices. It is free for both personal and commercial usage and you can deploy it anywhere. If this is your first experience with the platform we recommend to review what-is-thingsboard page and getting-started guide.

This sample application will allow you to control GPIO of your Raspberry Pi device using Thingsboard web UI. We will observe GPIO control using Led connected to one of the pins. The purpose of this application is to demonstrate Thingsboard RPC capabilities.

Raspberry Pi will use simple application written in Python that will connect to Thingsboard server via MQTT and listen to RPC commands. Current GPIO state and GPIO control widget is visualized using built-in customizable dashboard.

The video below demonstrates the final result of this tutorial.





Prerequisites

You will need to Thingsboard server up and running. Use either Live Demo or Installation Guide to install Thingsboard.

List of hardware and pinouts

  • Raspberry Pi - we will use Raspberry Pi 3 Model B but you can use any other model.

  • Led and corresponding resistor

  • 2 female-to-male jumper wires

Wiring schema

Since our application will allow to control state of all available GPIO pins, we recommend to attach some LEDs to those pins for visibility. You can use this basic instruction or another one to wire some LEDs.

Programming the Raspberry Pi

MQTT library installation

Following command will install MQTT Python library:

sudo pip install paho-mqtt

Application source code

Our application consists of single python script that is well commented. You will need to modify THINGSBOARD_HOST constant to match your Thingsboard server installation IP address or hostname. Use “demo.thingsboard.io” if you are using live demo server.

The value of ACCESS_TOKEN constant corresponds to sample Raspberry Pi device in pre-provisioned demo data. If you are using live demo server - get the access token for pre-provisioned “Raspberry Pi Demo Device”.

resources/gpio.py
import paho.mqtt.client as mqtt
import RPi.GPIO as GPIO
import json

THINGSBOARD_HOST = 'YOUR_THINGSBOARD_IP_OR_HOSTNAME'
ACCESS_TOKEN = 'RASPBERRY_PI_DEMO_TOKEN'

# We assume that all GPIOs are LOW
gpio_state = {7: False, 11: False, 12: False, 13: False, 15: False, 16: False, 18: False, 22: False, 29: False,
              31: False, 32: False, 33: False, 35: False, 36: False, 37: False, 38: False, 40: False}


# The callback for when the client receives a CONNACK response from the server.
def on_connect(client, userdata, rc):
    print('Connected with result code ' + str(rc))
    # Subscribing to receive RPC requests
    client.subscribe('v1/devices/me/rpc/request/+')
    # Sending current GPIO status
    client.publish('v1/devices/me/attributes', get_gpio_status(), 1)


# The callback for when a PUBLISH message is received from the server.
def on_message(client, userdata, msg):
    print 'Topic: ' + msg.topic + '\nMessage: ' + str(msg.payload)
    # Decode JSON request
    data = json.loads(msg.payload)
    # Check request method
    if data['method'] == 'getGpioStatus':
        # Reply with GPIO status
        client.publish(msg.topic.replace('request', 'response'), get_gpio_status(), 1)
    elif data['method'] == 'setGpioStatus':
        # Update GPIO status and reply
        set_gpio_status(data['params']['pin'], data['params']['enabled'])
        client.publish(msg.topic.replace('request', 'response'), get_gpio_status(), 1)
        client.publish('v1/devices/me/attributes', get_gpio_status(), 1)


def get_gpio_status():
    # Encode GPIOs state to json
    return json.dumps(gpio_state)


def set_gpio_status(pin, status):
    # Output GPIOs state
    GPIO.output(pin, GPIO.HIGH if status else GPIO.LOW)
    # Update GPIOs state
    gpio_state[pin] = status


# Using board GPIO layout
GPIO.setmode(GPIO.BOARD)
for pin in gpio_state:
    # Set output mode for all GPIO pins
    GPIO.setup(pin, GPIO.OUT)

client = mqtt.Client()
# Register connect callback
client.on_connect = on_connect
# Registed publish message callback
client.on_message = on_message
# Set access token
client.username_pw_set(ACCESS_TOKEN)
# Connect to Thingsboard using default MQTT port and 60 seconds keepalive interval
client.connect(THINGSBOARD_HOST, 1883, 60)

try:
    client.loop_forever()
except KeyboardInterrupt:
    GPIO.cleanup()

Running the application

This simple command will launch the application:

python gpio.py

Data visualization

In order to simplify this guide we have included “Raspberry PI GPIO Demo Dashboard” to the demo data that is available in each thingboard installation. Of course, you can modify this dashboard: tune, add, delete widgets, etc. You can access this dashboard by logging in as a tenant administrator. Use

in case of local Thingsboard installation.

Once logged in, open Dashboards->Raspberry PI GPIO Demo Dashboard page. You should observe demo dashboard with GPIO control and status panel for your device. Now you can switch status of GPIOs using control panel. As a result you will see LEDs status change on device and on the status panel.

Below is the screenshot of the “Raspberry PI GPIO Demo Dashboard”.

image

Next steps

Browse other samples or explore guides related to main Thingsboard features:

Your feedback

If you found this article interesting, please leave your feedback in the comments section, post questions or feature requests on the forum and “star” our project on the github in order to stay tuned for new releases and tutorials.

18 comments :

  1. I used raspberry pi in my final semester project, this raspberry is amazing and remarkable, just like you i am also a blogger and i recently publish e commerce websites in pakistan blog you can also read this blogpost too.

    ReplyDelete
  2. I was struggling with paraphrasing my dissertation, and the paraphrasing service uk
    team was a lifesaver! They helped me to reword my work effectively without compromising the meaning or quality. The turnaround time was quick, and the final product was fantastic. I highly recommend this service to any student struggling with paraphrasing their work!

    ReplyDelete
  3. Thanks for share this information to us !!!

    MyCCPay Log In

    ReplyDelete
  4. Thank you very much for the information; I will make an effort to learn more about it. Continue to propose posts like these and share posts that are as informative as they are. receiptify

    ReplyDelete
  5. I am extremely grateful for the information that you have provided; I will make an attempt to find out more about it. Maintain the practise of suggesting topics such as these and sharing posts that are equally as informative as these.
    cfa home

    ReplyDelete
  6. Sure, you can control Raspberry Pi GPIO via MQTT using Thingsboard. Explore features like automation and monitoring with Beetv APK for enhanced functionality.




    ReplyDelete
  7. I appreciate your message. We would be happy to help. So, please tell us briefly what the problem is that you're having. If you have any other questions, please let us know. krowd darden

    ReplyDelete
  8. That is all the helpful information I needed. I appreciate you sharing.
    Vampire Survivors

    ReplyDelete
  9. The problem of video streams being split into little files when recording is discussed in "Recording Video Streams (Movies) are Split into Small Files." This sometimes happens when recording video streams like movies or TV shows with specific programmes or equipment.

    The recording programme or file format may impose restrictions that necessitate the video stream being split into multiple files. To make video streams more manageable or to circumvent problems with high file sizes, certain recording applications may split them into many files. It's possible that the file format being used necessitates the splitting of video streams into multiple files.
    disney hub login

    ReplyDelete
  10. The ThingsBoard blog is a source for knowledge and analysis on the ThingsBoard open-source Internet of Things (IoT) platform. It provides IoT-related training, news, can police officer file protective order virginiaand debates to assist users get the most out of the platform for their IoT projects.

    ReplyDelete
  11. This is a fantastic guide for setting up IoT device control using Thingsboard and a Raspberry Pi. The clear instructions and sample code make it accessible even for beginners. IoT enthusiasts will find this immensely helpful in their projects.
    División de el Activos Divorcio Nueva York
    Casos de Divorcio en Nueva York

    ReplyDelete
  12. Online GRE test help Ethical considerations are a crucial aspect, and reputable services prioritize academic integrity.

    ReplyDelete
  13. The purpose of the sample app is to connect Raspberry Pi GPIO to Thingsboard via MQTT for IoT control. Deploy and customize Thingsboard for tailored IoT solutions liteblue

    ReplyDelete
  14. bandle offers a dynamic multiplayer experience where you can compete with friends or random opponents. This feature not only enhances the fun but also helps improve your word-forming abilities as you learn from others.

    ReplyDelete
  15. I love that they nail republic source their ingredients locally.

    ReplyDelete
  16. This is a great inspiring article.I am pretty much pleased with your good work. ฝากจอดรถยนต์อุบล You put really very helpful information. Keep it up.

    ReplyDelete