【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

相关文章

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Python WSGI HTTP服务器Gunicorn使用详解

《PythonWSGIHTTP服务器Gunicorn使用详解》Gunicorn是Python的WSGI服务器,用于部署Flask/Django应用,性能高且稳定,支持多Worker类型与配置,可处... 目录一、什么是 Gunicorn?二、为什么需要Gunicorn?三、安装Gunicorn四、基本使用启

通过配置nginx访问服务器静态资源的过程

《通过配置nginx访问服务器静态资源的过程》文章介绍了图片存储路径设置、Nginx服务器配置及通过http://192.168.206.170:8007/a.png访问图片的方法,涵盖图片管理与服务... 目录1.图片存储路径2.nginx配置3.访问图片方式总结1.图片存储路径2.nginx配置

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连