【OPC UA】基于OpcUaFx的OPC客户端读写KEPServerEx6服务器节点

2024-03-20 01:59

本文主要是介绍【OPC UA】基于OpcUaFx的OPC客户端读写KEPServerEx6服务器节点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、OPC UA 与 UAFX

3738eeac3e0c7667c30364763aeef339.png

OPC UA and UAFX System Architecture

5cc8c6c2769d04553dcaec4b8472fa94.png通过OPC UA (a)和UAFX (b)实现水平和垂直通信的统一,以及迁移到一个连续的、收敛的网络(c),从现场到云端,反之亦然

    2021 年 12 月 8 日 – OPC基金会现场层通信(FLC)倡议成立三年之际,完成了OPC UA FX(现场交换)规范集的第二个候选版本(RC2),并开始了审核与发布程序。此外,由20家世界大型自动化供应商,利用各自的控制器和网络基础设施组件构成的供应商Demo也成功展示。此次Demo展示了在工厂和过程自动化中,自动化组件多样化用例的跨供应商互操作性。

第一个OPC UA FX多供应商演示

ecc3f4e18f8b9f2df2aeb96ccdbbbc68.png

第一个OPC UA FX多供应商演示的原理结构

2021年11月,第一个多供应商互操作性演示实现了,其中自动化和网络组件结合在一起,演示了通过OPC UA和OPC UA FX扩展的跨供应商数据交换。为此,来自不同供应商(包括世界上最大的自动化制造商)的17个控制器(包括PLC、运动和机器人控制器以及分布式控制系统)通过公共网络基础设施相互连接。

该基础设施由传统的以太网交换机、以太网TSN(时间敏感网络)交换机和毫米波频率范围的5G试验台组成。

演示器的所有控制器通过集成的OPC UA服务器提供当前状态和资产信息,通过中央仪表板进行查询和可视化。“所有控制器”视图显示多供应商演示中所有17个控制器的OPC UA连接状态,以及由每个UAFX控制器原型配置的基于pubsub的UAFX连接的状态信息。仪表板本身是交互式的,当单击17个控制器中的一个时,切换到“资产视图”,其中显示控制器建模和公开的UAFX资产信息。

为了演示UAFX扩展的可能性和优势,在演示机上模拟了一个模块化装瓶线,其中4个用于清洗、灌装、旋盖和贴标的机器单元组合成一条生产线。为了演示跨供应商互操作性,每个单元都配备了来自不同制造商的控制系统。

通信连接的配置和通过这些连接交换的过程数据来实现一个正常工作的生产线是通过一个UAFX连接管理器来实现的,如上所述。在演示中,使用了基于UA Expert的统一自动化(Unified Automation)的独立(外部)连接管理器和集成到西门子SIMATIC PLC中的连接管理器,每个都有自己的图形用户界面。连接管理器充当OPC UA客户端,并使用集成在UAFX控制器原型中的OPC UA服务器来配置各自控制器之间的UAFX连接。

然后通过这些UAFX连接使用OPC UA Pub/Sub交换相应的流程数据。控制器作为UAFX发布者和/或UAFX订阅者取决于他们在配置的生产线中的角色和位置。流程数据可以是实时数据,也可以是用于故障安全操作的安全数据。配置的生产线可以在仪表板中可视化和监视。

二、基于OPC UAFX的读写客户端

3cd24e8af1e8dbb7ddd34a5a80310c83.png读取节点客户端

8782a1179c7aaa8e51ce2bb74ae085df.png写入节点数据客户端

视频演示

读取节点客户端部分代码:

public void UpdateTags_M1(OpcClient client, ref string strM1Name, ref double dM1Position, ref int nM1Mode, ref bool bM1Status, ref double dM1Temp){//Motor1             string strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Name";Opc.UaFx.OpcValue opcM1Name = client.ReadNode(strTagName);strM1Name = (string)opcM1Name.Value;strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Position";Opc.UaFx.OpcValue opcM1Pos = client.ReadNode(strTagName);dM1Position = opcM1Pos.Value==null?double.NaN:(double)opcM1Pos.Value;strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Mode";Opc.UaFx.OpcValue opcM1Mode = client.ReadNode(strTagName);nM1Mode = opcM1Mode.Value==null?int.MinValue:(int)opcM1Mode.Value;strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Status";Opc.UaFx.OpcValue opcM1Stt = client.ReadNode(strTagName);bM1Status = opcM1Stt.Value==null?false:(bool)opcM1Stt.Value;strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Temperature";Opc.UaFx.OpcValue opcM1Temp = client.ReadNode(strTagName);dM1Temp = opcM1Temp.Value==null?double.NaN:(double)opcM1Temp.Value;            }

写入节点客户端部分代码:

public void WriteTags_M1(OpcClient client, ref string strM1Name, ref string strM1Position, ref string strM1Mode, ref string strM1Status, ref string strM1Temp){//Motor1string strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Name";string strName = strM1Name;client.WriteNode(strTagName, strName);strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Position";double dPos = Convert.ToDouble(strM1Position);client.WriteNode(strTagName, dPos);strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Status";bool bStt = Convert.ToBoolean(strM1Status);client.WriteNode(strTagName, bStt);strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Mode";int nMode = Convert.ToInt32(strM1Mode);client.WriteNode(strTagName, nMode);strTagName = "ns=2;s=Devices.OPCUAReadData.Motor1.Temperature";double dTemp = Convert.ToDouble(strM1Temp);client.WriteNode(strTagName, dTemp);}

参考:

https://www.opcfoundation.cn/news/opc-foundation-china-news/47

https://www.tttech-industrial.com/resource-library/blog-posts/opc-ua-fx/

https://www.process-informatik.de/ftp/pub/handbook/en_opc-ua-framework-advanced.pdf

https://iebmedia.com/technology/edge-cloud/opc-ua-fx-for-the-field-level-and-multi-vendor-demo/

The End

这篇关于【OPC UA】基于OpcUaFx的OPC客户端读写KEPServerEx6服务器节点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/827938

相关文章

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

MySQL主从复制与读写分离的用法解读

《MySQL主从复制与读写分离的用法解读》:本文主要介绍MySQL主从复制与读写分离的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、主从复制mysql主从复制原理实验案例二、读写分离实验案例安装并配置mycat 软件设置mycat读写分离验证mycat读

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

MYSQL查询结果实现发送给客户端

《MYSQL查询结果实现发送给客户端》:本文主要介绍MYSQL查询结果实现发送给客户端方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql取数据和发数据的流程(边读边发)Sending to clientSending DataLRU(Least Rec

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

ShardingSphere之读写分离方式

《ShardingSphere之读写分离方式》:本文主要介绍ShardingSphere之读写分离方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录ShardingSphere-读写分离读写分离mysql主从集群创建 user 表主节点执行见表语句项目代码读写分