OPC通信原理在数采中的应用

OPC通信原理在数采中的应用

OPC是Object Linking and Embedding(OLE)for Process Control的缩写,它是微软公司的对象链接和嵌入技术在过程控制方面的应用。OPC以OLE/COM/DCOM技术为基础,采用客户/服务器模式,为工业自动化软件面向对象的开发提供了统一的标准,这个标准定义了应用Microsoft操作系统在基于PC的客户机之间交换自动化实时数据的方法。

在OPC数据存取规范中,一个OPC的数据存取服务器中包括几类对象(OPC Server)、组(OPC Group)和项(OPC Item)。OPC服务器对象维护有关服务器的信息并作为OPC组对象的容器,而OPC组对象维护有关其自身的信息,提供包容OPC项的机制,并管理OPC项。

OPC服务器对象主要实现IUnknown和IOPCServer接口,OPC客户通过OPC服务器的接口与OPC对象进行通信。IOPCServer接口为OPC客户提供了方便有效的OPC组的方法。OPC组提供了客户程序组织数据的手段,每个组中都可以定义一个或多个OPC项。组有两种类型:公共组(Public)和局部组(Local),公共组可以被多个客户共享,而局部组只能被一个客户使用。OPC组中有以下几个主要属性:

Name—组的名字;

Active—组的激活状态标志;

Update Rate OPC—服务器向客户程序提交数据变化的刷新率;

Percent Deadband—数据死区,即能引起数据变化的最小数据百分比。

OPC项代表了与服务器中的数据的连接,它并不是数据源,而仅仅是与数据源的连接。

每个项都与以下主要属性:

Active项的激活状态;

Value项的数据,类型为VARIANT;

Quality项的品质,代表数值的可信度,类型为SHORT;

Time Stamp时间戳,代表数据的存取时间。

OPC规范包含了两套接口:客户化接口(Custom Interface)和自动化接口(Automation Interface)。客户化接口是一个OPC服务器所必须实现的接口,它描述了OPC组件对象的接口和其中的方法,适合C++和PASCAL语言设计,并可实现最佳运行性能的客户应用程序,客户化接口没有项的对象,它对项的操作都是通过包容此项的组对象进行的。自动化接口是可选接口,它提供的是一个自动配置和存取过程控制数据的接口,它方便了Visual Basic、Excel及其它可以使用OLE自动化的服务器应用程序接口的高级商业软件使用。

服务器内安装有数据采集卡(通用多串口卡,网卡),软件安装有OPC Server完成对现场各个设备检测、监控、调节、诊断等功能。

考虑到系统对数据的实时性要求较高,在客户端安装的数据采集软件,开发工具用VC++6.0,与OPC服务器的通讯采用OPC定制接口。该软件包括两个模块:OPC数据采集和数据保存。模块之间采用Win32的多线程技术进行通讯,OPC数据采集作为工作线程在后台运行,数据保存即写系统主线程。工作线程的线程函数循环读取OPC服务器中的数据,数据的变化不断出发主线程的写库事件。此外为了保证数据的安全性,使用了信号灯同步对象,以协调两个线程对共享资源的访问。

装置的DCS系统是日本横河公司的CS3000,并有上位机软件,CS3000支持OPC通讯方式,可通过OPC方式和CS3000软件包的OPC Server进行通讯,取得实时数据。如下图,用一台工控机来采集实时数据,数采机安装两块网卡,其中一块网卡和PLC工程师站(上位机)连接,另一块通过交换机连接在厂内光纤网上。这样,数采机就同时和两个网络通讯,先通过OPC方式从上位机取得实时数据,然后把实时数据发送到实时数据库。

综上所述,目前此装置所采用的一些重要技术性指标有:

1.客户与服务器之间,采用了客户化接口和主动访问通信方式;

2.客户与服务器之间通信,也是进程间通道通信,不会占用CPU和内存过多资源;

3.客户与服务器之间数据通信,是以只读方式对服务器缓冲区数据的读取;

4.采集位号为207个;

5.刷新频率为20秒。

时间: 2024-11-06 09:38:46

OPC通信原理在数采中的应用的相关文章

React-Native系列Android——Native与Javascript通信原理(三)

前面两篇博客,详细分析了Native与Javascript通信的过程,可以满足绝大部分场景下Native和Javascript的相互调用,但是仍然有不健全的情况. 比如Javascript层要实时获取Native的一些状态,就需要Native被动地向Javascript层通信了.这个过程区别于通信第一篇中Native主动向Javascript层通信,本篇博客就来研究下这样一个被动回调的过程! 在阅读本篇博客前,希望能回顾下前两篇. React-Native系列Android--Native与Ja

数采仪在油田车辆监控方案中的应用

石油的采集点往往处于偏僻.广阔的地带,这就使得石油采集过程具有疏散.地广.环境恶劣.流动性大的特点.石油的运输.油井的清洗.工作人员的接送.油井数据采集都需要大量的车辆进行工作,而且日常工作产生的油耗,不同的司机操作也会产生巨大的差别.由于油田地域广阔,采用传统的方法很难对车辆.司机的工作情况进行实时的监测,无法实时获取相关数据,导致相关管理十分的困难. 油田车辆监控系统主要用来对油田工作车辆进行改造,使其具有远程数据传输的功能,采用数采仪对作业车辆洗井作业数据.运油车辆进行监控.汽车GPS实时

Linux学习之路-http通信原理

http通信原理 应用通讯的基本模型分析 基本通讯流程: 客户端http应用使用本机IP+随机注册生成的TCP端口,形成套接字socket,调用系统socket api 再经过网络层.数据链路层.物理层层层封装,把数据送达请求的服务器,经过层层解封,送达对应的http服务监听的套接字socket监听的相应的端口上. 期间涉及到的N种技术: (1)TCP和UDP协议 TCP特点: a.面向连接:收发数居前必须和对方建立可靠连接,一个连接必须经过3次握手 简单过程: 主机A向主机B发出连接请求数据包

第二十天 TCP 及socket通信原理、http协议及web服务、httpd核心配置详解

一.TCP及socket通信原理详解 二.http协议及web服务原理(一) 三.http协议及web服务原理(二) 四.httpd核心配置详解 1.tcp.udp是一种传输协议,实现进程地址标记,套接字是一个虚拟设备,用来表明主机上的某个进程      众所周知:0-1023:管理员才有权限使用,永久地分配给某应用使用(由IANA分配)      注册端口:1024-41951:只有一部分被注册,分配原则上非特别严格.      动态端口或私有端口:41952-65535:由内核分配临时端口,

基于web的IM软件通信原理分析

关于IM(InstantMessaging)即时通信类软件(如微信,QQ),大多数都是桌面应用程序或者native应用较为流行,而网上关于原生IM或桌面IM软件类的通信原理介绍也较多,此处不再赘述.而web端的IM应用,由于浏览器的兼容性以及其固有的“客户端请求服务器处理并响应”的通信模型,造成了要在浏览器中实现一个兼容性较好的IM应用,其通信过程必然是诸多技术的组合,本文的目的就是要详细探讨这些技术并分析其原理和过程. 1.基于web的固有通信方式 浏览器本身作为一个瘦客户端,不具备直接通过系

由于用mpu6050模块,所以要用上i2c通信原理。

i2c通信原理 i2c总线只有两根双向信号线,一根是数据线SDA,一根是时钟线SCL. 每个接到i2c总线上的器件都有唯一的地址,主机与其他器件之间的数据传送可以是由主机发送给其他器件.主机为发送器,从机为接收器.在80c51单片机系统中,通常80C51单片机为主机, 1:数据位的有效规定: 1.1:总线在进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,时钟线为低电平期间时,数据线上的高电平和低电平才能允许变化. 1.2:起始信号和终止信号都是由主机发出的,起始信号产生后,总线

深入浅出通信原理(Python代码版)

深入浅出通信原理Python代码版 深入浅出通信原理是陈爱军的心血之作,于通信人家园连载,此处仅作python代码笔记训练所用 陈老师的连载从多项式乘法讲起,一步一步引出卷积.傅立叶级数展开.旋转向量.三维频谱.IQ调制.数字调制等一系列通信原理知识 连载1:从多项式乘法说起 \[ (x+1)(x^2+2x+5)=x^3+3x^2+7x+5 \] import sympy x = sympy.Symbol('x') sympy.expand((x+1)*(x*x+2*x+5)) 这种计算方法总结

Socket 通信原理(Android客户端和服务器以TCP&&UDP方式互通)

ZERO.前言 有关通信原理内容是在网上或百科整理得到,代码部分为本人所写,如果不当,还望指教. 一.Socket通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据.而Socket通信则是在双方建立起连接后就可以直接进行数据的传输,在连接时可实现信息的主动推送,而不需要每次由客户端想服务器发送请求. 那么,什么是s

Spark Shuffle 堆外内存溢出问题与解决(Shuffle通信原理)

Spark Shuffle 堆外内存溢出问题与解决(Shuffle通信原理) 问题描述 Spark-1.6.0已经在一月份release,为了验证一下它的性能,我使用了一些大的SQL验证其性能,其中部分SQL出现了Shuffle失败问题,详细的堆栈信息如下所示: 16/02/17 15:36:36 WARN server.TransportChannelHandler: Exception in connection from /10.196.134.220:7337 java.lang.Out