Connecting Prosys OPC UA Forge to Various MQTT Brokers
Guides
You can find our finished guides below. Click on the tab you are interested in to read the guide for that specific MQTT broker.
- Azure IoT Hub
- Amazon IoT Core
- Eclipse Mosquitto
- HiveMQ
- Azure Event Grid
Forge Publisher – Azure IoT Hub
During this tutorial, we will be using the following products:
- Azure IoT Hub
- Visual Studio Code with Azure IoT Hub extension
Connecting to Azure IoT Hub
- Create a new device in the IoT Hub.
- The connection information to the IoT Hub is as follows:
- Connection address: mqtts://”Hostname”:8883
- Client Id: “DeviceId”
- Username: “Hostname”/”DeviceId”/?api-version=2021-04-12
- Password: “SAS Token”
- Queue: devices/”DeviceId”/messages/events/
- Metadata Queue: devices/”DeviceId”/messages/events/metadata/
- The hostname is the name of your IoT Hub, and it can be seen on the front page of the IoT Hub.
- DeviceId is the name of the device you created.
- Generate the SAS Token with Visual Studio Code.
data:image/s3,"s3://crabby-images/4f2fe/4f2fe7611f9c7e5e165bb1b13317e4fe914b2be9" alt="vscode_sas - Prosys OPC Generating password (SAS Token) for Azure IoT Hub in Visual Studio Code"
- Open Prosys OPC UA Forge and add the OPC UA Publisher Module.
- In the OPC UA Publisher -tab, you will need to add at least a Connection, Writer Group, and either Variable or Event Data Set.
- Add a Connection to Azure using the connection information you previously collected.
data:image/s3,"s3://crabby-images/0edc4/0edc4dd99824164823f29f91e2bc63e747b9129a" alt="forge_connection - Prosys OPC Azure connection information in Forge"
- Create a Writer Group and choose a Variable or Event Data Set that the Writer Group Publishes. Remember to add the correct MQTT Topic Settings to the Writer Group.
data:image/s3,"s3://crabby-images/4c81a/4c81a1974b472c891cc01821bba993ba4503b1c8" alt="writer_group - Prosys OPC MQTT Topic settings for Azure IoT Hub"
- The Publisher should now be enabled, and the IoT Hub should receive data. You can check the sent messages from Visual Studio Code.
data:image/s3,"s3://crabby-images/7f6b6/7f6b6f816e938b8d6ba36dfd78d656a334ed75b0" alt="vscode_c2d - Prosys OPC Subscribing to Azure IoT Hub Publisher in Visual Studio Code"
Forge Publisher – Amazon IoT Core – Forge Subscriber
During this tutorial, we will be using the following products:
- Amazon IoT Core
Connecting to Amazon IoT Core
- Create a new single Thing in IoT Core/Manage/All devices/Things/Create Things.
- Enter a name for the Thing and set it to have no shadow.
- Auto-generate a new certificate and download all certificate files when prompted.
data:image/s3,"s3://crabby-images/ed51e/ed51e84a8e1e9a761aa1d4e9d556ea061a5eeb96" alt="aws_load_cert - Prosys OPC Certificate generation and downloading in AWS IoT Core"
- Create a new policy, IoT Core/Manage/Security/Policies.
- Give the policy a name and fill in the policy document information as shown in the image below.
data:image/s3,"s3://crabby-images/8587c/8587c1266775de4d4ab69cafc339349b516ae1c8" alt="aws_policy - Prosys OPC Policy document creation information in AWS IoT Core"
- To attach the created policy, go to IoT Core/Manage/Things/”name of the created Thing”/Certificates and choose the certificate you wish to add the policy to.
data:image/s3,"s3://crabby-images/24e77/24e77b8d3ea9072ce1f9acb74394b48695647a1f" alt="aws_attach_policy - Prosys OPC Security Policies in Amazon IoT Core"
- You can find the connection Endpoint from IoT Core/Test/MQTT test client/Connection details/Endpoint.
- Open Prosys OPC UA Forge and add the Publisher and Subscriber Modules.
- In the OPC UA Publisher -tab you will need to add at least a Connection, Writer Group, and either Variable or Event Data Set.
- Add a new Connection using the connection Endpoint from IoT Core and the certificates downloaded.
data:image/s3,"s3://crabby-images/37e37/37e376c7c05beb200ad4b03084a251317ddc789a" alt="aws_connection - Prosys OPC Forge connection screen for AWS IoT Core"
- Create a Writer Group and choose a Variable or Event Data Set that the Writer Group Publishes.
- Now, you should see some data in the IoT Core/Test/MQTT test client.
- Use Subscriber wildcard * for the topic filter.
- Lastly, create an MQTT subscriber. In Forge/Data Sources/OPC UA Subscribers, add a new Subscriber using the same certificate files and Endpoint address as for the publisher.
Forge Publisher – Eclipse Mosquitto – Forge Subscriber
During this tutorial, we will be using the following products:
- Docker Desktop
- Eclipse Mosquitto
Connecting to Eclipse Mosquitto
- Pull and run the eclipse-mosquitto image in Docker Desktop.
data:image/s3,"s3://crabby-images/17628/1762813b755924d94aaf8234e4b6801a1698f066" alt="dd_pull_and_run - Prosys OPC Docker Desktop Pull and Run eclipse-mosquitto image"
- Set the correct host port for the MQTT broker. In this case, we use the default port, 1883. Other settings are not necessary.
- Run the Docker container.
data:image/s3,"s3://crabby-images/2aadf/2aadf841032ed9d69463b600eac851aff80d922a" alt="dd_settings - Prosys OPC Docker Desktop new container"
- Open the configuration file from Files/mosquitto/config/mosquitto.conf and edit it with the following information:
- listener 1883
- allow_anonymous true
These commands allow external connections to port 1883.
data:image/s3,"s3://crabby-images/cdc5e/cdc5ec295d44e087dd19dd540f09e57f6f6014f0" alt="dd_conf - Prosys OPC Docker Desktop edit mosquitto.conf file"
- Save and restart the container.
data:image/s3,"s3://crabby-images/21e6c/21e6c84b4f3f7e2eed6d86bb8ef206ec92a67407" alt="dd_restart - Prosys OPC Docker Desktop save and restart container"
- Open Prosys OPC UA Forge and add the OPC UA Publisher Module.
- In the OPC UA Publisher tab, you will need to add at least a Connection, Writer Group, and either Variable or Event Data Set.
- Add a Connection to the Eclipse Mosquitto using the address mqtt://localhost:1883.
data:image/s3,"s3://crabby-images/50346/50346623e4e2534dc7d243ef3be717eefa9a95aa" alt="mosquitto_forge_new_connection - Prosys OPC Connecting Forge to localhosted Eclipse MQTT Broker"
- Create a Writer Group and choose a Variable or Event Data Set that the Writer Group Publishes.
- Now, let’s also add the Publisher.
- Use Subscriber wildcard * for the topic filter.
- Lastly, create an MQTT subscriber. In Forge/Data Sources/OPC UA Subscribers, add a new Subscriber using the same connection address as for the publisher.
Forge Publisher – HiveMQ – Forge Subscriber
During this tutorial, we will be using the following products:- Docker Desktop
- HiveMQ
Connecting to HiveMQ
- Pull and run the hivemq4 image in Docker Desktop.
data:image/s3,"s3://crabby-images/5cfa5/5cfa50d7f4b3432e55fa8be1f0f0c1e7fbd50777" alt="hive_mq_dd_pull_and_run - Prosys OPC HiveMQ docker desktop pull and run"
- Set the correct host port for the MQTT broker. In this case, we use the default port, 1883. If you are using the default ports for some other applications, change the ports.
- Run the Docker container.
data:image/s3,"s3://crabby-images/40548/40548d92ac3a57b3638a93679f9c1f1b721cba3d" alt="hivemq_dd_settings - Prosys OPC HiveMQ docker desktop settings"
- Open Prosys OPC UA Forge and add the OPC UA Publisher Module.
- In the OPC UA Publisher tab, you will need to add at least a Connection, Writer Group, and either Variable or Event Data Set.
- Add a Connection to the HiveMQ using the address mqtt://localhost:1883. The connection Name does not matter and to demonstrate that, I am using the same connection from the previous part of this tutorial.
data:image/s3,"s3://crabby-images/50346/50346623e4e2534dc7d243ef3be717eefa9a95aa" alt="mosquitto_forge_new_connection - Prosys OPC Connecting Forge to localhosted Eclipse MQTT Broker"
- Create a Writer Group and choose a Variable or Event Data Set that the Writer Group Publishes.
- Now, let’s also add the Publisher.
- Use Subscriber wildcard * for the topic filter.
- Lastly, create an MQTT subscriber. In Forge/Data Sources/OPC UA Subscribers, add a new Subscriber using the same connection address as for the publisher.
Forge Publisher – Azure Event Grid – Forge Subscriber
During this tutorial, we will be using the following products:Generating Certificates with OpenSSL
If you have installed Git to your device, you already have OpenSSL on your computer. On Windows computers, it is normally located in: C:\Program Files\Git\usr\bin\openssl.exe- Open the .exe file
- Generate a Certificate Authority (CA) Certificate and Key with command: openssl req -new -x509 -days -extensions v3_ca -keyout ca.key -out ca.crt
- Generate a client Key for the Publisher with command: openssl genrsa -out client-pub.key 2048
- Generate a Certificate Signing Request (CSR) with command: openssl req -out client-pub.csr -key client-pub.key -new
- Send the CSR to the CA to sign it with command: openssl x509 -req -in client-pub.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out client-pub.crt -days <duration>
- Now lets generate another Keypair for the Subscriber. Generate a client Key with command: openssl genrsa -out client-sub.key 2048
- Generate a CSR with command: openssl req -out client-sub.csr -key client-sub.key -new
- Send the CSR to the CA to sign it with command: openssl x509 -req -in client-sub.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out client-sub.crt -days <duration>
Configuring the Azure Event Grid
- Create a new Azure Event Grid Namespace. This may take several minutes.
data:image/s3,"s3://crabby-images/a5bb7/a5bb74b487bbd16679b3d463f2c4da71b180c38b" alt="createEventGrid - Prosys OPC Azure search for event grid"
- Enable the MQTT broker that is disabled by default. This may also take several minutes.
data:image/s3,"s3://crabby-images/1a886/1a886cb464dfc9b8ff3bd3a7de91179b28cd40de" alt="disabledBroker - Prosys OPC"
data:image/s3,"s3://crabby-images/60035/60035df1e2b42997c33d5ed69fb0105b98287bf5" alt="enableBroker - Prosys OPC"
- Next create two new clients, Subscriber and Publisher.
- Select the Thumbprint Match as the Validation Scheme. Then thumbprint can be check from the Certificates we created earlier.
data:image/s3,"s3://crabby-images/63a15/63a15b1a805891f19fecea688789d6c1804eb330" alt="createClient - Prosys OPC"
data:image/s3,"s3://crabby-images/f9bcf/f9bcfead9585ba283e92e404e656fe318a14405e" alt="certificateThumbprint - Prosys OPC"
- Create a topic space. You can use any name and template for it. In this demo we are using example template called contosotopic/topic1
data:image/s3,"s3://crabby-images/d83b9/d83b93815eda2c4db90e9caaf8ecc85524688612" alt="createTopicSpace - Prosys OPC"
- Create two Permission Bindings. One for the Publisher and one for the Subscriber.
data:image/s3,"s3://crabby-images/9eb56/9eb5675821aa5847b9b27c444166b9c1de4499d8" alt="createPermissionBinding - Prosys OPC"
Connecting Forge to the Azure Event Grid
- Open Prosys OPC UA Forge and add the OPC UA Publisher and Subscriber Modules.
- In the OPC UA Publisher tab, you will need to add at least a Connection, Writer Group, and either Variable or Event Data Set.
- Add a Connection to the Azure Event Grid using the address mqtts://<MQTT hostname>:8883. Choose the Publisher Certificate and Key that we created earlier. The Username must be the same as the clients name in the Azure Event Grid.
data:image/s3,"s3://crabby-images/8221c/8221cfb39f07bb345655f7780fef47ad4a2ea80f" alt="mqttAddress - Prosys OPC"
data:image/s3,"s3://crabby-images/6be2f/6be2fcf013c7bf5720abccd819704dea2fa6fe95" alt="forgePub - Prosys OPC"
- Lastly, create an MQTT subscriber. In Forge/Data Sources/OPC UA Subscribers, add a new Subscriber using the same connection address as for the publisher. This time use the client-sub Keypair.
data:image/s3,"s3://crabby-images/3d5e0/3d5e00945947469bb2210ffab37671c1c5d1bc71" alt="forgeSub - Prosys OPC"
Next Steps
To learn more about Forge and its capabilities, request a detailed introduction by emailing sales@prosysopc.com or using our contact form. We’d be delighted to provide tailored information about Forge that aligns with your interests and requirements.
If you want to test Forge yourself, we can provide you with an evaluation license to get you started. You can request an evaluation license by emailing our sales team or filling out the request form.
data:image/s3,"s3://crabby-images/9e7d6/9e7d677af06a32f7d35f1dba3a716612a1e4721f" alt="author-general-avatar - Prosys OPC A generic vector graphic of an author avatar"
Elias Nykänen
Software Engineer
Email: elias.nykanen@prosysopc.com