Difference between revisions of "OPC-UA Client"

From ESS-WIKI
Jump to: navigation, search
 
(75 intermediate revisions by one other user not shown)
Line 1: Line 1:
 +
 
= Introduction =
 
= Introduction =
  
 
OPC Unified Architecture (OPC UA) is a machine to machine communication protocol for industrial automation developed by the OPC Foundation.
 
OPC Unified Architecture (OPC UA) is a machine to machine communication protocol for industrial automation developed by the OPC Foundation.
  
 
+
 
  
 
= Features =
 
= Features =
Line 11: Line 12:
 
Feature:
 
Feature:
  
*Manage multi OPC-UA server and multi NodeID
+
*Connection with multiple OPC-UA server and multiple Node ID.
*Support anonymous authentication, username/password authentication.
+
*Support anonymous authentication, username/password authentication.
*Currently support up-link OPC-UA data to WISE-PaaS , not support down-link from WISE-PaaS.
+
*Support individual node data update interval of subscription.
*Detailed features, please see [https://docs.google.com/spreadsheets/d/1hxUJgHvcPYq8f44gmVVmwUCddHhOPBflSRkSKR0H9Q4/edit?ts=5ca2bfc9#gid=348272669 https://docs.google.com/spreadsheets/d/1hxUJgHvcPYq8f44gmVVmwUCddHhOPBflSRkSKR0H9Q4/edit?ts=5ca2bfc9#gid=348272669]
+
*Configurable node alias.  
 +
*Currently support up-link OPC-UA data to WISE-PaaS , not support down-link from WISE-PaaS.  
 +
*Detailed features, please see [https://docs.google.com/spreadsheets/d/1hxUJgHvcPYq8f44gmVVmwUCddHhOPBflSRkSKR0H9Q4/edit?ts=5ca2bfc9#gid=348272669 https://docs.google.com/spreadsheets/d/1hxUJgHvcPYq8f44gmVVmwUCddHhOPBflSRkSKR0H9Q4/edit?ts=5ca2bfc9#gid=348272669]  
 +
 
 +
 
 +
 
 +
= How to =
 +
 
 +
== Login ==
  
 +
Step 1. Launch a web browser (Google Chrome, Microsoft Edge ...) and open iEdge local web '''http://127.0.0.1:8081'''
  
 +
Step 2. Login iEdge local web:
  
= How to =
+
Account: '''root'''
 +
 
 +
Password: '''P@ssw0rd'''
 +
 
 +
[[File:Ros2-iedge-plugin-config-01.png|frameless|900x520px|Ros2-iedge-plugin-config-01.png]]
 +
 
 +
 
 +
 
 +
 
 +
== Config OPCUACLient Plugin ==
 +
 
 +
Please follow below steps to config OPCUAClient plugin to subscribe data from OPCUA Demo Server:
 +
 
 +
Step 1. Go to "Plug-ins" / Plugin Config to select OPCUAClient Plug-in
 +
 
 +
[[File:Opcua config UtQlI7p.png|border|800x480px|Opcua config UtQlI7p.png]]
 +
 
 +
Setp 2. Click "+" to add OPCUA project
 +
 
 +
[[File:Opcua config uNA2oIS.png|border|800x480px|Opcua config uNA2oIS.png]]
 +
 
 +
Setp 3. Edit new OPCUA Project
  
== Software Requirements ==
+
'''PROJECT NAME''': Enter a project name in unique<br/>
 +
'''ENDPOINT URL''': Endpoint URL of OPCUA Server<br/>
  
*MQTT broker
+
[[File:Opcua config 4nAWV6Z.png|border|800x480px|Opcua config 4nAWV6Z.png]]
*Node.js
 
  
  
 +
'''SECURITY MODE''': None / Sign<br/>
 +
'''USER NAME''': Account of OPCUA Server<br/>
 +
'''PASSWORD''': Password of OPCUA Server<br/>
  
== Installation ==
+
[[File:Opcua config N19A761.png|border|800x480px|Opcua config N19A761.png]]
  
'''Windows:'''
 
  
1. Download OPC-UA Service for Windows from Release Table.
+
Setp 4. Click "+" to add Sensor Node
  
2. Double click to launch the installer to install it to the machine.
+
[[File:Opcua config bgenwaL.png|border|800x480px|Opcua config bgenwaL.png]]
  
 +
Step 5. Edit Node Information
  
 +
'''NODEID''': Node ID you'd like to monitor<br/>
 +
'''NODENAME''': Node name you'd like to show<br/>
 +
'''INTERVAL(SEC)''': Subscribe/update interval in seconds<br/>
  
'''Linux:'''
+
[[File:Opcua config UeyMgDP.png|border|800x480px|Opcua config UeyMgDP.png]]
  
1. Download OPC-UA Service for Windows from Release Table.
 
  
2. Launch the installer to install it to the machine.
+
Step 6. Click "+" to add multiple nodes
  
 +
[[File:Opcua config BlLUlTV.png|border|800x480px|Opcua config BlLUlTV.png]]
  
  
== Configuration ==
+
Step 7. Click on delete icon to remove sensor node or click on edit icon to modify sensor node
  
EdgeSense OPC-UA client can manage multi OPC-UA setting and multi NodeID, below settings are default after OPC-UA client installation.
+
[[File:Opcua config jDMeU3E.png|border|800x480px|Opcua config jDMeU3E.png]]
  
  
<pre>{
+
Step 8. Click "Save" to complete node editing.
&nbsp; &nbsp; "OPCUA_Server":[
 
&nbsp; &nbsp; &nbsp; &nbsp; {
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "Name": "opcua-server-1",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "endpointUrl":"opc.tcp://opcua-server-1:66666",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "userIdentity": {
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "userName": "admin",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "password": ""
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }, &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "NodeIDList":[{"NodeId":"node-id-1","Name":"node-name-1", "Type":"v", "Interval":2},
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; {"NodeId":"node-id-2","Name":"node-name-2", "Type":"v", "Interval":2},
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; {"NodeId":"node-id-3","Name":"node-name-3", "Type":"v", "Interval":2}
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; ]
 
  
&nbsp; &nbsp; &nbsp; &nbsp; },
+
[[File:Opcua config qYQ76Qq.png|border|800x480px|Opcua config qYQ76Qq.png]]
&nbsp; &nbsp; &nbsp; &nbsp; {
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "Name": "opcua-server-2",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "endpointUrl":"opc.tcp://opcua-server-2:66666",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "userIdentity": {
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "userName": "admin",
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "password": ""
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }, &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; "NodeIDList":[{"NodeId":"node-id-4","Name":"node-name-4", "Type":"v", "Interval":2},
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; {"NodeId":"node-id-5","Name":"node-name-5", "Type":"v", "Interval":2},
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; {"NodeId":"node-id-6","Name":"node-name-6", "Type":"v", "Interval":2}
 
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; ]
 
  
&nbsp; &nbsp; &nbsp; &nbsp; }
 
&nbsp; &nbsp; ]
 
}
 
</pre>
 
  
 +
Setp 9. Click "Apply" to set and apply the new setting
  
 +
[[File:Opcua config 4A88VkH.png|border|800x480px|Opcua config 4A88VkH.png]]
  
Name
 
  
*Assign name for OPC-UA server.
+
Setp 10. You can monitor OPCUA sensor nodes at "Plugin List".
  
endpointUrl
+
[[File:Opcua config 9TEBrJF.png|border|800x480px|Opcua config 9TEBrJF.png]]
  
*Assign OPC-UA Server Endpoint URL ,&nbsp;format is opc:tcp://hostname:Port/&nbsp; , hostname also can use ip address.
+
<br/><br/>
  
userIdentity
 
  
*Assign username and password for&nbsp;OPC-UA server security check.
 
  
NodeIDList
+
==== How to import plugin settings ====
  
*NodeId: Assign node ID you'd&nbsp;like to monitor.
+
Step 1. Click Import button from OPCUAClient Configuration
*Name: Assign node name&nbsp;you'd&nbsp;like to show for the node.
 
*Type: Assign node type: "v" is Number, "bv" is Boolean, "sv" is String.
 
  
 +
[[File:Opcua config YngfFAe.png|border|800x480px|Opcua config YngfFAe.png]]
  
  
{| border="1" cellspacing="1" cellpadding="1" style="width: 156px;"
+
Step 2. Select target file you like to import
|-
 
| style="width: 51px; text-align: center;" | v
 
| style="width: 93px; text-align: center;" | Number
 
|-
 
| style="width: 51px; text-align: center;" | bv
 
| style="width: 93px; text-align: center;" | Boolean
 
|-
 
| style="width: 51px; text-align: center;" | sv
 
| style="width: 93px; text-align: center;" | String
 
|}
 
  
 +
[[File:Opcua config 4M3dBVW.png|border|800x480px|Opcua config 4M3dBVW.png]]
  
 +
Import successful
  
*Interval: Assign node data subscribe/update interval in seconds.
+
[[File:Opcua config V5bZgSz.png|border|800x480px|Opcua config V5bZgSz.png]]
  
  
 +
Step 3. Click APPLY to use imported configuration
  
 +
[[File:Opcua config R6EsxAJ.png|border|800x480px|Opcua config R6EsxAJ.png]]
  
 +
<br/><br/>
  
= Demonstrate =
 
  
== Connect a Unified Automation C++ Demo Server ==
 
  
1. Download Unified Automation C++ Demo Server from&nbsp;[https://www.unified-automation.com/downloads/opc-ua-servers.html https://www.unified-automation.com/downloads/opc-ua-servers.html]&nbsp;and install it to the server machine.
+
==== How to export plugin settings ====
  
2. Launch UaCppServer from Windows Program Menu.
+
Step 1. Click Export button from OPCUAClient Configuration
  
[[File:Uacpp-demo-server-01.png|800x480px|Uacpp-demo-server-01.png]]
+
[[File:Opcua config cy8mrSR.png|border|800x480px|Opcua config cy8mrSR.png]]
  
3. Config OPC-UA Client to&nbsp;connect to the sample Server,&nbsp; Endpoint URLs shown in below.
 
  
 +
Step 2. Explore the exported file
  
 +
[[File:Opcua config D1OvcOS.png|border|800x480px|Opcua config D1OvcOS.png]]
  
  
 +
==== How to use RESTful API to get history data ====
  
4. Edit opcua-client.json to set up client configuration, for&nbsp;example:
+
<br/>
  
 +
Example:
  
 +
<code>[http://172.22.12.84:8080//rmm/v1/data/devices/histdata?plugin=OPCUAClient&sensorId=/OPCUA-01/Node/Temperature&beginTs=2022-01-21%2017:30:00.000&endTs=2022-01-21%2017:35:00.000 http://172.22.12.84:8080//rmm/v1/data/devices/histdata?plugin=OPCUAClient&sensorId=/OPCUA-01/Node/Temperature&beginTs=2022-01-21%2017:30:00.000&endTs=2022-01-21%2017:35:00.000] </code>
  
  
 +
[[File:Opcua config fqD2QRq.png|border|800x480px]]
  
== Connect a OPC-UA sample server ==
+
<br/><br/>
  
1. Download and install OPC UA Sample Applications 1.02:&nbsp;[file://eossfs/ESS-Release/EdgeSense/Tools/OPCUA/ OPC UA Sample Applications 1.02.msi] are available at local server, please paste file's url in File Explorer to copy file.
 
  
2. After OPC UA Sample Applications 1.02.msi&nbsp; is installed, launch DataAccess Server.
+
= Appendix =
  
3. Config OPC-UA Client to&nbsp;connect to the sample Server,&nbsp; Endpoint URLs shown in application.
+
== Install OPCUA Demo Server ==
  
[[File:DataAccessServer screenshot.png|RTENOTITLE]]
+
Please follow below steps to setup OPCUA Demo Server:
  
 +
1. Download Unified Automation C++ Demo Server from&nbsp;[https://www.unified-automation.com/downloads/opc-ua-servers.html https://www.unified-automation.com/downloads/opc-ua-servers.html]&nbsp;and install it to the server machine.
  
  
4. Edit opcua-client.json to set up client configuration, for&nbsp;example:
+
2. Launch UaCppServer from Windows Start&nbsp;Menu.
<pre>{
 
    "OPCUA_Server":[
 
        {
 
            "Name": "OPCUA-SERVER-1",
 
            "endpointUrl":"opc.tcp://desktop-2lhi6fa:62547",
 
            "userIdentity": {
 
                "userName": "admin",
 
                "password": ""
 
            },           
 
            "NodeIDList":[{"NodeId":"ns=2;s=1:CC2001?Input2","Name":"CC2001-Input2", "Type":"v", "Interval":2},
 
                          {"NodeId":"ns=2;s=1:CC2001?Output","Name":"CC2001-Output", "Type":"v", "Interval":2},
 
                          {"NodeId":"ns=2;s=1:CC1001?Output","Name":"CC1001-Output", "Type":"v", "Interval":2}
 
                        ]
 
  
        }
+
[[File:Opcua config POK0jrK.png|border|800x480px|Opcua config POK0jrK.png]]
    ]
 
}
 
</pre>
 
  
 +
[[File:Uacpp-demo-server-01.png|800x480px|Uacpp-demo-server-01.png]]
  
  
= Release =
+
3. Information of OPCUA Demo Server, include Username/Password, Endpoint URL and Node IDs are shown in below.
  
<span style="font-size:larger;">This is an overview that displays Modbus Service&nbsp;versions and some stats and numbers for each release.</span>
 
  
{| border="1" cellspacing="1" cellpadding="1" style="width: 797px;"
+
{| border="1" cellpadding="1" cellspacing="1" style="width:500px;"
 
|-
 
|-
| style="width: 47px; text-align: center;" | <span style="font-size:larger;">Index</span>
+
| style="width: 220px;" | '''Username'''
| style="width: 63px; text-align: center;" | <span style="font-size:larger;">Version</span>
+
| style="width: 267px;" | '''Password'''
| style="width: 72px; text-align: center;" | <span style="font-size:larger;">Date</span>
 
| style="width: 71px; text-align: center;" | <span style="font-size:larger;">Platform</span>
 
| style="width: 76px; text-align: center;" | <span style="font-size:larger;">OS</span>
 
| style="width: 432px; text-align: center;" | <span style="font-size:larger;">Release Note</span>
 
| style="width: 432px; text-align: center;" | <span style="font-size:larger;">Installer</span>
 
 
|-
 
|-
| style="width: 47px; text-align: center;" | <span style="font-size:larger;">1</span>
+
| style="width: 220px;" | root
| style="width: 63px; text-align: center;" | <span style="font-size:larger;">v2.0.1</span>
+
| style="width: 267px;" | secret
| style="width: 72px; text-align: center;" | <span style="font-size:larger;">2019/12/31</span>
+
|}
| style="width: 71px; text-align: center;" | <span style="font-size:larger;">x86_64 CPU</span><br/>
 
| style="width: 76px; text-align: center;" | <span style="font-size:larger;">Windows</span><br/>
 
| style="width: 432px; text-align: center;" | <br/>
 
| style="width: 400px; text-align: center;" |
 
  
  
 +
 +
{| border="1" cellpadding="1" cellspacing="1" style="width:500px;"
 +
|-
 +
| style="width: 217px;" | '''Endpoint URL Format'''
 +
| style="width: 270px;" | opc.tcp://<Mancine Name or IP>:<Port>
 +
|-
 +
| style="width: 217px;" | '''Endpoint URL for this Demo'''
 +
| style="width: 270px;" | opc.tcp://Protocol-Converter-GW:48010
 
|}
 
|}
  
<span style="font-size:larger;">Above files are available at local server, please paste file's&nbsp;url in File Explorer&nbsp;to copy file. ([[EdgeSense_FAQ|How to access to EOSSFS file server]]&nbsp;)</span>
+
 
[[Category:Editor]]
+
 
 +
{| border="1" cellpadding="1" cellspacing="1" style="width:500px;"
 +
|-
 +
| style="width: 217px;" | '''Node Nmae'''
 +
| style="width: 270px;" | '''Node ID'''
 +
|-
 +
| style="width: 217px;" | AirConditioner_1.Humidity
 +
| style="width: 270px;" | ns=3;s=AirConditioner_1.Humidity
 +
|-
 +
| style="width: 217px;" | AirConditioner_1.Temperature
 +
| style="width: 270px;" | ns=3;s=AirConditioner_1.Temperature
 +
|-
 +
| style="width: 217px;" | AirConditioner_2.Humidity
 +
| style="width: 270px;" | ns=3;s=AirConditioner_2.Humidity
 +
|-
 +
| style="width: 217px;" | AirConditioner_2.Temperature
 +
| style="width: 270px;" | ns=3;s=AirConditioner_2.Temperature
 +
|}

Latest revision as of 02:33, 7 January 2025

Introduction

OPC Unified Architecture (OPC UA) is a machine to machine communication protocol for industrial automation developed by the OPC Foundation.

 

Features

EdgeSense OPC-UA Client aims to collect data from OPC-UA Server and control.

Feature:

 

How to

Login

Step 1. Launch a web browser (Google Chrome, Microsoft Edge ...) and open iEdge local web http://127.0.0.1:8081

Step 2. Login iEdge local web:

Account: root

Password: P@ssw0rd

Ros2-iedge-plugin-config-01.png

 


Config OPCUACLient Plugin

Please follow below steps to config OPCUAClient plugin to subscribe data from OPCUA Demo Server:

Step 1. Go to "Plug-ins" / Plugin Config to select OPCUAClient Plug-in

Opcua config UtQlI7p.png

Setp 2. Click "+" to add OPCUA project

Opcua config uNA2oIS.png

Setp 3. Edit new OPCUA Project

PROJECT NAME: Enter a project name in unique
ENDPOINT URL: Endpoint URL of OPCUA Server

Opcua config 4nAWV6Z.png


SECURITY MODE: None / Sign
USER NAME: Account of OPCUA Server
PASSWORD: Password of OPCUA Server

Opcua config N19A761.png


Setp 4. Click "+" to add Sensor Node

Opcua config bgenwaL.png

Step 5. Edit Node Information

NODEID: Node ID you'd like to monitor
NODENAME: Node name you'd like to show
INTERVAL(SEC): Subscribe/update interval in seconds

Opcua config UeyMgDP.png


Step 6. Click "+" to add multiple nodes

Opcua config BlLUlTV.png


Step 7. Click on delete icon to remove sensor node or click on edit icon to modify sensor node

Opcua config jDMeU3E.png


Step 8. Click "Save" to complete node editing.

Opcua config qYQ76Qq.png


Setp 9. Click "Apply" to set and apply the new setting

Opcua config 4A88VkH.png


Setp 10. You can monitor OPCUA sensor nodes at "Plugin List".

Opcua config 9TEBrJF.png




How to import plugin settings

Step 1. Click Import button from OPCUAClient Configuration

Opcua config YngfFAe.png


Step 2. Select target file you like to import

Opcua config 4M3dBVW.png

Import successful

Opcua config V5bZgSz.png


Step 3. Click APPLY to use imported configuration

Opcua config R6EsxAJ.png




How to export plugin settings

Step 1. Click Export button from OPCUAClient Configuration

Opcua config cy8mrSR.png


Step 2. Explore the exported file

Opcua config D1OvcOS.png


How to use RESTful API to get history data


Example:

http://172.22.12.84:8080//rmm/v1/data/devices/histdata?plugin=OPCUAClient&sensorId=/OPCUA-01/Node/Temperature&beginTs=2022-01-21%2017:30:00.000&endTs=2022-01-21%2017:35:00.000


Opcua config fqD2QRq.png




Appendix

Install OPCUA Demo Server

Please follow below steps to setup OPCUA Demo Server:

1. Download Unified Automation C++ Demo Server from https://www.unified-automation.com/downloads/opc-ua-servers.html and install it to the server machine.


2. Launch UaCppServer from Windows Start Menu.

Opcua config POK0jrK.png

Uacpp-demo-server-01.png


3. Information of OPCUA Demo Server, include Username/Password, Endpoint URL and Node IDs are shown in below.


Username Password
root secret


Endpoint URL Format opc.tcp://<Mancine Name or IP>:<Port>
Endpoint URL for this Demo opc.tcp://Protocol-Converter-GW:48010


Node Nmae Node ID
AirConditioner_1.Humidity ns=3;s=AirConditioner_1.Humidity
AirConditioner_1.Temperature ns=3;s=AirConditioner_1.Temperature
AirConditioner_2.Humidity ns=3;s=AirConditioner_2.Humidity
AirConditioner_2.Temperature ns=3;s=AirConditioner_2.Temperature