Following the fourth part of the OPC Router tutorial, I’m presenting how to run an OPC Router application in a Linux operating system with Docker on a Raspberry Pi 4. Remember, we’re configuring and running a project for “Papín”, a fictional potato bread factory.
Why an OPC Router tutorial with Linux?
Because “learning by doing” with examples is fun. Also, this particular functionality can bring us an exciting use case: the possibility of running data acquisition applications in operating systems other than Windows, which could result in better performance, fewer resources to consume, and less expensive hardware. 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
- Perform multiple calculations within OPC Router
- Run an OPC Router application with Linux and Docker (this post)
- 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
Prerequisites
Firstly, you’ll need:
- Raspberry Pi 4 🍇
- Ethernet network ➿
- Schematic diagram 📝
- Installation of Ubuntu Server on a Raspberry Pi post with Docker 📓
- OPC Router Config application 💻
Schematic Diagram
To illustrate this idea better, look at this:
data:image/s3,"s3://crabby-images/50c1b/50c1b9b3277b930d9ec1db935ea9100889ff89dc" alt=""
Getting Started
- First, run OPC Router Config.
data:image/s3,"s3://crabby-images/0f34e/0f34ee429dd7ff984dc5cd771ad41ff2320bc01f" alt="opc router tutorial linux 1"
- Wait for the OPC Router 4 GUI to load.
data:image/s3,"s3://crabby-images/03bbc/03bbc6972171378cb139cbbf4806d2a6132ad5f5" alt="opc router tutorial linux 2"
- Then, you should see something like this in the Start tab:
data:image/s3,"s3://crabby-images/30abf/30abf9ac302ce8b680bb94dedbfeedf6913e82e9" alt="opc router tutorial linux 3"
Configure OPC Router service for Docker
- To begin with, go to the “Plug-ins” section to configure the OPC Router service.
data:image/s3,"s3://crabby-images/d2ab8/d2ab8f6d79991b800d681705245a0d7a471baa75" alt="opc router tutorial linux 4"
- Following this, choose “Manual Docker setup”.
data:image/s3,"s3://crabby-images/21be2/21be2b1d0bc1666d371d769c2e61011797ff4a05" alt="opc router tutorial linux 5"
- In “Basic settings”, set your “Service Name” as the name of your Docker container.
data:image/s3,"s3://crabby-images/e943a/e943a05b90256f5fae2829633f961876c17f01c2" alt="opc router tutorial linux 6"
- After that, set your “Version” as the name of the latest runtime Docker container available and keep your desired timezone.
data:image/s3,"s3://crabby-images/b4f9f/b4f9fd24980dfb2830a1f8bf2cfe966d2a3907e6" alt="opc router tutorial linux 7"
- Also, press the “Set access data” button to specify authentication details to your Docker container.
data:image/s3,"s3://crabby-images/01506/01506d7d13e7f170bbe6ab525ef816e5228e7b62" alt="opc router tutorial linux 8"
- Enter your username and password.
data:image/s3,"s3://crabby-images/8aa66/8aa6684e9a5fd2895c411abce36f427bf36e1ef6" alt="opc router tutorial linux 9"
- At this point, watch your user credentials in “Access data”.
data:image/s3,"s3://crabby-images/bc514/bc514027e41acb20154791ede7321140ccf104de" alt="opc router tutorial linux 10"
- Press the “Portmappings” button to start exposing desired ports to reach.
data:image/s3,"s3://crabby-images/d6f8b/d6f8bd7ac80ef14363c52918c56c109a0423d855" alt="opc router tutorial linux 11"
- Select “UA server(49420:49420)” for this use case.
data:image/s3,"s3://crabby-images/76616/766163551cb90618fc5d82e5e184d0cba50f179c" alt="opc router tutorial linux 12"
- Press the “OK” button to save changes.
data:image/s3,"s3://crabby-images/946f3/946f36e303761288c2f258df7592c6058ecba256" alt=""
- Accept the End User License Agreement (EULA) and press the “Next” button.
data:image/s3,"s3://crabby-images/b3aed/b3aedb8fce0ce8d5bc7c2b51104b1d1a4b4835d9" alt=""
- Watch the command that will create and run your OPC Router Docker container.
data:image/s3,"s3://crabby-images/f7a5c/f7a5c1ebecf0ffb9d7be2e21ee1e14a1b3419527" alt=""
- Copy and paste this command:
docker run -d -p 51515:27017 -p 49420:49420 --env TZ=America/Caracas --env OR_DATABASE_USERNAME=opc-router --env MONGO_INITDB_ROOT_USERNAME=opc-router --env OR_DATABASE_PASSWORD=opc-router --env MONGO_INITDB_ROOT_PASSWORD=opc-router --env MONGO_ENABLE_AUTHENTICATION=true --env MONGO_ENABLE_TLS=true --env OR_DATABASE_ENABLE_TLS=true -v opc-router-opc-router-db:/data/db -v opc-router-opc-router-cert:/root/.dotnet/corefx/cryptography/x509stores/ --name opc-router --restart=unless-stopped opcrouter/runtime:latest --i-accept-eula
data:image/s3,"s3://crabby-images/d4419/d441964f6e19dca481e84fb940e121ce0f46030c" alt=""
- Connect to the Raspberry Pi using SSH and paste the command to run.
data:image/s3,"s3://crabby-images/88ffd/88ffdd5252a96891c9c289635943bc2a70e60643" alt=""
- Then, press <Enter> and wait for the download of the “opcrouter/runtime:latest” Docker image.
data:image/s3,"s3://crabby-images/bd150/bd1504d43ff0fdc4fc92f8c527a33c2de2ff9f61" alt=""
- Watch for the creation of the “opc-router” Docker container.
data:image/s3,"s3://crabby-images/0ee4e/0ee4e359d2ef11bbd0f907f22c29d291bdf1e2b2" alt=""
- Also, monitor your recently created “opc-router” Docker container by running:
$ docker ps
data:image/s3,"s3://crabby-images/67f86/67f86a721b259db7ee4a40f31b991a4feabc5025" alt=""
data:image/s3,"s3://crabby-images/90273/90273d8f9a4bd36790e8ac2f8ae9cfca6b58f2d8" alt=""
Check your Linux Docker service with OPC Router
- Go back to OPC Router Config, make sure you have the correct Raspberry Pi IP address and user credentials. Then, press the “Test” button to test connectivity.
data:image/s3,"s3://crabby-images/991a8/991a88079df0ec4a58fc70eb24a80534a8bc5eed" alt=""
- Press the “OK” button to confirm the valid connection.
data:image/s3,"s3://crabby-images/ed50f/ed50fe59abb6f27cf951cfccdea697ec3ce50337" alt=""
- So, press the “Done” button to to complete this step.
data:image/s3,"s3://crabby-images/43aa2/43aa23903466736a28f20b17ad39f0bdf0979b99" alt=""
- At this point, see the connection to the newly integrated “opc-router” service.
data:image/s3,"s3://crabby-images/3dd53/3dd5342e37b4591d9c34d2b51016e01dcdcf23c6" alt=""
- Finally, you’re ready to add plugins and transfer objects to run on your Raspberry Pi. Notice that some plugins are not supported on the target system because only works on Windows.
data:image/s3,"s3://crabby-images/23a75/23a7519899b65a9d90ed6a4e4d9b5bc8ffb8d02d" alt=""
Did you enjoy this OPC Router tutorial with Linux? I’d love to hear from you.
Stay tuned and follow part 6 of this tutorial! 😎
For other articles like this one in English, click here. To see them in Spanish, click here.