How to use OPC UA publisher#
Follow this procedure to test the DL Streamer Pipeline Server OPC UA publishing using the docker or helm.
Configure and start the OPC UA Server If you already have a functioning OPC UA server, you can skip this step. Otherwise, this section provides instructions for using the OPC UA server provided by Unified Automation.
Download and Install the OPC UA Server Download the OPC UA C++ Demo Server (Windows) and install it on your Windows machine. Please note that this server is available only for Windows.
Starting the OPC UA Server
Open the Start menu on your Windows machine and search for UaCPPServer.
Launch the application to start the server.
Update the following variables related to the OPC UA server in
.env
for docker orhelm/values.yml
for helm.OPCUA_SERVER_IP= # <IP-Adress of the OPCUA server> OPCUA_SERVER_PORT= # example: 48010 OPCUA_SERVER_USERNAME= # example: root OPCUA_SERVER_PASSWORD= # example: secret
Update the OPC UA
variable
to appropriate value for the pipelinepallet_defect_detection_opcua
inconfigs/config.json
for docker orhelm/config.json
for helm."opcua_publisher": { "publish_frame" : true, "variable" : "ns=3;s=Demo.Static.Scalar.String" },
Bring up the containers for docker or deploy helm chart.
Start the pipeline with the following cURL command. Ensure to give the correct path to the model as seen below. This example starts an AI pipeline.
Note: Update the port to
30107
for helm or8080
if you are using docker environmentcurl http://<HOST_IP>:<port>/pipelines/user_defined_pipelines/pallet_defect_detection_opcua -X POST -H 'Content-Type: application/json' -d '{ "source": { "uri": "file:///home/pipeline-server/resources/videos/warehouse.avi", "type": "uri" }, "destination": { "frame": { "type": "webrtc", "peer-id": "pddopcua", "overlay": false } }, "parameters": { "detection-properties": { "model": "/home/pipeline-server/resources/models/geti/pallet_defect_detection/deployment/Detection/model/model.xml", "device": "CPU" } } }'
Run the following sample OPC UA subscriber on the different machine by updating the
<IP-Address of OPCUA Server>
to read the meta-data written to server variable from DL Streamer Pipeline Server.import asyncio from asyncua import Client, Node class SubscriptionHandler: def datachange_notification(self, node: Node, val, data): print(val) async def main(): client = Client(url="opc.tcp://<IP-Address of OPCUA Server>:48010") client.set_user("root") client.set_password("secret") async with client: handler = SubscriptionHandler() subscription = await client.create_subscription(50, handler) myvarnode = client.get_node("ns=3;s=Demo.Static.Scalar.String") await subscription.subscribe_data_change(myvarnode) await asyncio.sleep(100) await subscription.delete() await asyncio.sleep(1) if __name__ == "__main__": asyncio.run(main())