要做的第一件事就是要记下与您的环境和应用程序本身,如相关的信息:
有关在服务器计算机:
在服务器计算机是服务器应用程序即将运行的计算机。收集以下数据:
操作系统和安装的服务包。
是否有人登录到计算机?
如果登录是有人他们的权限是什么?他们是否在管理员组的一部分吗?是否他们作为登录域用户吗?
有关客户端计算机中:
客户端计算机是在客户端应用程序即将运行的计算机。收集以下数据:
操作系统和安装的服务包。
谁登录到这台计算机?是否它们作为域用户或身份登录本地用户吗?如果作为域用户登录他们在服务器计算机上的权限是什么?他们是否在服务器计算机上管理员组的一部分吗?
有关服务器应用程序:
使用的语言、 版本,和服务包的开发服务器?
不会它回调到客户端吗?
它不会引发事件吗?如果是这样,DCOM 安全设置在客户端计算机上为访问权限授予 所有人 帐户吗?
它有一个用户界面?
它被标记为 无人参与执行 吗?
它设置安全参数的函数,如 CoInitializeSecurity 或 CoSetProxyBlanket 调用通过以编程方式吗?
有关客户端应用程序:
使用的语言、 版本,和服务包已开发的应用程序?
它设置安全参数的函数,如 CoInitializeSecurity 或 CoSetProxyBlanket 调用通过以编程方式吗?
有关网络:
是否在客户端和服务器计算机上同一局域网 (LAN)?
是否在客户端和服务器计算机连接了 Internet 防火墙和它们之间的代理服务器没有通过?
是否在客户端和服务器计算机连接通过互联网使用防火墙和它们之间的代理服务器吗?
基本故障诊断步骤
检查所有 Dcomcnfg 中的设置合适,基于您在前面收集的数据。
268550如何为 Visual Basic DCOM 客户端/服务器应用程序使用 Dcomcnfg
如果您使用 Microsoft Windows 95 客户端或服务器计算机上,请确保您具有在其上安装 DCOM95。您可以从下面的 Microsoft 网站下载 DCOM95:
http://www.microsoft.com/com/dcom/dcom95/download.asp
如果您在服务器计算机上使用 Windows 95、 Microsoft Windows 98、 Windows Millennium 版 (Me),您将需要对您尝试使用客户端之前运行该服务器组件。作为一种检查验证服务器正在运行并且它正在等待客户端连接。
165101如何使用 Windows 95、 Windows 98 或 Windows Me 为 DCOM 服务器
如果客户端和服务器计算机通过防火墙和它们之间的代理服务器与 Internet 连接,DCOM 无法正常工作,如果没有任何类型的地址转换 (NAT) 在它们之间。如果没有地址转换您需要配置这些代理和防火墙以启用 DCOM 通信。您可以找到几个与 Microsoft 开发人员网络 (MSDN) 或在下面的 Microsoft 网站此主题有关的白皮书:
http://www.microsoft.com/technet/prodtechnol/windows2000serv/reskit/cnet/cnad_arc_wbak.mspx?mfr=true
此主题不介绍本文中的内容。
其它故障诊断
如果设置为根据您的环境和应用程序功能的权限设置的 Dcomcnfg 后仍有问题,下面是几个步骤,您可能需要解决您的问题:
使用任务管理器来验证服务器未运行时使用 Dcomcnfg 设置中进行更改。因此如果服务器正在运行时更改设置,新设置仅生效的下次启动时服务器启动时,所有设置都分配给进程。
验证的服务器和客户端上正确运行在同一台计算机。您应始终测试您的客户端和服务器运行的正确本地 ; 也就是在同一计算机上远程运行之前。
检查是否都面临的问题实际上是通常与代码本身,一个 DCOM 问题,或如果它是特定于您的应用程序的编码问题。通过使用只是一种或两个非常简单的方法创建一个非常简单的客户端/服务器应用程序来执行此操作。按照正常的过程的打包和安装。如果您的服务器引发的事件,然后在小示例也应引发事件。 有关更多的信息请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
266717如何使用 Visual Basic 创建 DCOM 客户端/服务器应用程序
267836如何使用 Visual Basic 事件与创建 DCOM 客户端/服务器
理想情况下,您应使用上述文章原则是,因为它们带您逐步通过从头最终打包和部署。在您使用的为您的应用程序和查看这是否正常工作,请使用相同的设置。如果您的问题与 DCOM 相关,您面临着同样的问题对小示例应用程序中一样。直到您找到问题的保留故障排除较小的示例问题。 如果小应用程序工作正常但您自己的应用程序不能使用相同的设置,则您可以将面临两个问题:
您的代码中的某些内容就创建问题。例如对于如果在您的代码和您的服务器的身份访问的数据库不具有执行此操作的权限。如果您试图访问的文件或其他对象进行实例化同样的问题,就会发生这种情况。
您的代码很好,但在该注册表如到您的服务器的多个条目中有一些问题。 有关更多的信息请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
180525PRB: Dcomcnfg 报告 DCOM 服务器的多个副本
客户端计算机指向错误的服务器计算机。请检查该位置中选项卡 Dcomcnfg 在客户端计算机上。有关更多的信息请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
268550如何为 Visual Basic DCOM 客户端/服务器应用程序使用 Dcomcnfg
请验证您具有打包并安装客户端和服务器正确。正确地创建分发程序包是成功的安装基础。有关如何创建 DCOM 客户端/服务器应用程序使用 Visual Basic 分步示例的其他信息,请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
266717如何使用 Visual Basic 创建 DCOM 客户端/服务器应用程序
267836如何使用 Visual Basic 事件与创建 DCOM 客户端/服务器
验证您的网络正常工作,由客户端从服务器计算机和服务器从客户端计算机执行 ping 操作。在服务器上打开一个命令提示符窗口,然后执行下面的命令前面 ClientcomputerName 应在客户端计算机的名称:
Ping ClientcomputerName
如果一切工作正常,您应该看到三个或四个答复,在每个时间。如果您看到超时或其他错误,您的网络设置过程中遇到问题,您需要在继续之前,请修复这些。重复使用服务器的计算机名称在客户端计算机上相同的步骤。
在客户端计算机上的 Dcomcnfg,更改通过该服务器的名称替换为服务器的 IP 地址的服务器的位置。如果它工作正常使用的 IP 地址而不是与服务器的计算机名称,然后多个可能必须与您的网络设置的问题。
请尝试重新启动服务器和客户端。有时某些设置缓存在内存和 $ 重新启动后在 Dcomcnfg 中进行更改后,问题解决了。
在 Windows 95 或 Windows 98,使用 $ TCP/IP 协议。若要执行此操作删除 Dcomcnfg 中的默认协议列表中的所有其他协议。
通常,如果 DCOM 问题您得到错误当您试图通过调用 CreateObject 函数或设置对象变量,用 New 关键字实例化远程对象。能够区分如果您收到一条错误消息,由于在创建该对象本身,或者是由于在对象的初始化事件在做什么重要的。如果您试图实例化的对象的初始化事件没有任何的代码,那么毫无疑问您收到该错误与对象的实例化相关。 如果您然而,在初始化事件中的连接到数据库或其他的对象进行实例化的代码应包括内部 Initialize 事件捕获错误,并引发自定义用户错误。如果您不补漏白您内部 Initialize 事件的错误,并且会产生错误,它冒泡出到客户端,并可能将您相混淆。您可能会认为问题在于对象创建时存在的问题是在初始化代码的实际事件。
如果服务器运行在 Microsoft Windows NT 4 或 Microsoft Windows 2000 中,您可以使用事件查看器以了解有关 DCOM 连接失败的原因的其他审核信息。但是,记录这些类型的事件是通常不启用默认情况下。您需要设置审核选项以启用它。
在 Windows NT 4 中启用这些选项,如下所示:
在 Windows 2000 中启用这些选项,如下所示:
一旦激活这些日志记录选项再次测试您的客户端。您收到错误消息后,使用事件查看器查看是否存在任何 DCOM 事件。该事件可能会告诉您原因,访问被拒绝。此外,它可以告诉您谁已登录到客户端计算机上,如果这是一个域用户或本地用户。它可以告诉您客户端请求的协议不是服务器,等上可用。通常,COM 日志被添加到系统日志中。
在 开始 菜单上选择 程序,选择 管理工具,然后选择 本地安全策略。
在左边的窗格中,您将看到一个树视图。单击加号 (+) 号左边的 本地策略,您看到 审核策略 项。选择 审核策略项,请注意在右窗格包含一个已启用哪些,其中一个不是哪些的所有审核选项。右键单击在下列任一选项使您可以启用或禁用它们。
启用审核成功和失败的以下选项: 审核登录事件、 审核对象访问、 审核特权使用。
关闭 本地安全策略 窗口。
在 开始 菜单上选择 程序,选择 管理工具,然后选择 用户管理器。
如果运行的 NT 4 服务器您必须选择一个域 ; 在这种情况下 用户 菜单上选择 域 选项,然后选择本地计算机。
在 策略 菜单上选择 审核 选项。启用审核的成功和失败的前三个项: 登录/注销、 文件和对象访问使用的用户权限。 单击 确定 并关闭用户管理器。
如果您的服务器有多个类和这些类的某些工作,并且其他人不要,检查 Dcomcnfg 中在客户端计算机上的每个类条目。默认状态下,每个类都有其自己的 AppID,并因此,自己设置以便可以正确设置了一些您的类和其他人并不是。 有关客户端的应用程序列表中定位您的服务器的其他信息请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
268550如何为 Visual Basic DCOM 客户端/服务器应用程序使用 Dcomcnfg
运行时错误 70: 拒绝
此错误通常与安全设置。此错误是一个比较好的提示方法调用到达目标计算机,所以网络连接可能不是问题在此处。下面是要检查的几个事项:
如果将身份验证级别设置为 连接,验证域用户,而不是本地用户以登录用户登录到客户端计算机。
如果将身份验证级别设置为 连接,验证在服务器计算机实际上属于域。 如果独立的计算机它无法验证该用户,除非您在客户端和服务器计算机上有一个匹配的用户名称/密码。
如果将身份验证级别设置为 无,则检查如果您已设置为客户端和服务器计算机上无此选项。
如果您设置为 无 身份验证级别,并且您已经验证两台计算机有正确的此设置确保客户端和服务器应用程序都不设置以编程方式使用功能,如 CoInitializeSecurity 或 CoSetProxyBlanket 身份验证。以编程方式设置身份验证将覆盖从 Dcomcnfg 该注册表项。
如果您将身份验证级别设置为 无,并且您有非域用户选中如果您在权限包括"每个人"(或"的 World"的 Windows 95 和 Windows 98),并启动权限。
检查所的访问权限和 $ 启动 Dcomcnfg 中的权限,并验证用户登录到客户端计算机上显式包含在这些列表,或属于一个组包含用户。
本文中稍后介绍,请参见"已知问题以检查"。有关更多的信息请单击下面文章编号,以查看 Microsoft 知识库中相应的文章:
216051FIX: Dcomcnfg NT 4.0 SP4 做不写下 HKCR\APPID.Exe 文件名
解释COM、COM+和DCOM的定义和区别? COM是组件对象模型,是实现3/N层应用的基础,它的目的就是组件化,应用程序分层.DCOM是分布式的COM,也就说可以远程的创建,最初它利用远程自动化来实现,用注册VBR的方法来配置客户端,来适应DCOM服务器. COM+现在的概念不很清楚,因为它是一个扩展集,MS现在的MTS取代了远程自动化这种原始的功能很弱的方法后,他们似乎已经都是一个集合体. 何谓Mts? MTS(Microsoft Transaction Server)是微软为其Windows NT操作系统推出的一个中间件产品,由于它具有强大的分布事务支持、安全管理、资源管理和多线程并发控制等特性,使其成为在Windows平台上开发大型数据库应用系统的首选产品。由于MTS屏蔽了底层实现的复杂性,极大地简化了这类应用的开发,程序员可以将精力集中在业务逻辑上,因而有效地提高了软件的开发效率. 组件对象模型(COM Componet Object Model),是微软公司为了计算机工业的软件生产更加符合人类的行为方式开发的一种新的软件开发技术。在COM构架下,人们可以开发出各种各样的功能专一的组件,然后将它们按照需要组合起来,构成复杂的应用系统。由此带来的好处是多方面的:可以将系统中的组件用新的替换掉,以便随时进行系统的升级和定制;可以在多个应用系统中重复利用同一个组件;可以方便的将应用系统扩展到网络环境下;COM与语言,平台无关的特性使所有的程序员均可充分发挥自己的才智与专长编写组件模块。 COM是开发软件组件的一种方法。组件实际上是一些小的二进制可执行程序,它们可以给应用程序,操作系统以及其他组件提供服务。开发自定义的COM组件就如同开发动态的,面向对象的API(应用程序调用系统功能的接口)。多个COM对象可以连接起来形成应用程序或组件系统。并且组件可以在运行时刻,在不被重新链接或编译应用程序的情况下被卸下或替换掉。Microsoft的许多技术,如ActiveX(根据微软权威的软件开发指南MSDN(Microsoft Developer Network)的定义,ActiveX插件以前也叫做OLE控件或OCX控件,它是一些软件组件或对象,可以将其插入到WEB网页或其它应用程序中), DirectX(DirectX并不是一个单纯的图形API,它是由微软公司开发的用途广泛的API,它包含有Direct Graphics(Direct 3D+Direct Draw)、Direct Input、Direct Play、Direct Sound、Direct Show、Direct Setup、Direct Media Objects等多个组件,它提供了一整套的多媒体接口方案。只是其在3D图形方面的优秀表现,让它的其它方面显得暗淡无光。DirectX开发之初是为了弥补Windows 3.1系统对图形、声音处理能力的不足,而今已发展成为对整个多媒体系统的各个方面都有决定性影响的接口)以及OLE(OLE是指与对象链接和嵌入有关的技术,包括容器、服务器、就地编辑、拖放和彩单合并等。在应用程序之间共享的一大块数据称为一个OLE对象,能够包含OLE对象的应用程序称为OLE容器,而允许自己的数据被包含到其他应用程序中的程序称为OLE服务器)等都是基于COM而建立起来的。并且Microsoft的开发人员也大量使用COM组件来定制他们的应用程序及操作系统。 COM所含的概念并不止是在Microsoft Windows操作系统下才有效。COM并不是一个大的API(用标准的定义来讲,API就是Windows的32位应用程序编程接口,是一系列很复杂的函数,消息和结构,它使编程人员可以用不同类型的编程语言编制出的运行在Windows95 和Windows NT操作系统上的应用程序。),它实际上象结构化编程及面向对象编程方法那样,也是一种编程方法。在任何一种操作系统中,开发人员均可以遵循“COM方法”。 一个应用程序通常是由单个的二进制文件组成的。当编译器生成应用程序之后,在对下一个版本重新编译并发行新生成的版本之前,应用程序一般不会发生任何变化。操作系统,硬件及客户需求的改变都必须等到整个应用程序被重新生成。 目前这种状况已经发生变化。开发人员开始将单个的应用程序分隔成单独多个独立的部分,也既组件。这种做法的好处是可以随着技术的不断发展而用新的组件取代以有的组件。此时的应用程序可以随新组件不断取代旧的组件而渐趋完善。而且利用已有的组件,用户还可以快速的建立全新的应用。 传统的做法是将应用程序分割成文件,模块或类,然后将它们编译并链接成一个单模应用程序。(静态的链接,文件扩展名为.obj,在进程内实现的)它与组件建立应用程序的过程(称为组件构架)有很大的不同。一个组件同一个微型应用程序类似,即都是已经编译链接好并可以使用的二进制代码,应用程序就是由多个这样的组件打包而得到的。单模应用程序只有一个二进制代码模块。自定义组件可以在运行时刻同其他的组件连接起来以构成某个应用程序。在需要对应用程序进行修改或改进时,只需要将构成此应用程序的组件中的某个用新的版本替换掉即可(动态的链接,文件扩展名为.dll,是在进程外实现的)。 COM即组件对象模型,是关于如何建立组件以及如何通过组件建立应用程序的一个规范,说明了如何可动态交替更新组件。 COM是一种说明如何建立可动态互变组件的规范,此规范提供了为保证能够互操作,客户和组件应遵循的一些二进制和网络标准。通过这种标准将可以在任意两个组件之间进行通信而不用考虑其所处的操作环境是否相同、使用的开发语言是否一致以及是否运行于同一台计算机。 COM的优点? 首先:用户一般希望能够定制所用的应用程序,而组件技术从本质上讲就是可被定制的,因而用户可以用更能满足他们需要的某个组件来替换原来的那个。其次,由于组件是相对应用程序独立的部件,我们可以在不同的程序中使用同一个组件而不会产生任何问题,软件的可重用性将大大的得到增强。第三,随着网络带宽及其重要性的提高,分布式网络应用程序毫无疑问的成为软件市场上越来越重要的买点。组件价构可以使得开发这类应用程序的过程得以简化。 DCOM 是微软与其他业界厂商合作提出的一种分布 组件 对象模型,它是COM在分布计算方面的自然延续,为分布在网络不同节点的两个COM 组件 提供了互操作的基础结构。 DCOM 增强COM的分布处理性能,支持多种通信协议,加强 组件 通信的安全保障,把基于认证Internet安全机制同基于Windows NT的C2级安全机制集成在一起。但从系统内部的实现机制而言, DCOM 所采用的技术仍符合图1所示的COM模式。 DCOM 自动建立连接、传输信息并返回来自远程 组件 的答复。 DCOM 在 组件 中的作用有如PC机间通信的PCI和ISA总线,负责各种 组件 之间的信息传递,如果没有 DCOM ,则达不到分布计算环境的要求。微软通过纳入事务处理服务、更容易的编程以及对Unix和其它平台的支持扩充了 DCOM 。 建立 DCOM 时和使用COM建立对象的方式是相同的,只需再加入一个机器名称的参数。如果COM通过Windows API的CoGetClassObject建立对象,只需再输入机器名称的参数即可在远程指定的计算机中建立对象,并且取得指定接口的信息。它构造于RPC的技术之上,并且使用TCP/IP作为网络通信协议。 什么是COM+ ? COM+并不是COM的简单升级,COM+的底层结构仍然以COM为基础,它几乎包容了COM的所有内容,COM+综合了COM、DCOM和MTS这些技术要素,它把COM组件软件提升到应用层而不再是底层的软件结构,它通过操作系统的各种支持,使组件对象模型建立在应用层上,把所有组件的底层细节留给操作系统,因此,COM+与操作系统的结合更加紧密。 COM+不再局限于COM的组件技术,它更加注重于分布式网络应用的设计和实现。COM+继承了COM几乎全部的优势,同时又避免了COM实现方面的一些不足,把COM、DCOM和MTS的编程模型结合起来,继承了它们的绝大多数特性,在原有的特性上增加了新的功能。 COM+的新的优点? 以下列出COM+的几个主要特性: COM+不仅继承了COM所有的优点,而且还增加了一些服务,比如队列服务、负载平衡、内存数据库、事件服务等。 队列服务对于分布式应用非常有意义,特别是在现在网络速度很慢的情况下,这种机制可以保证应用系统能够可靠地运行。在应用系统包含大量节点但服务器又繁忙的情况下,客户应用程序可以把它们的请求放到队列中,当服务器负载比较轻的时候再处理这些请求; 又如COM+提供了负载平衡服务,它可以实现动态负载平衡,而且COM+应用程序的负载平衡特性并不需要编写代码来支持,客户程序和组件程序都可以按通常的方式实现。获得负载平衡特性并不是用程序设计的方式来实现的,而是通过配置实现分布式应用程序的负载平衡,如上所讲的队列服务,其实也反映了一种负载平衡。 (1) 真正的异步通讯。COM+底层提供了队列组件服务,这使客户和组件有可能在不同的时间点上协同工作,COM+应用无须增加代码就可以获得这样的特性。 (2) 事件服务。新的事件机制使事件源和事件接收方实现事件功能更加灵活,利用系统服务简化了事件模型,避免了COM可连接对象机制的琐碎细节。 (3) 可伸缩性。COM+的可伸缩性来源于多个方面,动态负载平衡以及内存数据库、对象池等系统服务都为COM+的可伸缩性提供了技术基础,COM+的可伸缩性原理上与多层结构的可伸缩特性一致。 (4) 可管理和可配置性。管理和配置是应用系统开发完成后的行为,在软件维护成本不断增加的今天,COM+应用将有助于软件厂商和用户减少这方面的投入。 (5) 易于开发。COM+应用开发的复杂性和难易程度将决定COM+的成功与否,虽然COM+开发模型比以前的COM组件开发更为简化,但真正提高开发效率仍需要借助于一些优秀的开发工具。 COM+标志着Microsoft的组件技术达到了一个新的高度,它不再局限于一台机器上的桌面系统,它把目标指向了更为广阔的企业内部网,甚至Internet国际互连网络。COM+与多层结构模型以及Windows操作系统为企业应用或Web应用提供了一套完整的解决方案。本文档根据各种不同的情况,讲述如何进行OPC DCOM配置。 对于远程访问OPC服务器,需要在客户和服务器计算机上都进行DCOM设置,以前我们采用的方式是: 客户、服务器都建立一个名字、密码相同的具有管理员权限的帐号,并分别以次登录,在服务器端将OPC服务器的启动方式设为交互式用户。这种方法虽然方便,但安全性较差,不利于在实际应用中推广。这里提供一些较合理的解决方案。(假定都是在工作组里) (1) 序言 在使用了OPC技术,并有网络数据访问的应用系统中,不可避免地要进行OPC DCOM权限配置。 DCOM配置与windows操作系统的安全体系结合在一起,而各版本的操作系统(9x、NT、2000、XP等)的安全体现又或多或少地有所区别;同时,OPC服务器运行的方式也不尽相同(进程内、进程外、系统服务、有无界面……);而且,不同的应用系统对安全的要求也不同。总之,要想根据具体情况尽量合理地完成OPC DCOM配置并不是一件很轻松的事。 本文档根据各种不同的情况,讲述如何进行OPC DCOM配置。 (2) 准备 要进行DCOM安全配置,操作者通常必须拥有客户和服务器计算机的管理员权限。 【注意】一般情况下,DCOM通信是基于TCP/UDP的,所使用的端口不固定,很可能被一些防火墙软件屏蔽。如果本文下述配置不成功的话,请尝试关闭客户和服务器计算机上的防火墙,或者以带网络连接的安全模式启动系统(这时防火墙软件一般不被自动运行)。 (3) 最简单的情况 如果用户对网络安全基本上没有要求,或者处于客户、服务器程序开发阶段,...... (4) 服务器计算机始终有用户登录的情况(NT/2000) 这也是实际应用中比较常见的情况,但对于以NT服务方式运行的OPC服务器不适合。设置方法如下: Ø 在服务器计算机上建立一个用户,如OPCUser,可以是管理员,也可以是一般用户,服务器计算机在运行OPC服务器时必须以这个用户登录。 Ø 在服务器计算机上建立一个用户组,如OPCClients。 (单一客户情况下可以不建立,建这个组的目的是管理方便) Ø 在各个OPC客户计算机中,分别建立OPCUser用户,口令也要与服务器上的一致,可以设为普通用户以保证安全。 Ø 客户计算机运行时不必以OPCUser登录,比如使用ClientA登录,就要在服务器上建立相同的用户ClientA及相同的密码。并在服务器计算机上将ClientA加入到OPCClients组中。ClientA在客户和服务器计算机上都可以是普通用户。 Ø 服务器端DCOM配置 运行dcomcnfg,进行如下设置: 默认属性: 启用DCOM; 默认身份验证级别:连接 默认模拟级别:标识 默认安全机制: 默认访问权限: 至少要保证OPCClients组允许访问,也可放宽至Everyone; 默认启动权限:至少保证允许INTERACTIVE用户调用; 默认配置权限:一般情况下不需修改。 默认协议:保证面向连接的TCP/IP在最上,其它可以删除。 具体的服务器配置: 常规:身份验证级别为默认值; 位置:在这台计算机上运行; 安全性:使用默认的访问和启动权限,配置权限不要修改; 身份标识:交互式用户。 终结点:不修改。 OPCEnum程序配置: 在dcomcnfg程序的应用程序列表里找到opcenum.exe,对其按照上面具体服务器的配置进行设置。 Ø 客户计算机的配置: 为了保证OPC数据订阅等回调机制能正常运行,需要对客户计算机的DCOM权限进行配置。 默认属性、默认协议的配置和服务器端基本一致; 默认安全机制只需要修改默认访问权限。保证允许OPCUser访问。也可放宽至Everyone。 【注意】 在服务器没有用户登录的情况下,远程将无法启动OPC服务器; 对于有用户界面,并需要界面交互的OPC服务器,建议(可能必须)采用这种方式。 (5) OPC服务器为后台程序的情况(NT/2000) 这种情况下,服务器计算机可以没有用户登录。 做为后台程序,OPC服务器有两种运行方式:系统服务(service)方式和普通用户程序。 这里只介绍普通程序方式,系统服务方式的配置说明以后添加。 OPC服务器做为普通方式运行的后台程序,一般没有用户界面。完全可以按照(1)中有界面的方式进行配置,即设置为交互式用户启动。 但是(1)的配置方式限定了服务器计算机必须有用户登录,而且登录用户必须在客户计算机上有DCOM访问权限。所以,无界面的后台OPC服务器可以用另一种更灵活的方式运行。 配置方法:(未明确说明的部分与(1)相同) 在服务器端按照(1)中所述建立一个OPCUser用户,专门用来运行OPC服务器。然后在OPC服务器属性配置中,将启动方式改为指定用户,注意要输入用户密码。 这样,OPC服务器计算机可以用任意用户登录,当客户计算机发出连接请求时,系统负责以OPCUser的身份运行OPC服务器,如果已经运行则使用已有的OPC服务器。 【注意】还有一种启动方式,是“启动”用户。即系统以发连接请求的用户的身份启动OPC服务器,这可能造成服务器计算机上同时运行多个OPC服务器的实例,显然不妥。所以一般情况下不建议设置为“启动”用户,虽然它是缺省选项。 (6) Windows XP系统下的配置说明 在XP操作系统(SP1,不包括SP2及其以后版本)下,OPC的配置实际上和NT/2000基本一样,这体现在OPC DCOM相关的各项配置在注册表中的位置、名称都是一致的。 二者只是配置界面不同欢迎分享,转载请注明来源:夏雨云
评论列表(0条)