Skip to content
This repository has been archived by the owner on Dec 8, 2022. It is now read-only.

Latest commit

 

History

History
287 lines (253 loc) · 9.46 KB

File metadata and controls

287 lines (253 loc) · 9.46 KB

OMP OPC UA Connector via MQTT

The OMP OPC UA Connector (hereafter referred to as the Connector) via an MQTT broker, provides a mechanism to interact with OPC UA Servers over MQTT, wihtout having to implement the OPC UA protocol. The Connector allows you to:

  • Subscribe to nodes in order to receive telemetry messages when values change on these nodes
  • Do Read operations on nodes
  • Do Write operations on nodes
  • Do Call operations on nodes
  • Browse nodes
  • ...and more

This document serves as a guide to Configure, Build, Run and Test a generic implementation of the connector utilizing an MQTT broker.

Index

Prerequisites

  • Docker - To Build and run the Connector via Docker
  • OPC UA Server
  • MQTT Broker

How to Configure the Connector

Very important: An example settings file is provided moduleSettings.example.json (/samples/MqttSample/moduleSettings.example.json). Please copy the file and change the name to moduleSettings.json (/samples/MqttSample/moduleSettings.json). Change the required settings to suit your environment.

Understanding how the Connector's Configuration works

To understand how the connector's configuration works, it is important to understand how/where the Connector receives command requests and sends response/telemetry messages to and from the outside world.

Endpoint Description
Command This is the endpoint (MQTT Topic) where the outside world sends commands to the Connector
Response This is the endpoint (MQTT Topic) where the Connector sends the results of commands back
Telemetry This is the endpoint (MQTT Topic) where the Connector publishes telemetry messages for subscriptions

Configuring the Endpoints for MQTT

The configuration file has a couple of sections, but for brevity, we focus on the Communication section here. Under Communication there are 4 sub-sections of importance

  • Shared
 {
  ...,
  "Communication": {    
    "Shared": {
      "Type": "mqtt",
       ...

The Shared section groups MQTT settings (e.g Username, Password,..) that are shared between different endpoints (when the same MQTT Broker is used for all endpoints (Topics)). This reduces unnecessary repetition and bloating of the settings file.

Note: The Shared settings are read and applied first. Settings in subsequent sections will override those with the same name that appear in the Shared settings. For example, if the brokerAddress is set in Shared as 'Broker-Shared', and it is set again in the CommandEndpoint section (under NativeSettings) as 'Broker-Command', the final value of brokerAddress will be 'Broker-Command' and not 'Broker-Shared'.

  • Command Endpoint
 {
  ...,
  "CommandEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "commands",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
        ...

This is where the topic name, QoS Level and any other settings specific to the Command Endpoint are set.

  • Response Endpoint
 {
  ...,
  "ResponseEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "responses",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
        ...

This is where the topic name, QoS Level and any other settings specific to the Response Endpoint are set.

  • Telemetry Endpoint
{
  ...,
    "TelemetryEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "telemetry",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
        ...

This is where the topic name, QoS Level and any other settings specific to the Telemetry Endpoint are set.

Complete example of the Communication section in the settigns file:

 {
  ...,
  "Communication": {
    "SchemaUrl": "https://someSchemaStore.com/schemas/",
    "Shared": {
      "Type": "mqtt",
      "NativeSettings": {
        "brokerAddress": "localhost",
        "brokerPort": "1883",
        "username": "test",
        "password": "test",
        "clientId": null,
        "secure": false,
        "caCertData": null,
        "clientCaCertData": null,
        "ignoreCertificateValidation": false,
        "cleanSession": true,
        "willFlag": false,
        "willQosLevel": 0,
        "willTopic": null,
        "willMessage": null,
        "willRetain": false,
        "keepAlivePeriod": 60,
        "autoReconnectTimeInSeconds": 10,
        "sslProtocols": "None",
        "protocolVersion": "Version_3_1"
      }
    },
    "TelemetryEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "telemetry",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
    },
    "CommandEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "commands",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
    },
    "ResponseEndpoint": {
      "Type": "mqtt",
      "NativeSettings": {
        "topics": [
          {
            "topicName": "responses",
            "qosLevel": 1,
            "retain": false
          }
        ]
      }
    }
  },
  "Persistance": {
    "Type": "inMemory",
    "NativeSettings": {
    }
  }
}

How to configure MQTT

Internally the connector uses a 3rd party package that handles the specifics of the MQTT protocol (M2MqttDotnetCore).

NativeSettings

All the MQTT specific settings that are exposed by the 'M2MqttDotnetCore' package, can be configured in this NativeSettings section.
Below is a list of these settings (Note: This list contains the most common settings, but it is not meant to be an exhaustive list)

{
...,
"Communication": {
  "Shared": {
    "Type": "mqtt",
    "NativeSettings": {
      "brokerAddress": "localhost",
      "brokerPort": "1883",
      "username": "test",
      "password": "test",
      "clientId": null,
      "secure": false,
      "caCertData": null,
      "clientCaCertData": null,
      "ignoreCertificateValidation": false,
      "cleanSession": true,
      "willFlag": false,
      "willQosLevel": 0,
      "willTopic": null,
      "willMessage": null,
      "willRetain": false,
      "keepAlivePeriod": 60,
      "autoReconnectTimeInSeconds": 10,
      "sslProtocols": "None",
      "protocolVersion": "Version_3_1"
    }
  },
 ...
}

Note: Defaults will be applied for settings that are not explicitly configured.

How to Configure OPC UA

Internally the connector uses a 3rd party package that handles the specifics of the OPC UA protocol (OPC UA .NET Standard).

All the MQTT specific settings that are exposed by the 'OPC UA .Net Standard' package, can be configured in this NativeSettings section.
Below is a list of these settings (Note: This list contains the most common settings, but it is not meant to be an exhaustive list)

{
...,
"OpcUa": {
  "DefaultServerBrowseDepth": 3,
  "NodeBrowseDepth": 1,
  "EnableRegisteredNodes": false,
  "SubscriptionBatchSize": 100,/* We will batch to try and not overload the OPC UA Server */
  "ReadBatchSize": 100,/* When sending commands for many nodes in a single request we will batch these command to try and not overload the OPC UA Server */
  "RegisterNodeBatchSize": 100,/* We will batch to try and not overload the OPC UA Server */
  "AwaitSessionLockTimeoutSecs": 3,
  "ReconnectIntervalSecs": 10,/* We try and re-establish connection incase of network problem - How many seconds should we wait before retrying to connect*/
  "NativeSettings": {
  }
},
 ...
}

Note: Defaults will be applied for settings that are not explicitly configured.


How to Run

Mqtt Docker file

docker build -t mqqttest1 -f Dockerfile.MqttSample .
Docker Run
docker run -t mqtttest1

How to Test

Below is a list of commands that you can send over mqtt to the Command Topic of your choosing (same Command Topic that you configured in the connector prior to building).

Note: The current message models (API) is being reviewed and will change in the comming weeks [2021-10-18]


What is coming next?

Next we aim to provide an end-to-end environment via a docker compose file. Which will setup a OPC UA Server, MQTT Broker the actual Connector and a small sample app to send commands and see the results - a Preview link to the Docker Compose file can be seen here.