|
发表于 2008-7-31 08:46:44
|
显示全部楼层
我先解释一下什么是OPC# ^" w0 f% g1 x; r$ O
1、在控制领域中,系统往往由分散的各子系统构成;并且各子系统往往采用不同厂家的设备和方案。用户需要,将这些子系统集成,并架构统一的实时监控系统。 & _( l4 ^$ F: l2 _! r, E# F
2、这样的实时监控系统需要解决分散子系统间的数据共享,各子系统需要统一协调相应控制指令。
4 }; f. x% G0 c2 h, }3、再考虑到实时监控系统往往需要升级和调整。 * c) S, [7 N. F8 c8 J8 L$ |7 W
4、就需要各子系统具备统一的开放接口。 5 E9 s$ e0 O6 I- ?. r2 q+ m! R
5、OPC(OLE for Process Control) 规范正是这一思维的产物。
# J. @6 v" |; P6 r3 [7 m6、OPC 基于Microsoft公司的 Distributed interNet Application (DNA) 构架和 Component Object Model (COM) 技术的,根据易于扩展性而设计的。OPC规范定义了一个工业标准接口。
/ F; o8 F& j5 I0 i/ z. J6 E7、OPC是以OLE/COM机制作为应用程序的通讯标准。OLE/COM是一种客户/服务器模式,具有语言无关性、代码重用性、易于集成性等优点。OPC规范了接口函数,不管现场设备以何种形式存在,客户都以统一的方式去访问,从而保证软件对客户的透明性,使得用户完全从低层的开发中脱离出来。
/ }/ n- P+ e5 Z5 W( q8、OPC定义了一个开放的接口,在这个接口上,基于PC的软件组件能交换数据。它是基于Windows的OLE——对象链接和嵌入、COM——部件对象模型(Component Object Model)和DCOM——分布式COM(Distributed COM)技术。因而,OPC为自动化层的典型现场设备连接工业应用程序和办公室程序提供了一个理想的方法。
9 r% s9 {1 [3 Y: `) A" V- L/ `1 {' t' y6 B0 C! Y
OPC应用领域
) E) `7 b3 S; u/ b1、工控解决方案用户
: g7 e6 O7 P- y; h" i2 b2、楼控解决方案用户
8 r L* d- n4 U8 t3、工控解决方案厂商
' M4 B6 E8 Y0 e: \( y4、楼控解决方案厂商 ; }% {' I; H0 h2 H
5、工控解决方案集成商
1 `* D P6 } n+ e& b6、楼控解决方案集成商 : o J: p+ Q2 B* [. a7 Y5 ^8 f
7、 All Automation Fields % G" F7 W+ P1 \0 t1 K
: S/ ~8 \6 g$ U; G6 l X' j7 e0 jOPC是为了连接数据源(OPC服务器)和数据的使用者(OPC应用程序)之间的软件接口标准。数据源可以是PLC,DCS,条形码读取器等控制设备。随控制系统构成的不同,作为数据源的OPC服务器即可以是和OPC应用程序在同一台计算机上运行的本地OPC服务器,也可以是在另外的计算机上运行的远程OPC服务器。
, v+ R4 |2 K: k
+ Q% e K! `& B N5 QOPC接口既可以适用于通过网络把最下层的控制设备的原始数据提供给作为数据的使用者(OPC应用程序)的HMI(硬件监督接口)/SCADA(监督控制与数据采集),批处理等自动化程序,以至更上层的历史数据库等应用程序,也可以适用于应用程序和物理设备的直接连接。所以OPC接口是适用于很多系统的具有高厚度柔软性的接口标准。: o: C2 d' P2 z/ Q! W
OPC解决了什么?
; s2 D" k& d+ u g8 `OPC诞生以前,硬件的驱动器和与其连接的应用程序之间的接口并没有统一的标准。例如,在FA(FactoryAutomation)——工厂自动化领域,连接PLC(Programmable Logic Controller)等控制设备和SCADA/HMI软件,需要不同的FA网络系统构成。根据某调查结果,在控制系统软件开发的所需费用中,各种各样机器的应用程序设计占费用的7成,而开发机器设备间的连接接口则占了3成。此外,在PA(Process Automation)——过程自动化领域,当希望把分布式控制系统(DCS——Distributed Control System)中所有的过程数据传送到生产管理系统时,必须按照各个供应厂商的各个机种开发特定的接口,例如,利用C语言DLL(动态链路数据库)连接的DDE(动态数据交换)服务器或者利用FTP(文件传送协定)的文本等设计应用程序。如由4种控制设备和与其连接的监视、趋势图以及表报3种应用程序所构成的系统时,必须花费大量时间去开发分别对应设备A,B,C,D的监视,趋势图以及表报应用程序的接口软件共计要用12种驱动器。同时由于系统中共存各种各样的驱动器,也使维护运转环境的稳定性和信赖性更加困难。
: P- {5 E$ W% H3 M, q; X0 _+ M" k. z
而OPC是为了不同供应厂商的设备和应用程序之间的软件接口标准化,使其间的数据交换更加简单化的目的而提出的。作为结果,从而可以向用户提供不依靠于特定开发语言和开发环境的可以自由组合使用的过程控制软件组件产品。0 q! ~3 B( x3 x% P
9 i/ I f. q" B! h. e利用OPC的系统,是由按照应用程序(客户程序)的要求提供数据采集服务的OPC服务器,使用OPC服务器所必需的OPC接口,以及接受服务的OPC应用程序所构成。OPC服务器是按照各个供应厂商的硬件所开发的,使之可以吸收各个供应厂商硬件和系统的差异,从而实现不依存于硬件的系统构成。同时利用一种叫做Variant的数据类型,可以不依存于硬件中固有数据类型,按照应用程序的要求提供数据格式。* E$ {' y0 D2 F
: _+ Y$ j$ d# `0 d% h7 A, j5 @/ e
利用OPC使接口标准化可以构成如图5所示的系统。从图5可此看出,用户可以不依存于设备A,B,C,D的内部结构及它的供应厂商,来选用监视,趋势图以及表报应用程序。
$ ~5 k& e3 S# g- o, E为什么开发自主OPC Server和OPC Gateway?
; I( j7 _* J) o* o8 c$ `4 l1、国外原厂商的高价格" o; M" I; q" Y+ A/ Q" ~: N
2、国外原厂商面对项目的不灵活性
' G% O, q- a8 T+ i3、国内项目中子系统的多样性难以提供DRIVER; _* l2 B& I* M7 n1 g
4、自主OPC服务器追求的是稳定、实时、迅速。
6 j" ^; [3 n3 ]0 d; g0 i5、众多子系统的不规范性
# T/ S/ M4 {* o" H0 a8 g6 N) ]6、总包项目在投标前后可能出现的不一致性
1 J" h" ]; i* J e; S4 }, b* z2 ^7、价格昂贵的原厂平台服务器软件; t& A7 ~, g0 D( r1 e
8、总包商集成是否投入大量的人力开发0 U7 C0 H. B- Z" f1 ?- ^
9、平台和子系统的兼容性
; K$ ?* M; N% U8 E! o5 V$ e10、建立了OPC平台和子系统的互通 $ }& S0 t" c# |4 N( k$ _ r
11、解决厂商和集成商在项目集成的烦恼
4 N$ y& }/ \/ R7 b/ U) {12、解决厂商和集成商分散资源进行二次开发
$ x- m1 k2 b9 H+ `& }13、解决项目中子系统厂商的困扰
8 _, @5 \( l% k14、为上下位的数据通讯提供透明的通道 |
|