How to Transfer Data from MQTT to OPC UA

How to Transfer Data from MQTT to OPC UA

Open Automation Software can be used to transfer data from a MQTT broker to an OPC UA server locally or over a network. This guide walks you through downloading and installing OAS, configuring a MQTT connector, an OPC UA connector and one tag for each.

This guide uses the Data Route feature of OAS to transfer a Tag's value to another Tag's value using the Tag-to-Tag method.

For this guide on how to transfer data from a MQTT broker to an OPC UA server you will need:

  • To install MQTT Explorer or a similar tool for publishing messages to a MQTT broker and subscribing to messages in a MQTT broker

ℹ️ For simulation purposes, you will use the OPC UA server available in the OAS platform to write a Tag value. If you already have an OPC UA server or device available, you can also adjust your configuration to suit your own OPC UA server or device.

1 - Download and Install OAS

If you have not already done so, you will need to download and install the OAS platform.

Fully functional trial versions of the software are available for Windows, Windows IoT Core, Linux, Raspberry Pi and Docker on our downloads page.

On Windows, run the downloaded setup.exe file to install the Open Automation Software platform. For a default installation, Agree to the End User License Agreement and then click the Next button on each of the installation steps until it has completed.

If you'd like to customize your installation or learn more, use the following instructions:

The OAS Service Control application will appear when the installation finishes on Windows.

OAS Service Control

Click on each START SERVICE button to start each of the three OAS services.

2 - Configure OAS

Configure OAS is the main application used to configure local and remote OAS instances.

OAS Logo

  1. From your operating system start menu, open the Configure OAS application.

  2. Select the Configure > Tags screen.

    Important

    If this is the first time you have installed OAS, the AdminCreate utility will run when you select a screen in the Configure menu. This will ask you to create a username and password for the admin user. This user will have full permissions in the OAS platform.

    For further information see Getting Started - Security.

  3. If this is the first time you are logging in, you will see the AdminCreate utility. Follow the prompts to set up your admin account. Otherwise, select the Log In menu button and provide the Network Node, username and password.

    Log In Menu

    Log In Dialog

Info

In this guide you will use the Configure OAS application to configure the local Network Node which by default is localhost.

If you have installed OAS on a remote instance you can also connect to the remote instance by setting the relevant IP address or host name in the Network Node field.

3 - Create Security Group and User

When connecting to the local OAS OPC UA server, you need to configure a security group and a user to provide Tag read/write access. You'll need these credentials when creating the OPC UA connector instance later.

ℹ️ You can skip this step if you are connecting to your own third party OPC UA server.

  1. Select Configure > Security from the top menu.

    Configure drivers menu

  2. Provide a Group Name such as OPC UA Access.

    OPC UA security group name

  3. Click on the DISABLE ALL button to disable all access.

    Disable all access button

  4. In the Tags tab, ensure Get Tag Group Names and Get Tag Names is checked. This setting is required when browsing the OPC UA server tag structure once you get to the step of assigning the OPC UA data source to a Tag.

    Allow get tag groups and tag names

  5. In the Read Tags tab, ensure Disable All Tags From Reading is NOT checked.

    Read tags not disabled

  6. In the Write Tags tab, ensure Disable Add Tags From Writing is NOT checked.

    Write tags not disabled

  7. Click on the ADD GROUP button on the left hand side to add this security group configuration. Once added, the security group name should appear in the list of security groups.

    Add security group button

  8. Select Configure > Users from the top menu.

    Configure drivers menu

  9. Provide a User Name such as opcuauser, a password and set the Security Group as OPC UA Access.

    Set username and security group

  10. Click on the ADD USER button on the left hand side to add this user configuration. Once added, the user name should appear in the list of users.

    Add user button

4 - Configure MQTT Data Source Connector

In the following steps you will create and configure a MQTT Connector to connect to a third party broker so that tags will be able to subscribe to a topic. For the purposes of this guide, you will connect to the public HiveMQ broker.

  1. Select Configure > Drivers from the top menu.

    Configure drivers menu

  2. Enter a meaningful Driver Interface Name to give this driver interface instance a unique name.

  3. Ensure the following parameters are configured:

    • Driver: MQTT
    • IP Address: broker.hivemq.com
    • Port: 1883
    • Client ID: OAS_Client_123

    MQTT connector configuration

    Tips

    If you are having trouble reading a value in later steps, try to change the Client ID to something else as each client ID connecting to the broker must be unique.

  4. Click on the ADD DRIVER button on the left hand side to add this driver configuration. Once added, the driver interface name should appear in the list of drivers.

    Add MQTT driver button

5 - Add Tags

In this step you will add two tags. One tag to represent a JSON payload coming from an external data source and a second Tag to represent the sensor value.

  1. Select Configure > Tags from the top menu.

    Configure tags menu

  2. If you want to add a Tag to the root Tags group make sure the Tags node is selected in the tag list and click on the ADD TAG button.

    Add tag button

    If you want to add a Tag to a Tag Group, select the Tag Group first and then click on the ADD TAG button.

    You can also add Tag Groups by using the ADD GROUP button.

  3. Enter TemperatureSensorJSON as the Tag name and click the OK button.

    Add JSON tag to root node dialog

  4. Repeat the above two steps and add another Tag with the name TemperatureSensor.

    Add tag to root node dialog

6 - Assign MQTT as Tag Data Source

You will now set the Tag's data source to the MQTT driver interface that you created previously.

At the end of this section you will need to use a tool like MQTT Explorer to publish a value to your Tag.

  1. Select the Tag that will source data from the MQTT data source.

    Tag

  2. Set the following properties:

    • Data Type: JSON
    • Data Source: MQTT
    • Select Driver Interface: MQTT Data Source
    • Topic: oas/temperature

    MQTT tag configuration

  3. Click on the Apply Changes button to apply the changes.

  4. Using an MQTT testing tool to publish messages, such as MQTT Explorer, publish a JSON message to the oas/temperature topic.

    {
        "temperature": 24.9
    }
    

    MQTT explorer connection

    MQTT explorer connection advanced

    MQTT explorer connection publish

  5. Check that the quality status is Good Quality and you can see the JSON value.

    MQTT tag quality

7 - Parse JSON Payload

In this step you will extract the sensor value from the JSON payload using a Calculation Tag and JSON functions.

  1. Select the Tag that will represent the temperature value.

    Tag

  2. Set the Data Source value to Calculation.

  3. Next to the Calculation field click on the EDIT button.

  4. In the CALCULATION EDITOR window enter the following function.

    JSONQUERY([TemperatureSensorJSON.Value], "$.temperature")
    

    This will extract the temperature field from the TemperatureSensorJSON Tag value.

    Click the OK button to save the calculation.

    JSON calculation

  5. Click on the Apply Changes button to apply the changes.

  6. You should now see the sensor value in the Value field.

Tips

In this guide we used a separate calculation Tag in order to extract the sensor value. This is good practice when you want each Tag to have a single purpose and when you want to use the sensor value for other purposes like alarm thresholds and trending.

There is an alternative method using direct JSON access using the JSON property of a Tag. Instead of creating a separate TemperatureSensor calculation tag, the TemperatureSensorJSON tag can be accessed directly using the following syntax:

TemperatureJSON.JSON-temperature

This avoids having to create separate tags for each JSON property that you want to extract.

For more information on JSON handing, calculation and data access see the following:

8 - Add Simulated OPC UA Tag for Temperature Input

In this section you will create a Tag to represent a Temperature input in a destination OPC UA server. This Tag is used for simulation because we are using the OAS OPC UA server.

ℹ️ If you have your own third-party OPC UA server where you can simulate a Tag value then you can skip this step.

  1. Select Configure > Tags from the top menu.

    Configure tags menu

  2. Select the root Tags group and click on the ADD TAG button.

    Add tag button

  3. Provide a Tag Name such as OPCUA_TemperatureInput and click the OK button.

    Add sim tag to root node dialog

This tag will have a default value of zero. It will automatically update once your destination data connector and tag are configured.

9 - Configure OPC UA Data Destination

In the following steps you will create and configure a OPC UA Connector to connect to the OAS internal OPC UA server on port 58728 and act as a data destination.

ℹ️ If you want to use your own third-party OPC UA server you can provide the relevant Server URL and security credentials instead of the details provided below.

  1. Select Configure > Drivers from the top menu.

    Configure drivers menu

  2. Enter a meaningful Driver Interface Name to give this driver interface instance a unique name.

  3. Ensure the following parameters are configured:

    • Driver: OPC UA
    • Server Url: opc.tcp://localhost:58728
  4. Click on the BROWSE button to select a Security Profile. Choose the appropriate security profile. For this guide we will choose None:None:Binary.

    OPC UA security profile

  5. Enabled User Security and enter the Username and Password credentials created in the earlier section.

    OPC UA connector configuration

  6. Click on the ADD DRIVER button on the left hand side to add this driver configuration. Once added, the driver interface name should appear in the list of drivers.

    Add OPC UA driver button

10 - Add Data Destination Tag

In this section you will create a Tag to represent a data point that you want to write to.

  1. Select Configure > Tags from the top menu.

    Configure tags menu

  2. If you want to add a Tag to the root Tags group make sure the Tags node is selected in the tag list and click on the ADD TAG button.

    Add tag button

    If you want to add a Tag to a Tag Group, select the Tag Group first and then click on the ADD TAG button.

    You can also add Tag Groups by using the ADD GROUP button.

  3. Provide a Tag Name such as TemperatureOutput and click the OK button.

    Add tag to root node dialog

11 - Assign OPC UA as Tag Data Destination

You will now set the Tag's data source to the OPC UA driver interface that you created previously to act as a data destination.

  1. Select the Tag that will send data to the local OPC UA server.

    Tag

  2. Set the Data Source to OPC UA.

  3. Set the Select Driver Interface drop-down to the OPC UA Connector interface created previously.

  4. Click on the BROWSE button next to the NodeId field. In the BROWSE OPC UA SERVER window you can select the Local node, then select OPCUA_TemperatureInput. In the right hand VARIABLE section select - Value. You should see the Node ID is now OPCUA_TemperatureInput.Value.

    Click on the OK button to select this Tag.

    Browse OPC UA Server window

  5. Click on the Apply Changes button to apply the changes.

    OPC UA tag configuration

  6. Check that the quality status is Good Quality and the data in the Value field is defaulted to zero.

12 - Configure Tag-To-Tag Data Route

In this section you will configure the Target of the source Tag to be the destination Tag value. This means whenever the source Tag value is updated, the destination Tag value will also be updated. This will cause a write operation on any associated driver if it is supported.

  1. Select the source data Tag.

    Select temperature sensor Tag

  2. Select the Target tab.

    Select Target tab

  3. Enable the Enable Write to Target option.

    Enable Tag Target

  4. Click on the BROWSE button to select the destination tag.

    Select destination Tag

  5. Optionally, configure the Deadband property or enable Write Continuously to configure a continuous writing frequency.

    Complete Tag Target Configuration

  6. Click on the Apply Changes button to apply the configuration.

  7. To verify that your data transfer is working correctly, select the destination Tag and check that the Tag value matches the Tag value of the source Tag.

    Temperature Output Tag

    You should also verify that the Tag value has been written to your destination device. Depending on your configuration in step 5 above, this destination value should be updated whenever the source value changes or at the given frequency.

13 - Save Changes

Once you have successfully configured your OAS instances, make sure you save your configuration.

On each configuration page, click on the Save button.

If this is the first time you are saving the configuration, or if you are changing the name of the configuration file, OAS will ask you if you want to change the default configuration file.

If you select Yes then OAS will make this configuration file the default and if the OAS service is restarted then this file will be loaded on start-up.

If you select No then OAS will still save your configuration file, but it will not be the default file that is loaded on start-up.

Change Default Configuration Files dialog

Important

Each configuration screen has an independent configuration file except for the Tags and Drivers configurations, which share the same configuration file. It is still important to click on the Save button whenever you make any changes.

For more information see: Save and Load Configuration

Info

  • On Windows the configuration files are stored in C:\ProgramData\OpenAutomationSoftware\ConfigFiles.
  • On Linux the configuration files are stored in the ConfigFiles subfolder of the OAS installation path.