OPC通讯配置详解

上传人:A**** 文档编号:153785102 上传时间:2020-12-02 格式:DOC 页数:9 大小:35.33KB
返回 下载 相关 举报
OPC通讯配置详解_第1页
第1页 / 共9页
OPC通讯配置详解_第2页
第2页 / 共9页
OPC通讯配置详解_第3页
第3页 / 共9页
OPC通讯配置详解_第4页
第4页 / 共9页
OPC通讯配置详解_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《OPC通讯配置详解》由会员分享,可在线阅读,更多相关《OPC通讯配置详解(9页珍藏版)》请在金锄头文库上搜索。

1、.OPC通讯协议解析1 通讯步骤1.1 第一问OPC Client和OPC Server之间通讯谁是主动的?答:当然是OPC Client。1.2 第二问OPC Client第一次动作做了什么?答:从大多数OPC Client行为来看,一是自动遍历本机已注册的OPC Server列表名称,二是等待用户定义预访问的OPC Server的信息。1.3 第三问OPC Client第二次动作做了什么?答:OPC Client的第一步动作会产生分支,访问本地OPC Server的这个分支就不再说了。要分析的是网络方式访问OPC Server这个分支。第二个动作是根据用户指定的IP地址或计算机名去查询远程

2、计算机上已注册的OPC Server列表名称。从这步开始就比较复杂了。1.4 第四问OPC Client是用什么协议去和远程计算机交流的?答:用的是TCP/IP这个协议。OPC Client用TCP/IP 135端口去打开远程计算机的那一扇门。简单解释下:在Windows操作系统中,135端口主要用于使用PRC协议并提供DCOM(分布式组件对象模型)服务,通过RPC可以保证在一台计算机上运行的程序可以顺利地执行远程计算机上的代码。使用DCOM可以通过网络直接进行通信,能够跨包括HTTP协议在内的多种网络传输。多年来,135端口一直被人利用。1.5 第五问OPC Client去访问远程计算机的T

3、CP135这扇门时,第一道关卡是谁?答:网络安全防火墙是第一关卡,网络安全放火墙中,如果不允许远程计算机的TCP 135端口,那么连接就被掐断了。后续的通讯就无法进行。要想能向下进行,网络安全防火墙必须允许对TCP 135这扇门的访问。这里需要在防火墙中将135端口例外操作。1.6 第六问各系统的安全策略有什么不同?答:(一)Windows 2000的安全策略:支持来访者以自己的身份进行验证,且不拒绝来宾用户从网络中访问,来宾用户默认启用。(二)Windows XP和Windows 2003的安全策略:支持来访者以自己的身份进行验证或将所有来访者都看成是来宾访问,默认将所有来访者都看成来宾访问

4、。且默认拒绝Guest用户从网络访问本机。来宾用户默认禁用。(三)Windows 7的安全策略:支持来访者以自己的身份进行验证或将所有来访者都看成是来宾访问(经典-对本地用户进行身份验证,不改变其本来身份),默认支持来访者以自己的身份进行验证。且默认拒绝Guest用户从网络访问本机(拒绝从网络访问这台计算机)。来宾用户默认禁用。(四)Windows 2008的安全策略:支持来访者以自己的身份进行验证或将所有来访者都看成是来宾访问,默认支持来访者以自己的身份进行验证。来宾用户默认禁用。配置OPC Client和OPC Server之间的网络通讯,先得看看对应的操作系统。选好安全审核机制再说。举例

5、说明:例1:OPCClient和OPCServer都在Windows2000操作系统上来举个例子:由于操行系统都是Windows2000,那么安全策略都是来访者以自己的身份进行验证(自己指OPCServer)。这里的以来访者以自己的身份进行验证是什么意思?就是指OPCClient去敲OPCServer的135这扇门时,会告知OPCClient的登录用户名是谁,我的登录密码是多少。OPCServer所在的操作系统通过来访者告知的用户名和密码去自己的用户列表中去查找是否也存在这个用户,密码是否正确。如果用户名和密码正确,则进入下一步工作。例2:OPCClient和OPCServer都在Window

6、sXP操作系统上来举个例子:由于操行系统都是WindowsXP,那么默认的安全策略都是将所有来访者都看成是来宾访问。(对本地用户进行身份验证,其身份为来宾。)且默认拒绝Guest用户从网络访问本机。这里的将所有来访者都看成是来宾访问是什么意思?就是指OPCClient去敲OPCServer的135这扇门时,会告知,我的登录用户名是谁,我的登录密码是多少。OPCServer所在的操作系统却不管你是谁,所有来访者一视同仁,都是来宾,而且按照规定,来宾都拒绝掉。这下可好,后面二者之间的通讯也不用继续了。上面的(一)这种情况工作还能继续往下做,(二)这种情况就完全不行了,啥都不管了。因此(二)这种情况

7、是需要修改安全策略的,一种是将安全策略修改为来访者以自己的身份进行验证;另外一种是将“拒绝从网络中访问此计算机”规则中的来宾用户给去掉,从用户管理中将来宾用户启用,且密码为空。(仅来宾-对本地用户进行身份验证,其身份为来宾)1.7 第七问网络防火墙允许进入,操作系统的安全审核也通过了,终于可以访问OPC Server了吧?答:还得问一问DCOM的安全配置同不同意。运行“组件服务”检查一下。DCOM的“访问权限”默认只有Sell和System,需要添加指定用户或者允许所有人,需要注意的是,“本地访问”与“远程访问”都需要选择“允许”。DCOM的“启动和激活权限”默认只有“Administrato

8、r”和“System”,需要添加指定用户或者允许所有人,需要注意的是,“本地访问”与“远程访问”,“本地激活”和“远程激活”都需要选择“允许”。 1.8 总结1.8.1 小结1经过上面的一些处理过程,我们在这里可以总结一下都做了些什么?(一)配置防火墙,允许访问OPCServer所在计算机的TCP135端口。(二)配置操作系统的安全策略,使得可以接受远程计算机的rpc请求,可配置为按照来访者身份验证模式或来宾模式。(直接选择以本地身份验证)(三)配置操作系统的用户管理。来访者身份验证模式需在OPCServer所在计算机中添加来访者的用户名和密码;来宾模式需要启用Guest用户。(四)配置计算机

9、全局的DCOM安全配置,使之允许远程访问,已经远程启动和激活。以上4步基本已将OPCServer这端的访问权限配置得差不多。但在实际操作过程中,还需要检查如下一些内容:(一)OPC库文件是否安装注册?OPC库文件没有正确的安装注册,OPCServer是无法工作的。而现在的不少OPCServer安装时并不会自动安装OPC库文件。(二)OPC server是否注册?OPCServer未注册,是无法访问的,OPCServer必须正确注册。而现在的不少OPCServer安装后也不会自动注册,需要手动在程序界面上提供的功能按钮进行注册。(三)OPC server的主程序是否存在?有的时候OPCServe

10、r注册了,但主程序可能被误删除或改名了,这个操作系统可不会告诉你。只能自己检查一下或重新注册一遍。(四)OPC Server的主程序与其他程序是否有依赖关系?因为OPCServer只是软件对外提供数据的一种标准接口,它本身也是通过从其他的软件获取数据,常见的如组态软件,实时数据库等,而现在的一些OPCServer启动时会检查依赖的程序是否启动,如未启动,要么退出,要么啥都提供不了,也不会告诉OPCClient出了啥问题。(五)OPCServer在DCOM环境中自己的配置信息,OPCServer在DCOM的环境中的配置信息如下图。如OPCServer是NT服务方式启动,那么“标识”这一栏就为系统

11、帐户,不推荐使用“下列用户”。如OPCServer是COM方式注册,那么“标识”这一栏默认为“交互式用户”或“启动用户”(各家OPCServer注册时处理方法不太一样),最好都使用。“交互式用户”,不推荐使用“启动用户”和“下列用户”。具体原因后期再说。(OPC Server是NT服务方式启动,标识这栏为“系统账户(仅用于服务)”)(OPC Server是COM方式注册,标识这栏为“交互式用户”)1.8.2 小结2到了这一步,可能绝大部分人都会觉得这完成没有问题了。OPCServer都连接上了,增加个OPC组还不是轻而易举的事情吗?而实际上,OPC的组是一个大有深意的设计。OPC的组是用来给O

12、PCClient灵活定义数据采集方式的一个方法,如希望对OPCServer中测点,一些测点的采样频率是1秒,一些测点的采样频率是5秒,一些测点数据变化即采集,一些测点数据变化超过量程多少才采集等等。而且还定义了数据采集的两种模式,SynchronousI/O(同步)和AsynchronousI/O(异步)。对同步和异步进行一个简单的说明:同步模式:OPCClient向OPCServer要5000个测点的数据,必须等到OPCServer将5000个测点的数据都返回后才做后面的事情。异步模式:OPCClient向OPCServer要5000个测点的数据,OPCClient告诉OPCServer:“

13、我为你留了一个通道,我要的这5000个点,只要任何点有变化,你就立马按照预定的周期告诉我”,于是OPCServer就按照预定的周期将数据发生变化的测点通过OPCClient预留的通道告知OPCClient。异步模式中,就会发生OPCServer反向连接OPCClient的情况,那么就会再次发生前面9个问题的所有事情。这也是很多时候OPCServer配置完成了,但OPC的通讯还是不正常的缘故。因为现在的绝大多数OPCClient默认都是采用异步方式与OPCServer进行通讯,这就要求OPCClient所在计算机的网络防火墙、操作系统的安全策略,DCOM的全局安全配置也需要配置正确。某OPCCl

14、ient客户端添加OPC组时的属性配置。此处给各位留下一个问题:既然异步方式增加了对OPCClient端的配置要求,那为何大家默认不使用同步模式呢?1.8.3 小结3到了这一步,还问这样的问题,估计有人会很愤怒了,“这种弱爆了的问题还要问吗?”,其实不然,在很多实际的案例中,就遇到了OPC的通讯配置问题解决了。但却看不到测点,一般会有如下几种原因:(一)OPCServer真的没有测点。(二)仔细阅读第10问中的检测要点的第4条。OPCServer中的测点来自于组态软件或实时数据库,当组态软件和实时数据库未启动或OPCServer启动在组态软件和实时数据库之前时,OPCServer中很可能就没有

15、测点。如何解决?重启一下就好了嘛。2 OPC Client/OPC Server2.1 问题现象目前市场上的OPC Client与OPC Server软件在Windows上的运行方式有Windows桌面程序和Windows NT服务。本来也没啥。但由于OPC Client 是一个厂家的软件,而OPC Server是另一家的软件,正因为软件的多样性,也就导致了如下一些现像:1:OPC Client 连接目标OPC Server,发现无法连接,但在OPC Serve计算机上明明看见OPC Serve进程已经启动。2:OPC Client连接目标OPC Server,能连接,也能看见测试点,但无法获取到数据。经过多次现场的积累后,发现此类问题多出现在OPC Client和OPC Server软件在Windows上运行方式不同导致的。也就是说,OPC Client和OPC Server软件的运行方式不一样。譬如:OPC Client是Windows桌面程序方式,OPC Server是Windows NT服务时,发现上面的现象基本不出现。这是为什么呢?2.2 问题解决原因如下:OPC Client和OPC Serv

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号