Following the second part of the OPC Router tutorial, I’m presenting how to load MQTT data into an InfluxDB time-series database now. Remember, we’re configuring and running a project for “Papín”, a fictional potato bread factory.
Why an OPC Router tutorial with MQTT?
Because “learning by doing” with examples is fun. Also, this particular functionality can bring us an interesting use case: the ability to send telemetry from a device with resource constraints or limited network bandwidth. See below a list of posts that complete this tutorial:
- Getting Started with OPC Router
- Connect an OPC DA server to Microsoft SQL Server
- Connect an MQTT data source to InfluxDB Cloud (this post)
- Perform multiple calculations within OPC Router
- Run an OPC Router application with Linux and Docker
- Build a process data simulator with Python, CSV and OPC Router
- Explore basic RESTful web services within OPC Router
- Build a Telegram basic interaction within OPC Router
- Build an SMS basic interaction within OPC Router
- Build a WhatsApp basic interaction within OPC Router
- Build a Teams basic interaction within OPC Router
- Explore advanced RESTful web services within OPC Router
- Run an OPC Router application with Portainer
Working with OPC Router, MQTT, and InfluxDB Cloud
Knowing your Plugins
- To begin with, the configuration of OPC Router starts with your licensed plugins. There are several categories such as “Cloud / IoT”, “Topfloor”, “Shopfloor”, “Storage”, “Advanced”, “Messaging” and “Printer”.
data:image/s3,"s3://crabby-images/faec5/faec59680d0fa6e8fa0110e6c0b37ef8aa2e98a5" alt="opc router tutorial mqtt 1"
data:image/s3,"s3://crabby-images/bfcb4/bfcb45dcf678615f57ab747303edbcd4dc346c34" alt="opc router tutorial mqtt 2"
- Make sure to notice MQTT and InfluxDB 2.0.
Knowing your Transfer Objects
- At this point, we’re going to need four (4) transfer objects to solve our use case:
data:image/s3,"s3://crabby-images/8b279/8b279aa92fd9c6de0e080294b1ac370e3a581d37" alt="opc router tutorial mqtt 3"
- Make sure to notice Variables, Constant Values, MQTT trigger, and InfluxDB 2.0.
Creating an InfluxDB Cloud account
- Let’s go here to start creating your free InfluxDB Cloud account. If you want, you could sign up with a Google or Microsoft account, even with your work email address.
data:image/s3,"s3://crabby-images/dcf41/dcf41ee6d1c9b97144cb091f97bd583150355af6" alt="opc router tutorial mqtt 4"
- Then, choose a provider and region where you want to store your data. enter your company name and agree to the Terms of Service.
data:image/s3,"s3://crabby-images/3112e/3112ea047d1619e074eed6277a355e1d185332b0" alt="opc router tutorial mqtt 5"
- Select the “Free” plan. You can upgrade later at any time.
data:image/s3,"s3://crabby-images/18477/18477871b9ab85251bd0c8e63503af493b62161c" alt="opc router tutorial mqtt 6"
- Notice your “Get Started” dashboard once you logged in.
data:image/s3,"s3://crabby-images/fd192/fd192f657cf93336c1c1d752de1105f8fa782919" alt="opc router tutorial mqtt 7"
- Go to “Organization > Settings” and register your “Cluster URL” (Host).
data:image/s3,"s3://crabby-images/50049/500494310e1ba412dea75abcf1d998b3e953a02f" alt="opc router tutorial mqtt 8"
data:image/s3,"s3://crabby-images/7bc98/7bc98dbd4232fd2cf939d907e33e2576872cea01" alt="opc router tutorial mqtt 9"
- Also, register your own “User ID” and “Organization ID”.
data:image/s3,"s3://crabby-images/a50bd/a50bdc4c2c54d5cde31b65a73a0d897d883c8d2d" alt="opc router tutorial mqtt 10"
- At this point, go to “API Tokens” and generate a new API token.
data:image/s3,"s3://crabby-images/a00f8/a00f8cd773cc275ce7e4ac834d97b1255926b1e6" alt="opc router tutorial mqtt 11"
- Select “All Access API Token” as a key to authenticate your complete access to the InfluxDB Cloud account.
data:image/s3,"s3://crabby-images/82623/8262334df37055083f7617ec6428186cee6b2c20" alt="opc router tutorial mqtt 12"
- Enter a description for the new token and press the “SAVE” button. Make sure to copy your new custom API token now because you won’t be able to see it again!
data:image/s3,"s3://crabby-images/e36af/e36af96d058c52785723c62fb3258d2af399c104" alt="opc router tutorial mqtt 13"
- Go to the “Buckets” tab. A bucket is a named location where time-series data is stored. All buckets have a Retention Policy, a duration of time that each data point persists. Next, press the “CREATE BUCKET” button to start.
data:image/s3,"s3://crabby-images/2219e/2219ed512a4a609c07614fc914efbdc7640c44c6" alt="opc router tutorial mqtt 14"
data:image/s3,"s3://crabby-images/bf9f4/bf9f4652be48d5b5db49f8ff82a3cdc528f067ea" alt="opc router tutorial mqtt 15"
- Create your “pv_tb_rv_vsd_motor_i” bucket.
data:image/s3,"s3://crabby-images/2e16f/2e16f39b6b37101ea3fdafec058f989b9569ab23" alt="opc router tutorial mqtt 16"
- Check the creation of your new bucket.
data:image/s3,"s3://crabby-images/26a0c/26a0cbeed8b2f78cc53a5d702d693d1a96090d1a" alt="opc router tutorial mqtt 17"
Configuring your Plugins
- Following identification, OPC Router needs to configure every licensed plugin. Let’s start creating a new plug-in instance with MQTT (double click on the object):
data:image/s3,"s3://crabby-images/62934/629349bf06212c135424d01a521c5b814e310c05" alt="opc router tutorial mqtt 18"
data:image/s3,"s3://crabby-images/64f02/64f0257331ff93e91693fcfae8b72a8d0edc7f05" alt="opc router tutorial mqtt 19"
- At this point, define a remote MQTT broker using a Raspberry Pi and press the “Check connection” button to test connectivity. Finally, press the “OK” button twice to save changes and close the window.
data:image/s3,"s3://crabby-images/870d7/870d75a77be070ac0c2d79115ffbb49850c134fc" alt="opc router tutorial mqtt 20"
data:image/s3,"s3://crabby-images/fc7c7/fc7c7db182bf6a420f82e29a7d694c58b612395b" alt="opc router tutorial mqtt 21"
data:image/s3,"s3://crabby-images/34276/34276d9000061d62931845e9def84bb374220e72" alt="opc router tutorial mqtt 22"
- After that, let’s start creating a new plug-in instance with InfluxDB 2.0:
data:image/s3,"s3://crabby-images/bfd77/bfd77e77f8b737e23bbb29d6e2c83cfe1518ebad" alt="opc router tutorial mqtt 23"
data:image/s3,"s3://crabby-images/d1e43/d1e43d8e680aa912a5947327c5b0db2ad29bd9a2" alt="opc router tutorial mqtt 24"
- Then, define a remote InfluxDB Cloud link and press the “Check connection” button to test connectivity.
data:image/s3,"s3://crabby-images/440ec/440eccbf268009bbfcd93b3f6abae3539f9a5f93" alt=""
data:image/s3,"s3://crabby-images/924aa/924aab1aa2cac9c0ffb6346bc195035146e0d8e0" alt=""
Creating your Third Template
- In similar fashion to the second part of the tutorial, a template is the correct approach once again. Let’s create a new InfluxDB Cloud template MCurr within IFDB folder (VSD motor current):
data:image/s3,"s3://crabby-images/37f66/37f66255a38881f2a86c5ac58805eed00bb88736" alt=""
data:image/s3,"s3://crabby-images/4502f/4502f8c2b6de04cb5f270101c3ef29a73d402d4f" alt=""
- Watch an empty design panel so you can start building your template:
data:image/s3,"s3://crabby-images/e49a9/e49a985a71cfefdc2bfb3a25f5c11455a518130c" alt=""
- Drag and drop these two blocks as shown here. Additionally, make sure to create template variable “cd_location3“:
data:image/s3,"s3://crabby-images/7aaad/7aaad69e57c28f97fa54a502212850346ab9021e" alt=""
- Insert the MQTT trigger block:
data:image/s3,"s3://crabby-images/746fd/746fd1b16c040e8d0424e3343fb6db46a9f865b2" alt=""
data:image/s3,"s3://crabby-images/0595a/0595a9b96c79df6a0ebb07aace79e79df0242513" alt=""
- Make sure to create template variable “ds_mqttb_connection” for MQTT links:
data:image/s3,"s3://crabby-images/3f0d8/3f0d844a1a84741611b953780337e5b3d4601a55" alt=""
- Edit the MQTT trigger block and make sure it looks like this:
data:image/s3,"s3://crabby-images/14e13/14e1329c385029e604419f04e11de7a103d55632" alt=""
data:image/s3,"s3://crabby-images/9d329/9d329ceed79e39696aaa9d6f6af4719930dafef3" alt=""
- Insert the InfluxDB 2.0 block:
data:image/s3,"s3://crabby-images/29d69/29d69b40924492b24f963c6bdfc84f0e47e32f18" alt=""
data:image/s3,"s3://crabby-images/7b6be/7b6be1a1bd49db940b0b4d1fe50ac12f123e5f0d" alt=""
- Edit the INSERT operation and make sure it looks like this:
data:image/s3,"s3://crabby-images/40b7e/40b7e5eb3f6324cb70b2fa6fcbb53e7cd28562f4" alt=""
data:image/s3,"s3://crabby-images/a823d/a823deb1d7a7bb0697e3513300caa034158afff5" alt=""
- Make sure to link blocks as shown here to complete your third template:
data:image/s3,"s3://crabby-images/57e04/57e04bb014253cd203c8fcaa240b28b2bda24fe1" alt=""
Working with Instances from Templates
- With your third template, a new instance is required now. Start creating it using the contextual menu:
data:image/s3,"s3://crabby-images/1d7d8/1d7d831480b01ee0408745233660b88acb56218d" alt=""
data:image/s3,"s3://crabby-images/8cb85/8cb854b7358f692f50d2a00f2e1516139819ce00" alt=""
- Check the new instance:
data:image/s3,"s3://crabby-images/b3260/b326046c3a84bdf328895473e6b570a23eb3a487" alt=""
- In the design panel, double click to check values in template variables according to location and actual MQTT link:
data:image/s3,"s3://crabby-images/cf79f/cf79f0cf9e609ed3e053a8bf2bbc56a544e8d446" alt=""
data:image/s3,"s3://crabby-images/8c7ad/8c7ad9aa1bea554c604b426f38751a4e3fb55680" alt=""
Compile, Save and Publish your OPC Router Project Configuration with MQTT and InfluxDB Cloud
- At this time, you need to compile, save and publish the connection you just created by clicking the “Go productive” button:
data:image/s3,"s3://crabby-images/3decf/3decf094c59d95ac21a6403df29363bc55561258" alt=""
data:image/s3,"s3://crabby-images/7036a/7036afb3cc68a575a13bc6a6055c495ea9dbacf3" alt=""
data:image/s3,"s3://crabby-images/19597/1959787634cafd0803f6b0d543aa307e5c741376" alt=""
- Meanwhile, the project is saved and published.
data:image/s3,"s3://crabby-images/65600/65600c443d4b4addd44cd92878fef4628bf21cf3" alt=""
- Press the “Yes” button to start the OPC Router service and run your application.
data:image/s3,"s3://crabby-images/d717c/d717c9c579c49a6b84b97b71f2af909ed322ae96" alt=""
Publish and Subscribe to MQTT Data
- From a Raspberry Pi, publish and subscribe to some MQTT test data:
$ mosquitto_pub -h 192.168.1.188 -t "vsd_motor_i" -m 122.5 -d
data:image/s3,"s3://crabby-images/89cfe/89cfedf11b5a62ec9b0560211e5833c68ed5125c" alt=""
data:image/s3,"s3://crabby-images/eea94/eea94dad0eb7c129a9255677806be34f51d3c3bf" alt=""
$ mosquitto_pub -h 192.168.1.188 -t "vsd_motor_i" -m 111.8 -d
data:image/s3,"s3://crabby-images/e494a/e494ade3a3e785ad2a9a677eaa04059d4d295747" alt=""
data:image/s3,"s3://crabby-images/a94a4/a94a4561157a65cd76e1a9ddacf5c0309b3138d6" alt=""
$ mosquitto_pub -h 192.168.1.188 -t "vsd_motor_i" -m 108.2 -d
data:image/s3,"s3://crabby-images/f35b5/f35b59574d39ce081820178e1b85d5cf6dbac786" alt=""
data:image/s3,"s3://crabby-images/a2792/a27928d5ff6f761769053222829c55fd9aaa8095" alt=""
Check Compiled Connection State
- Finally, you should check the state of your compiled connection by pressing the “State” button:
data:image/s3,"s3://crabby-images/0b743/0b743010cdc8cc02054575ed03ae1baecab3f232" alt=""
data:image/s3,"s3://crabby-images/160d8/160d8b09b9ff629d662543413f3b471a164675ae" alt=""
- You should notice an execution time visually (it’s 1048.09 milliseconds in this example):
data:image/s3,"s3://crabby-images/91510/915108392465201b3340c3c072346fcc0bf6a30e" alt=""
Verify OPC Router Data Transfer from MQTT to InfluxDB Cloud
- Additionally, you can verify data transfer within the Data Explorer web interface:
data:image/s3,"s3://crabby-images/e2e37/e2e3703895f8d0dee49993d5b0d2f74b91bdcc05" alt=""
data:image/s3,"s3://crabby-images/efb1c/efb1c6db163e369c6e210effe82578a85cc8a33c" alt=""
Control OPC Router service
- You are able to start, stop or restart the OPC Router service when needed.
data:image/s3,"s3://crabby-images/41a0a/41a0a9f6d370949e17be4cddb3ccbebd110bd6ce" alt=""
data:image/s3,"s3://crabby-images/36203/36203ded97e46c84ff68b2e5794748808523767a" alt=""
Did you enjoy this OPC Router tutorial with MQTT? I’d love to hear from you.
Stay tuned and follow part 4 of this tutorial! 😎
For other articles like this one in English, click here. To see them in Spanish, click here.