前面章节我们采用OPC作为设备到上位的信息交互的协议,本章我们介绍跨平台的OPC UA。OPC作为早期的工业通信规范,是基于COM/DCOM的技术实现的,用于设备和软件之间交换数据,最初,OPC标准仅限于Windows操作系统。OPC是OLE for Process Control的缩写(中文意思:用于过程控制的OLE)。

OPC规范包括了3大部分:

  1. OPC DA:OPC实时数据访问规范,定义了包括数据值,更新时间与数据品质信息的相关标准。前面实战2我们使用openOPC获取的tag位号值就属于OPC DA,通过OPC DA读取底层设备的状态、工业参数等位号的实时数据。
  2. OPC HDA:OPC历史数据访问规范,定义了查询、分析历史数据和含有时标的数据的方法。
  3. OPC AE:OPC报警事件访问规范,定义了报警与时间类型的消息类信息,以及状态变化管理等相关标准。

由于基于COM/DCOM的技术有着不能跨平台的根本缺点,随着技术的发展,OPC基金会在2008年发布了新的规范:OPC UA (OPC Unified Architecture)OPC 统一框架。

1. OPC UA是什么

  2008年发布的OPC统一架构(UA)将各个OPC Classic规范的所有功能集成到一个可扩展的框架中,独立于平台并且面向服务。OPC UA规范不再是基于COM/DCOM技术,因此OPC UA不仅能在Windows平台上实现,更可以在Linux,以及其它的嵌入式平台中实现。

这种多层方法实现了最初设计UA规范时的目标:

  1. 功能对等性:所有COM OPC Classic规范都映射到UA
  2. 平台独立性:从嵌入式微控制器到基于云的基础设施
  3. 安全性:信息加密、身份验证和审核
  4. 可扩展性:添加新功能而不影响现有应用程序的能力
  5. 综合信息建模:用于定义复杂信息

2. OPC UA相对于传统OPC的变化

功能对等性

OPC UA不仅支持传统OPC的所有功能,更支持更多新的功能:

  1. 发现:在本地PC和/或网络上查找可用的OPC服务器
  2. 地址空间:所有数据都是分层表示的(例如文件和文件夹),允许OPC客户端发现、利用简单和复杂的数据结构
  3. 按需:基于访问权限读取和写入数据/信息
  4. 订阅:监视数据/信息,并且当值变化超出客户端的设定时报告异常
  5. 事件:基于客户端的设定通知重要信息
  6. 方法:客户端可以基于在服务器上定义的方法来执行程序等
  7. OPC UA产品和OPC Classic产品之间的集成可以通过COM/Proxy Wrappers轻松实现。

平台独立性

  鉴于市场上有各种各样的硬件平台和操作系统,平台独立性就显得至关重要。OPC UA包含但不限于以下平台及系统:

  硬件平台:传统PC硬件、云服务器、PLC、微控制器(ARM等)

  操作系统:Microsoft Windows、Apple OSX、Android或任何Linux发行版本等

  OPC UA为企业之间的互操作性提供必要的M2M、M2E及两者之间的基础架构。

安全性

  最大的变化是OPC UA可以通过任何单一端口(经管理员开放后)进行通信,这使得OPC通信不再会由于防火墙受到大量的限制,实现Internet 通讯。

综合信息建模

  OPC UA信息建模框架将数据转换为信息。通过完全面向对象的功能,即使是最复杂的多级结构也可以建模和扩展。数据类型和结构在配置文件中定义。 例如,现有的OPC Classic规范被建模为UA配置文件,也可以由其他组织扩展:

  更详细的内容请参阅OPC基金会官网:http://opcfoundation.cn/

3. 安装python-opcua组件

  pip安装:pip install opcua

  组件按照完毕后,我们可以在python环境执行uadiscover命令查看效果:

  由于运行电脑上没有运行的opcua服务端,命令没有发现任何opcua服务。下面通过运行opcua上最新的服务端代码再来看看效果。

  1. 在C:\Python\Python36-32\Scripts\下创建examples目录;
  2. Copy opcua源码下的server-minimal.py到C:\Python\Python36-32\Scripts\examples;
  3. 在C:\Python\Python36-32目录下运行命令,如下图:
  4. python C:\Python\Python36-32\Scripts\examples\server-minimal.py

  重新运行uadiscover命令,结果如下:

  现在连接到 OPCUA Sever 的模拟器提供的 OPC UA 服务了。

4. 创建一个4C9反应罐的OPCUA Server模拟器

4.1. 在Solution上添加一个Python Application Project  Tank4C9Svr

  打开Tank4C9Svr.py文件,修改Example里的server-minimal.py文件里代码,模拟4C9反应罐如下:

  1. import sys
  2. sys.path.insert(0, "..")
  3. import time
  4. import random
  5.  
  6. from opcua import ua, Server
  7.  
  8. if __name__ == "__main__":
  9.  
  10. # setup our server
  11. server = Server()
  12. server.set_endpoint("opc.tcp://0.0.0.0:4840/freeopcua/server/")
  13.  
  14. # setup our own namespace, not really necessary but should as spec
  15. uri = "http://examples.freeopcua.github.io"
  16. idx = server.register_namespace(uri)
  17.  
  18. # get Objects node, this is where we should put our nodes
  19. objects = server.get_objects_node()
  20.  
  21. # populating our address space
  22. myobj = objects.add_object(idx, "Tank4C9")
  23. status = myobj.add_variable(idx, "Status", 0)
  24. overheadFlow = myobj.add_variable(idx, "OverheadFlow", 0)
  25. buttomsFlow = myobj.add_variable(idx, "ButtomsFlow", 0)
  26. power = myobj.add_variable(idx, "Power", 0)
  27.  
  28. #myVar.set_writable() # Set MyVariable to be writable by clients
  29.  
  30. # starting!
  31. server.start()
  32.  
  33. try:
  34. count = 0
  35. while True:
  36. time.sleep(5)
  37. count = count + 1
  38. print(count%4)
  39. if count%4>0:
  40. status.set_value(1)
  41. else:
  42. status.set_value(0)
  43.  
  44. a= random.randint(100,500)
  45. print("OverheadFlow:"+str(a))
  46. overheadFlow.set_value(a)
  47. buttomsFlow.set_value(random.randint(50,500))
  48. power.set_value(random.randint(1000,5000))
  49. finally:
  50. #close connection, remove subcsriptions, etc
  51. server.stop()

  我们把Tank4C9Svr设置成solution默认启动项目后,F5调试运行Tank4C9Svr,如下图:

5. opcua-client浏览4C9 opcua服务器

  安装:pip install opcua-client

  cmd窗口C:\Python\Python36-32\Scripts目录下执行opcua-client.exe命令,如下图:

  地址栏输入 opc.tcp://localhost:4840 点击连接按钮,就能看见我们构建的Tank4C9设备和对于的tag变量了,如下图:

  我们可以在变量上右键来订阅数据变化的读取最新的数据值。

6. 小结

  本小节主要介绍了OPC DA到OPC UA之间的关系,更多详细的信息参考OPC基金会官网。首先,我们使用 python-opcua 组件模拟构建一个Tank4C9的反应罐OPC UA服务器,然后,演示OPC UA的Objects是如何构建的。最后,展示opcua-client连接这个OPCUA服务器并订阅数据变化是如何的显示效果。下一节我们将用演示监控如何迁移到OPC UA数据通信协议。

python工业互联网监控项目实战4—python opcua的更多相关文章

  1. python工业互联网监控项目实战5—Collector到opcua服务

    本小节演示项目是如何从连接器到获取Tank4C9服务上的设备对象的值,并通过Connector服务的url返回给UI端请求的.另外,实际项目中考虑websocket中间可能因为网络通信等原因出现中断情 ...

  2. python工业互联网监控项目实战2—OPC

    OPC(OLE for Process Control)定义:指为了给工业控制系统应用程序之间的通信建立一个接口标准,在工业控制设备与控制软件之间建立统一的数据存取规范.它给工业控制领域提供了一种标准 ...

  3. Python工业互联网监控项目实战3—websocket to UI

    本小节继续演示如何在Django项目中采用早期websocket技术原型来实现把OPC服务端数据实时推送到UI端,让监控页面在另一种技术方式下,实时显示现场设备的工艺数据变化情况.本例我们仍然采用比较 ...

  4. Python爬虫开发与项目实战

    Python爬虫开发与项目实战(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1MFexF6S4No_FtC5U2GCKqQ 提取码:gtz1 复制这段内容后打开百度 ...

  5. H2O中的随机森林算法介绍及其项目实战(python实现)

    H2O中的随机森林算法介绍及其项目实战(python实现) 包的引入:from h2o.estimators.random_forest import H2ORandomForestEstimator ...

  6. Python爬虫开发与项目实战pdf电子书|网盘链接带提取码直接提取|

    Python爬虫开发与项目实战从基本的爬虫原理开始讲解,通过介绍Pthyon编程语言与HTML基础知识引领读者入门,之后根据当前风起云涌的云计算.大数据热潮,重点讲述了云计算的相关内容及其在爬虫中的应 ...

  7. python工业互联网应用实战2—从需求开始

    前言:随着国家工业2025战略的推进,工业互联网发展将会提速,将迎来一个新的发展时期,越来越多的企业开始逐步的把产线自动化,去年年底投产的小米亦庄的智能工厂就是一个热议的新闻.小米/华为智能工厂只能说 ...

  8. python工业互联网应用实战3—模型层构建

    本章开始我们正式进入到实战项目开发过程,如何从需求分析获得的实体数据转到模型设计中来,变成Django项目中得模型层.当然,第一步还是在VS2019 IDE环境重创建一个工程项目,本文我们把工程名称命 ...

  9. Python不能用于大型项目?关于Python的10大误解

     语言多元化是PayPal编程文化中一个重要的组成部分.在C++和Java长期流行的同时,更多的团队选择了Jva和Scala.同时,Braintree的收购也引入了一个久经世故的Ruby社区.Pyt ...

随机推荐

  1. Fedora20在神州战神K650D1安装过程,使用netinstall和Dvd.iso镜像安装。

    最近新买一笔记本,神州战神K650D-i5 D1.仍旧安装双系统,WIndows7+Fedora20.磁盘分区是这样的: 第一主分区 /boot ext4 20G 第二主分区 / ext4 70G 第 ...

  2. 维护你的请求队列,处理token异常

    前言 网络请求是开发中最基础也是最核心的需求,封装一个稳定且可用性高的请求也显得尤为重要.通常封装的内容除了入参之外,更多的是请求中的异常处理.本文分享下我在处理 token 异常方面的做法,通过维护 ...

  3. 浅谈C#中Tuple和Func的使用

    为什么将Tuple和Func混合起来谈呢? 首先,介绍一下:Tuple叫做元组,是.Net Framwork4.0引入的数据类型,用来返回多个数值.在C# 4.0之前我们函数有多个返回值,通常是使用r ...

  4. 深入理解Java AIO(三)—— Linux中的AIO实现

    我们调用的Java AIO底层也是要调用OS的AIO实现,而OS主要也就Windows和Linux这两大类,当然还有Solaris和mac这些小众的. 在 Windows 操作系统中,提供了一个叫做 ...

  5. docker下centos7编译安装ffmpeg

    1.安装基础命令 docker下精简版centos没有make等命令,先安装: yum -y install gcc automake autoconf libtool make yum instal ...

  6. CentOS-7.6 下搭建 NIS 服务器

    ##服务端配置: ####Server: 192.168.0.178(CentOS 7.6) # systemctl stop firewalld # systemctl disable firewa ...

  7. SSM项目依赖,spring5.1.9

    SSM项目依赖,spring5.1.9 简单的SSM项目,未加AOP等等操作 Spring三包bean core content Mybatis 五个mybatis mybatis-spring jd ...

  8. Docker常用yml

    GitLib version: '3.1' services: web: image: 'twang2218/gitlab-ce-zh:11.0.5' restart: always hostname ...

  9. PTA数据结构与算法题目集(中文) 7-11

    PTA数据结构与算法题目集(中文)  7-11 7-11 关键活动 (30 分)   假定一个工程项目由一组子任务构成,子任务之间有的可以并行执行,有的必须在完成了其它一些子任务后才能执行.“任务调度 ...

  10. udev规则,部署Multipath

    部署Multipath多路径环境 配置iSCSI服务 编写udev规则 配置并访问NFS共享 部署Multipath多路径环境 1 配置iSCSI服务 1.1 问题 本案例要求先搭建好一台iSCSI服 ...