CN101765817A - 可编程逻辑控制器协议转换器 - Google Patents

可编程逻辑控制器协议转换器 Download PDF

Info

Publication number
CN101765817A
CN101765817A CN200880100586A CN200880100586A CN101765817A CN 101765817 A CN101765817 A CN 101765817A CN 200880100586 A CN200880100586 A CN 200880100586A CN 200880100586 A CN200880100586 A CN 200880100586A CN 101765817 A CN101765817 A CN 101765817A
Authority
CN
China
Prior art keywords
plc
thread
data
memory array
agreement
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN200880100586A
Other languages
English (en)
Inventor
J·卡普曼
T·R·卡明斯
H·J·拉巴特-托基
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
LAir Liquide SA pour lEtude et lExploitation des Procedes Georges Claude
Original Assignee
LAir Liquide SA pour lEtude et lExploitation des Procedes Georges Claude
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by LAir Liquide SA pour lEtude et lExploitation des Procedes Georges Claude filed Critical LAir Liquide SA pour lEtude et lExploitation des Procedes Georges Claude
Publication of CN101765817A publication Critical patent/CN101765817A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B19/00Programme-control systems
    • G05B19/02Programme-control systems electric
    • G05B19/04Programme control other than numerical control, i.e. in sequence controllers or logic controllers
    • G05B19/05Programmable logic controllers, e.g. simulating logic interconnections of signals according to ladder diagrams or function charts
    • G05B19/058Safety, monitoring
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B19/00Programme-control systems
    • G05B19/02Programme-control systems electric
    • G05B19/418Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM]
    • G05B19/4185Total factory control, i.e. centrally controlling a plurality of machines, e.g. direct or distributed numerical control [DNC], flexible manufacturing systems [FMS], integrated manufacturing systems [IMS] or computer integrated manufacturing [CIM] characterised by the network communication
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/10Plc systems
    • G05B2219/14Plc safety
    • G05B2219/14002Independent processor, coprocessor monitors plc
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/31From computer integrated manufacturing till monitoring
    • G05B2219/31348Gateway
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/31From computer integrated manufacturing till monitoring
    • G05B2219/31436Host monitors plc, control processor without interrupting its program
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/02Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • General Engineering & Computer Science (AREA)
  • Manufacturing & Machinery (AREA)
  • Quality & Reliability (AREA)
  • Programmable Controllers (AREA)
  • Computer And Data Communications (AREA)

Abstract

公开了一种可编程逻辑控制器(PLC)协议转换器,其允许监督控制和数据获取(SCADA)系统使用期望的通信协议与PLC设备有效地通信,特别在PLC设备没有“说出”期望的通信协议的情况下。第一线程可被配置为使用PLC设备知晓的通信协议逐个地连续读取PLC地址。第一线程可将数据值存储在程序存储器中的共享数据阵列中。因此,第一线程从PLC设备暴露在配置文件中指定的数据。同时,第二线程可被配置为根据第二通信协议例如向SCADA系统供应在共享数据阵列中的数据。

Description

可编程逻辑控制器协议转换器
本申请依据35U.S.C.§119(e)要求享受2007年7月26日递交的临时申请No.60/952,118的优先权,其全部内容以引用方式并入本文。
背景技术
许多工业设施采用通常称为PLC(可编程逻辑控制器的简称)的设备。已知地,PLC提供了基于微处理器的工业控制系统。PLC通过数据链路与其他处理控制部件通信。在处理控制中,PLC用于简单的开关任务(例如打开和关闭阀门)、PID控制、复杂数据操作、算术运算、定时和处理和机器控制等。例如,PLC可连接至被配置为提供温度、压力、流速、以及与工业操作的操作状态相关的各种其他数值的传感器。类似地,PLC还可收集与离散值相关的信息,例如给定的阀门是打开的还是关闭的。PLC可被配置为在特定地址、寄存器、或数据库位置中存储这种信息。
此外,在PLC中包括的微处理器可被配置为基于所报告的数据参与各种处理控制行为。例如,PLC可被编程为保持处理室内的特定温度。在这种情况下,当温度下降到指定最小值以下时,PLC可执行增加温度的行为(例如关闭/打开阀门,增加流向燃烧室的燃料等)。类似地,当温度超过指定最大值时,PLC可执行相反的行为降低温度。
此外,PLC可被配置为响应于在任意给定的时间点对于给定传感器记录什么值的相关信息的请求。这个请求典型地采用对于特定存储器位置或数据库值的请求的形式。此外,必须使用PLC“知晓”的通信协议来对这个请求格式化。在一些情况下,可通过向PLC增加通信卡来提高PLC表达给定通信协议的能力。然而,向PLC增加通信卡频繁地需要大量的PLC配置,并且通常需要工厂停工,这可能极端破坏性。此外,一些通信卡仅提供从PLC设备对有限数据的访问-因此,取决于工厂操作者期望从PLC取出什么样的数据,这个方法可能很容易失败。
发明内容
本发明的一个实施例提供一种从可编程逻辑控制器(PLC)设备暴露数据的方法。所述方法一般地包括:访问用于识别要暴露的多个PLC地址的配置文件;和初始化共享的存储器阵列。所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据。所述方法还包括:调用第一线程。所述第一线程一般地可被配置为重复地:发送对于所识别的PLC地址之一的请求,以及响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值。每个请求根据第一通信协议来配置。所述方法还包括:调用第二线程。所述第二线程一般地可被配置为:接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;取出所请求的一个或多个数据值;以及以与所述第二通信协议一致的格式返回所请求的数据值。
本发明的另一实施例包括一种计算机可读存储介质,其包括被配置为执行从PLC设备暴露数据的非侵入方法的程序,所述程序包括用于执行操作的指令。所述操作一般地可包括:访问用于识别要暴露的多个PLC地址的配置文件;和初始化共享的存储器阵列。所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据。所述操作还包括:调用第一线程。所述第一线程一般地可被配置为重复地:发送对于所识别的PLC地址之一的请求,以及响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值。每个请求根据第一通信协议来配置。所述操作还包括:调用第二线程。所述第二线程一般地可被配置为:接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;取出所请求的一个或多个数据值;以及以与所述第二通信协议一致的格式返回所请求的数据值。
本发明的另一实施例包括一种系统,其具有处理器以及存储器,所述存储器包含被配置为执行从PLC设备获得数据值的操作的程序。由所述程序执行的操作一般地可包括:访问用于识别要暴露的多个PLC地址的配置文件;和初始化共享的存储器阵列。所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据。所述操作还包括:调用第一线程。所述第一线程一般地可被配置为重复地:发送对于所识别的PLC地址之一的请求;以及响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值。每个请求根据第一通信协议来配置。所述操作还包括:调用第二线程。所述第二线程一般地可被配置为:接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;取出所请求的一个或多个数据值;以及以与所述第二通信协议一致的格式返回所请求的数据值。
附图说明
为了进一步理解本发明的特点和目的,可参照以下具体实施方式的描述并结合附图,在附图中对于类似的元素给出相同或相似的标号,其中:
图1是根据本发明一个实施例的被监视工业设施和操作控制中心的概念性视图,所述操作控制中心包括SCADA系统,其被配置为与PLC转换器系统和PLC设备通信;
图2是示出根据本发明一个实施例被配置为执行PLC协议转换处理的PLC转换器系统的部件的框图;
图3是示出根据本发明一个实施例由PLC协议转换器使用的共享的存储器阵列以允许使用期望的通信协议与PLC设备通信的概念图;以及
图4示出根据本发明一个实施例的PLC协议转换器使用期望的通信协议与PLC设备通信的方法。
具体实施方式
本发明实施例提供一种PLC协议转换器系统,其允许SCADA系统使用期望的通信协议与PLC设备有效地通信,特别在PLC设备没有“说出”期望的通信协议的情况下。SCADA系统(监督控制和数据获取系统的简称)使得处理数据中心化,并允许远程监视和控制各种工业系统。SCADA系统可被配置为从远程位置实时收集数据,以在流水线(例如烃流水线、或氢流水线)中控制设备和条件。例如,SCADA系统可被配置为向PLC控制器发送对于在存储器中的地址处记录的值的请求,其表示在工业工厂中传感器那时的当前值、或在工业工厂中部件的离散状态。对于与PLC通信的SCADA系统,两者必须能够使用兼容的通信协议进行通信。
在一个实施例中,PLC转换器系统可以是这样的计算机(例如嵌入式系统),其被配置为通过执行应用程序与PLC设备和SCADA系统通信。实践中,程序可读取配置文件,其识别从PLC期望什么数据元素(例如存储器值、寄存器值、或数据库字段值),以及映射从PLC收集的数据的一组存储器地址(例如MODBUS地址)。可基于配置文件中的存储器地址将收集的数据存储在共享的存储器阵列的单元内。可使用已知的通信协议(例如ftp)将配置文件发送至PLC转换器。
此外,程序可包括第一线程,其被配置为使用PLC设备知晓的通信协议逐个地连续读取期望的PLC地址。例如,PLC转换器可使用串行连接物理地连接至PLC设备,从而允许程序使用PLC设备知晓的串行线协议发送对于信息的请求。在特定实施例中,所述协议是已知的非智能终端协议(NITP)。第一线程可将数据值存储在程序存储器中的共享数据阵列中。因此,第一线程从PLC设备暴露在配置文件中指定的数据。
同时,程序还可包括第二线程,其被配置为根据第二通信协议例如向SCADA系统供应在共享数据阵列中的数据。例如,第二线程可使用已知的TCP-MODBUS协议从共享存储器向“知晓”TCP-MODBUS协议的SCADA系统供应数据。这个操作允许来自PLC设备的数据对于经由PLC转换器系统上存在的以太网端口接收的任意MODBUS主轮询(poll)实现共享。因此,实践中,PLC转换器系统伪装成PLC设备,用于响应MODBUS消息请求。此外,如果期望从第一线程暴露的集增加(或去除)数据点,则用户简单地修改配置文件,(例如经由ftp)将其上传至PLC转换器系统,并(例如使用基于HTTP的诊断接口)重启程序。
有利地,本发明实施例可用于提供对于PLC数据库中的任意数据类型(例如数字的、离散的等)的只读访问,以及在SCADA系统知晓的协议下提供数据。此外,本发明实施例不需要PLC设备自身中的任何配置、或任何处理器重启/关闭来运行;可在不存在对PLC设备的任何影响的情况下连接至/断开连接至PLC设备;以及可(例如经由TCP连接)连接至SCADA系统,以允许远程配置、管理、和使用。
注意,在这里相对于特定PLC设备-即5x5系列设备-从德国柏林西门子公司购买-描述了本发明实施例。已知地,5x5系列(特别地505系列)提供这样一种PLC设备,其能够响应于在RS-232串联上使用非智能终端协议(NITP)格式化的请求,但是不支持(至少没有某种附加通信卡)使用MODBUS轮询的数据的请求。此外,还已知地,即使具有附加通信卡,由该通信卡提供的MODBUS数据映射仅允许访问PLC数据库中可用数据类型的子集。然而,本领域普通技术人员可理解,5x5系列设备仅是示例性的,并且本发明不限于此。
本发明一个实施例可作为计算机系统使用的一个或多个软件程序来实现。程序包括执行本发明实施例(包括这里所述的方法)的指令,并可存储在各种计算机可读介质上。示例性计算机可读介质包括但不限于:(i)在上面永久存储信息的不可写存储介质(例如计算机中的只读存储设备,例如CD-ROM或DVD-ROM驱动器可读的CD-ROM或DVD-ROM盘)和/或(ii)在上面存储可变信息的可写存储介质(例如在盘驱动器中的软盘、硬盘驱动器、或闪存设备)。其他介质包括向计算机传送信息所经由的通信介质,例如计算机或电话网络,包括无线通信网络。后一实施例特别地包括向/从因特网和其他网络发送信息。当承载执行本发明功能的计算机可读指令时,这种计算机可读介质代表本发明的实施例。
此外,这里的描述引用了本发明的实施例。然而,应理解,本发明不限于任何特定描述的实施例。相反,无论是否与不同实施例相关,以下特征和元素的任意组合可考虑为实现和实践本发明。此外,在各个实施例中,本发明提供了相比于现有技术的多个优点。然而,尽管本发明实施例可实现相比于其他可能方案和/或相比于现有技术的优点,但是通过给定实施例是否实现特定优点并不构成对本发明的限制。因此,以下方面、特点、实施例和优点仅是示例性的,并非认为是所附权利要求的元素或限制,除非在权利要求中清楚阐述。同样,对“本发明”的提及不应该理解为这里公开的任意发明主题的概括,并且不应该认为是所附权利要求的元素或限制,除非在权利要求中清楚阐述。
一般地,被执行以实现本发明实施例的例程可以是操作系统或特定应用、部件、程序、模块、对象、或指令序列的一部分。此外,程序包括驻留在程序本地中或在存储器中或存储设备上找到的变量和数据结构。此外,以下描述的各个程序可基于在本发明特定实施例中实现的应用来识别。然而,应理解,随后的任意特定程序术语仅为了方便而使用,因此本发明不限于仅在由这些术语识别和/或暗示的任意特定应用中使用。
图1是根据本发明一个实施例的被监视工业设施105和操作控制中心130的概念性视图,所述操作控制中心130包括SCADA系统135,其被配置为与PLC转换器系统120和PLC设备115通信。如图所示,被监视工业设施105包括由PLC设备115监视和管理的工厂系统110的集合。包括工厂系统110的集合,以代表由PLC设备115控制的各种工业处理。工厂系统的实例包括低温空气分离单元、水处理工厂、液体产品喷雾器、和氢净化单元。如上所述,PLC设备115提供了可编程逻辑控制器,其被配置为通过数据链路与其他处理控制部件通信,并且PLC设备115可用在简单的开关任务(例如打开和关闭阀门)的处理控制、PID控制、复杂数据操作、算术运算、定时和处理和机器控制等中。在特定实施例中,PLC设备115是购于德国柏林的西门子公司的5x5系列设备。当然,可使用具有这里所述特征的其他PLC设备。
在一个实施例中,PLC设备115可响应于来自PLC转换器系统120的请求。这种请求可使用通信协议来格式化,并且可以在PLC设备115和PLC转换器系统120之间建立的数据链路上发送。例如,PLC转换器系统120可被配置为使用串行线连接(由箭头117所示)与PLC设备115通信,以使用NITP协议发送请求(和接收响应)。
同时,PLC转换器系统120还可被配置为通过网络137(由箭头119所示)与SCADA系统135通信。例如,SCADA系统135可向请求已识别的MODBUS地址块的PLC转换器系统120提交MODBUS主轮询。响应地,在PLC转换器系统120上执行的应用程序可从共享的存储器阵列取出所请求地址的值,并发送至SCADA系统135。
在特定实施例中,PLC转换器系统120是购于
Figure GPA00001009423400071
公司的UC-7110型嵌入式计算机系统,其配置有多线程应用程序,如这里详细所述。已知地,UC-7110型提供具有两个串联端口的基于RISC的准备运行计算机,和双局域网。当然,本发明实施例可适于使用具有这里所述特征的其他计算设备。
在一个实施例中,将来自SCADA系统135的请求的结果发送至操作控制中心130。操作控制中心130可采用多个计算机系统,这些系统运行用于协调、监视、和控制被监视工业设施105的操作的应用程序。图示地,流水线操作控制中心130包括SCADA系统135、SCADA数据库145、HTTP服务器148和客户端系统170,他们被配置为在局域网137上彼此通信。注意,包括在操作控制中心130中所示的计算机系统135和170以代表现有的计算机系统,例如台式计算机、服务器计算机、膝上型计算机、平板式计算机等。然而,本发明实施例不限于任意特定计算系统、应用、设备、架构或网络,相反,可适用于利用新的计算系统和平台(在他们可用时)。此外,本领域普通技术人员将认识到,简化计算机系统135、148、和170的视图以突出本发明的多个方面,并且计算系统和网络典型地包括图1中没有示出的多个部件。
如上所述,SCADA系统135可被配置为使得来自各个工业操作的处理数据中心化,并允许远程监视和控制被监视的工业设施105。图示地,将SCADA系统135接收的数据存储在数据库145中。此外,浏览器应用175可被配置为从数据库145请求与被监视工业操作的当时现存(或历史)状态相关的数据。典型地,HTTP服务器148被配置为发送由web浏览器(例如SCADA浏览器应用175)呈现的HTML网页,其中网页的内容以结构化的形式表现来自数据库142的信息。由此,客户端计算机系统170包括web浏览器175,其用于呈现从web服务器HTTP服务器148接收的信息。注意,尽管将数据库145和web服务器148示出为单独的系统,但是本领域普通技术人员可认识到,这些部件可以以各种方式组织和配置。
图2是示出根据本发明一个实施例被配置为执行PLC协议转换处理的PLC转换器系统120的部件的框图。如图所示,PLC转换器系统120包括CPU 215、存储设备220、存储器230、串行连接端口205和以太网连接端口210,其每个连接至总线211。包括CPU 215以代表单个CPU、多个CPU、具有多个处理核的单个CPU等。例如,
Figure GPA00001009423400081
的嵌入式系统包括ARM932位192MHz处理器。存储设备220可提供用于由PLC转换器系统120使用的应用程序和数据的永久存储区。存储设备220的实例包括一个或多个硬盘驱动器、固态存储器设备、光学介质等。图示地,示出存储器220包括配置文件220。在一个实施例中,配置文件225提供一组逗号分隔值(CSV),其指示通过PLC转换器系统120使得哪个PLC设备地址可用,以及通过PLC转换器系统120使得每个这样的地址应该映射到哪些MODBUS地址(例如哪个MODBUS地址)。
存储器230可以是一个存储器设备或其组合,包括随机存取存储器、非易失性或备用存储器(例如可编程或闪速存储器、只读存储器等)。图示地,存储器230存储操作系统260、共享的存储器阵列250、和PLC协议转换器应用235。操作系统260用于管理硬件和在PLC转换器系统120上执行的软件,包括PLC协议转换器应用235。此外,操作系统260可包括与PLC转换器系统120和PLC协议转换器应用235交互所需的任意数目的实用应用(例如FTP或HTTP服务器处理)。
如图所示,PLC协议转换器应用235包括第一线程240(标记为NITP线程)和第二线程245(标记为MODBUS线程)。在一个实施例中,第一线程240被配置为在PLC设备115中连续读取在配置文件220中标识的地址。此外,可使用PLC设备115知晓的通信协议(例如西门子公司505系列PLC知晓的NITP协议)逐个地读取地址。第一线程240可在共享的存储器阵列250中存储从PLC设备115读取的数据值。因此,第一线程240从PLC设备115暴露在配置文件220中指定的数据。
在开始时,PLC协议转换器应用235读取配置文件220,其描述期望哪些PLC地址以及将他们映射到哪些MODBUS地址。在一个实施例中,评估从配置文件220读取的信息,以构建第一线程240使用的信息集,收集来自PLC设备115的数据值。例如,在一个消息中可以传送多少个数据元素方面NITP是受限的,因此消息一般被构建为确保PLC设备115不会因为数据请求而负担过多。一旦构建消息,则第一线程240开始逐个地将他们发送至PLC设备115,每次在发送下一个之前等待响应。在共享的存储器阵列250中存储来自每个后续响应的数据,以由PLC协议转换器应用235的第二线程245使用。在一个实施例中,第一线程240在无限循环中按规律间隔重复发送消息,直到接收到指引PLC协议转换器应用235关闭的中断。
第二线程245一般被配置为向SCADA系统135供应在共享的存储器阵列250中存储的数据。即,第二线程245一般可被配置为用作MODBUS从设备,按需提供MODBUS地址值。例如,在一个实施例中,第二线程245等待经由以太网端口210上建立的TCP连接、来自SCADA系统135的命令请求,并用来自共享的存储器阵列250的所请求值进行响应。与第一线程240类似,第二线程245一般也可以在无限循环中运行,始终等待来自SCADA系统135的新数据请求,直到接收到指引PLC协议转换器应用235关闭的中断。
图3是进一步示出根据本发明一个实施例由PLC控制转换器应用235使用的共享的存储器阵列250的框图。如图所示,共享的存储器阵列250包括数字数据值的阵列槽的集合335、离散数据值的阵列槽的集合340、和诊断值的阵列槽的集合345。此外,第一线程240(标记为NITP线程)的操作通常表现为图3中的共享的存储器阵列250的左侧,第二线程245(标记为MODBUS线程)的操作通常表现为图3中的共享的存储器阵列250的右侧。在一个实施例中,使用数字数据值335和离散数据值340之一的每个槽来存储从PLC设备115取出的数据值。还可将数字数据值335和离散数据值340之一的每个槽与MODBUS地址相关联,从而允许第二线程245响应于从SCADA系统135接收的对MODBUS地址值的请求。
在一个实施例中,每个数字数据值的阵列槽提供4字节存储空间来存储浮点数。数字数据值335典型地存储可沿着连续范围下降的工业设施105的某个方面的度量,例如温度、压力、流速等。离散数据值340典型地存储可取得整数或布尔值的工业设施105的某个方面的度量,例如整数计数或作为“打开”或“关闭”的开关的位置。
图示地,图3示出从PLC设备115提出的“LPV1”地址、“V101”地址、和“LSP3”地址,并将他们存储在共享的存储器阵列250中的数字数据值335的前三个阵列槽中。已知地,对于西门子505系列PLC设备,“LPV1”、“V101”和“LSP3”地址分别对应于控制循环的处理变量1、一般存储器变量101、和控制循环的设置点3。此外,在这个实例中,阵列槽映射到对于MODBUS地址的“40,000”序列的前三个值。还已知地,将MODBUS地址细分为块,其中“40,000”序列被普遍理解为包含数字数据的“保持寄存器”。在一个实施例中,SCADA系统130可通过在以太网连接210上向第二线程245发送消息来请求任意数字数据值335。响应地,第二线程245从共享的存储器阵列250取出所请求的值,并在以太网连接210上将其发送至SCADA系统130,如箭头320所示。
类似地,图3示出从PLC设备115提出的“X1”地址和“C3”,并将其存储在共享的存储器阵列250中的离散数据值340的前三个阵列槽中。已知地,对于西门子505系列PLC设备,“X1”和“C3”PLC地址分别对应于开关状态1和输出线圈3。此外,在这个实例中,阵列槽映射到对于MODBUS地址的“10,000”序列的前三个值。类似于数字数据值335,SCADA系统130也可通过在以太网连接210上向第二线程245发送消息来请求任意离散数据值340。响应地,第二线程245从共享的存储器阵列250取出所请求的值,并在以太网连接210上将其发送至SCADA系统130,如箭头325所示。
在一个实施例中,除了从PLC设备115提出数据值之外,第一线程240还可被配置为向共享的存储器阵列250中保留的槽写入用于诊断值345的信息。例如,图3示出为了诊断信息(例如日期、时间、一般状态等)而保留的阵列槽。诊断值345一般地可用于记录与协议转换器应用235和/或PLC转换器系统120的运行状态相关的信息。如PLC地址值,SCADA系统130可向第二线程245发送对于诊断值345的请求。在响应中,第二线程245可从共享的存储器阵列250取出所请求的值,并在以太网连接210上将其发送至SCADA系统130,如箭头330所示。
图4示出根据本发明一个实施例的PLC协议转换器应用230使用期望的通信协议与PLC设备115通信的方法400。在一个实施例中,可使用PLC协议转换器应用230来执行方法400用于与PLC设备115(例如西门子公司的505系列PLC设备)和SCADA系统130通信,如上所述。然而,本领域普通技术人员将认识到,在这里可为了图示的目的使用特定设备、软件和产品的实例,在不脱离本发明的范围的情况下,可以使用其他类型的这些项目。
如图所示,方法400开始于步骤405,其中PLC协议转换器应用230开始执行。在一个实施例中,该应用可读取配置文件220并创建共享的存储器阵列250。初始地,阵列250包括用于数字数据值335、离散数据值340和诊断值345的槽,如配置文件220所指定的,而在各自的阵列元中没有任何实际数据。在步骤410,PLC协议转换器应用230可初始化第一线程240和第二线程245。参照步骤410-435描述第一线程240的操作,参照步骤445-465描述第二线程245的操作。
在步骤415,第一线程240建立与PLC设备115的连接。例如,如上所述,可与西门子公司505系列PLC设备建立RS-232串联。步骤420-435代表PLC协议转换器应用230继续执行时由第一线程240执行的循环。在步骤420,第一线程240识别要从PLC设备115请求的下一数据值。例如,第一线程240可在共享的存储器阵列250中保持代表最后更新值的索引。在这种情况下,第一线程240在每次通过步骤420-435的循环时将索引递增至下一值。在步骤425,第一线程240可向PLC设备115发送消息,以请求在步骤420识别的PLC地址。例如,如上所述,可向西门子公司505系列PLC设备发送使用NITP协议构成的消息。一旦接收到响应,则在共享存储器阵列250的适当位置中存储从PLC设备115发送的值(步骤430)。在步骤435,第一线程240可确定是否(例如经由中断)接收到关闭命令。然而,只要PLC协议转换器应用230继续执行,则第一线程240继续逐个地读取期望的PLC地址。
在一个实施例中,第二线程245响应于来自SCADA系统130的对于共享的存储器阵列250中的值的请求,同时由第一线程240更新这样的值。在步骤445,第二线程445建立与SCADA系统130的连接。例如,如上所述,PLC转换器应用230可被配置为建立与SCADA系统120的TCP连接,从而允许第二线程245用作MODBUS从设备。步骤450-460代表PLC协议转换器应用230继续执行时由第二线程245执行的循环。在步骤450,第二线程240接收对于共享的存储器阵列250中一段范围的值的请求。在一个实施例中,该请求可被格式化为对于一段范围的MODBUS地址的MODBUS请求。在步骤445,第二线程245从共享的存储器阵列250取出所请求的值,并且在步骤450,以适当格式(例如MODBUS格式)向SCADA系统130发送所请求的数据。在步骤465,第二线程240可确定是否(例如经由中断)接收了关闭命令。然而,只要PLC协议转换器应用230继续执行,则第二线程可等待,并响应对于共享的存储器阵列250中的信息的请求。
有利地,本发明实施例提供了一种PLC协议转换器系统,其允许SCADA系统使用期望的通信协议有效地与PLC设备通信,特别在PLC设备没有“说出”期望的通信协议的情况下。如上所述,本发明实施例可用于提供对于PLC数据库中任意数据类型(例如数字、离散等)的只读访问,并使用SCADA系统理解的协议提供数据。此外,本发明实施例不需要在PLC设备自身中的任何配置,或任意处理器重启/关闭来作用;可与PLC设备连接/断开连接,而不对PLC设备存在任何影响;以及可(例如经由TCP连接)连接至SCADA系统,以允许远程配置、管理和使用。
已经描述了用于实践本发明的优选方法和装置。对于本领域普通技术人员来说,可容易理解并且清楚地是,在不脱离本发明的精神和范围的情况下,可以对上述实施例进行许多改变和修改。以上内容仅是示例性的,并且在不脱离由随后权利要求限定的本发明的真实范围的情况下可采用集成的方法和装置的其他实施例。

Claims (24)

1.一种从可编程逻辑控制器(PLC)设备暴露数据的方法,包括:
访问用于识别要暴露的多个PLC地址的配置文件;
初始化共享的存储器阵列,其中所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据;
调用第一线程,其中所述第一线程被配置为重复地:
发送对于所识别的PLC地址之一的请求,其中所述请求根据第一通信协议来配置;以及
响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值;以及
调用第二线程,其中所述第二线程被配置为:
接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;
取出所请求的一个或多个数据值;以及
以与所述第二通信协议一致的格式返回所请求的数据值。
2.如权利要求1所述的方法,其中对于一个或多个数据值的请求通过监督控制和数据获取(SCADA)系统发送,并返回至该SCADA系统。
3.如权利要求1所述的方法,其中所述第一协议包括非智能终端协议(NITP)。
4.如权利要求1所述的方法,其中所述第一协议用于在所述PLC设备和所述第一线程之间建立的串行通信数据链路上通信。
5.如权利要求1所述的方法,其中所述第二协议包括TCP/MODBUS协议。
6.如权利要求1所述的方法,其中所述共享的存储器阵列包括至少一个数字数据值。
7.如权利要求1所述的方法,其中所述共享的存储器阵列包括至少一个离散数据值。
8.如权利要求1所述的方法,其中所述共享的存储器阵列包括至少一个诊断值。
9.一种计算机可读存储介质,其包括被配置为执行一种从可编程逻辑控制器(PLC)设备暴露数据的方法的程序,所述程序包括用于执行操作的指令,所述操作包括:
访问用于识别要暴露的多个PLC地址的配置文件;
初始化共享的存储器阵列,其中所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据;
调用第一线程,其中所述第一线程被配置为重复地:
发送对于所识别的PLC地址之一的请求,其中所述请求根据第一通信协议来配置;以及
响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值;以及
调用第二线程,其中所述第二线程被配置为:
接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;
取出所请求的一个或多个数据值;以及
以与所述第二通信协议一致的格式返回所请求的数据值。
10.如权利要求9所述的计算机可读存储介质,其中对于一个或多个数据值的请求通过监督控制和数据获取(SCADA)系统发送,并返回至该SCADA系统。
11.如权利要求9所述的计算机可读存储介质,其中所述第一协议包括非智能终端协议(NITP)。
12.如权利要求9所述的计算机可读存储介质,其中所述第一协议用于在所述PLC设备和所述第一线程之间建立的串行通信数据链路上通信。
13.如权利要求9所述的计算机可读存储介质,其中所述第二协议包括TCP/MODBUS协议。
14.如权利要求9所述的计算机可读存储介质,其中所述共享的存储器阵列包括至少一个数字数据值。
15.如权利要求9所述的计算机可读存储介质,其中所述共享的存储器阵列包括至少一个离散数据值。
16.如权利要求9所述的计算机可读存储介质,其中所述共享的存储器阵列包括至少一个诊断值。
17.一种系统,包括:
处理器;以及
存储器,其包含被配置为执行从可编程逻辑控制器(PLC)设备获得数据值的操作的程序,所述操作包括:
解析用于识别要暴露的多个PLC地址的配置文件;
初始化共享的存储器阵列,其中所述共享的存储器阵列包括多个单元,其每个用于存储从所述PLC设备获得的数据;
调用第一线程,其中所述第一线程被配置为重复地:
发送对于PLC地址之一的请求,其中所述请求根据第一通信协议来配置;以及
响应于在所述共享的存储器阵列的单元之一中的请求,存储由所述PLC设备返回的数据值;以及
调用第二线程,其中所述第二线程被配置为:
接收根据第二通信协议传送的对于在所述共享的存储器阵列中存储的数据值中的一个或多个的请求;
取出所请求的一个或多个数据值;以及
以与所述第二通信协议一致的格式返回所请求的数据值。
18.如权利要求17所述的系统,其中对于一个或多个数据值的请求通过监督控制和数据获取(SCADA)系统发送,并返回至该SCADA系统。
19.如权利要求17所述的系统,其中所述第一协议包括非智能终端协议(NITP)。
20.如权利要求17所述的系统,其中所述第一协议用于在所述PLC设备和所述第一线程之间建立的串行通信数据链路上通信。
21.如权利要求17所述的系统,其中所述第二协议包括TCP/MODBUS协议。
22.如权利要求17所述的系统,其中所述共享的存储器阵列包括至少一个数字数据值。
23.如权利要求17所述的系统,其中所述共享的存储器阵列包括至少一个离散数据值。
24.如权利要求17所述的系统,其中所述共享的存储器阵列包括至少一个诊断值。
CN200880100586A 2007-07-26 2008-07-26 可编程逻辑控制器协议转换器 Pending CN101765817A (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US95211807P 2007-07-26 2007-07-26
US60/952,118 2007-07-26
PCT/IB2008/053012 WO2009013726A1 (en) 2007-07-26 2008-07-26 Programmable logic controller protocol converter

Publications (1)

Publication Number Publication Date
CN101765817A true CN101765817A (zh) 2010-06-30

Family

ID=39968137

Family Applications (1)

Application Number Title Priority Date Filing Date
CN200880100586A Pending CN101765817A (zh) 2007-07-26 2008-07-26 可编程逻辑控制器协议转换器

Country Status (9)

Country Link
US (1) US7894460B2 (zh)
EP (2) EP2296067A1 (zh)
JP (1) JP2010534880A (zh)
KR (1) KR20100050481A (zh)
CN (1) CN101765817A (zh)
AU (1) AU2008278630B2 (zh)
CA (1) CA2694283A1 (zh)
RU (1) RU2474860C2 (zh)
WO (1) WO2009013726A1 (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101977167A (zh) * 2010-10-25 2011-02-16 深圳市兆讯达科技实业有限公司 无线传感器网络接入Modbus总线的网关通信协议转换方法
CN105700493A (zh) * 2014-12-10 2016-06-22 通用电气公司 用于存储器映射利用的系统和方法
CN107438097A (zh) * 2017-06-26 2017-12-05 北京五八信息技术有限公司 网络请求处理方法及装置
CN108254685A (zh) * 2016-12-29 2018-07-06 北京金风科创风电设备有限公司 风机的测试方法、辅助测试设备、主控装置及测试系统
CN110224910A (zh) * 2019-05-28 2019-09-10 江苏阿农物联网有限公司 基于Modbus的数据通信方法及系统
CN110914768A (zh) * 2017-06-07 2020-03-24 布鲁克斯自动化(德国)有限公司 用于使用pc程序控制plc的方法

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4383476B2 (ja) * 2007-10-05 2009-12-16 新日本製鐵株式会社 プラント制御システム及び方法
US8527653B2 (en) * 2010-11-08 2013-09-03 At&T Mobility Ii Llc GGSN front end processor (GFEP) system for SCADA inter-domain communications
US8805596B2 (en) 2010-12-28 2014-08-12 Inventus Holdings, Llc Remote wind turbine reset system and method
US8908531B2 (en) 2011-08-25 2014-12-09 At&T Mobility Ii Llc Communication gateway for facilitating communications with a supervisory control and data aquisition system
CN104272204B (zh) * 2012-03-15 2017-07-11 施耐德电器工业公司 自动化控制系统中的设备地址管理
US20160156501A1 (en) * 2014-11-28 2016-06-02 Advantech Co., Ltd. Network apparatus with inserted management mechanism, system, and method for management and supervision
DE102015121104A1 (de) * 2015-12-03 2017-06-08 Phoenix Contact Gmbh & Co. Kg Vorrichtung zur Kopplung zweier Bussysteme
US10637841B2 (en) * 2015-12-08 2020-04-28 Honeywell International Inc. Apparatus and method for using a security appliance with IEC 61131-3
CN109283875B (zh) * 2018-11-07 2023-11-21 国网辽宁省电力有限公司经济技术研究院 基于arm9架构的高性能热电联产机组运行数据采集终端

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020124011A1 (en) * 2001-03-01 2002-09-05 Baxter Robert W. Methods, systems, and computer program products for communicating with a controller using a database interface
WO2007075105A1 (en) * 2005-12-28 2007-07-05 Siemens Aktiengesellschaft Automation network, automation device and electronic component, particularly a field device for an automation network, and a method for the transmission of operating data of an automation device between an automation system and a remote computer

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6505247B1 (en) * 1998-08-21 2003-01-07 National Instruments Corporation Industrial automation system and method for efficiently transferring time-sensitive and quality-sensitive data
US7027452B2 (en) * 1999-01-25 2006-04-11 Beckwith Robert W Hub which converts SCADA protocols to the BLUJAY™ protocol
US20030147420A1 (en) * 1999-01-25 2003-08-07 Beckwith Robert W. Wireless communications hub with protocol conversion
US7013345B1 (en) * 2000-06-12 2006-03-14 Metric Systems Corporation Method and apparatus for wireless networking
JP2002091913A (ja) * 2000-09-12 2002-03-29 Techno Digital:Kk 遠隔メンテナンスシステム、並びにこれに用いられるメンテナンス装置およびサポート装置
US6950851B2 (en) * 2001-04-05 2005-09-27 Osburn Iii Douglas C System and method for communication for a supervisory control and data acquisition (SCADA) system
JP3984046B2 (ja) * 2001-12-21 2007-09-26 日清エンジニアリング株式会社 情報配信装置並びにリモートエンジニアリングシステム
US6799080B1 (en) * 2003-06-12 2004-09-28 The Boc Group, Inc. Configurable PLC and SCADA-based control system
JP2005269127A (ja) * 2004-03-18 2005-09-29 Nec Engineering Ltd パケット通信システム、プロトコル変換機及びそれらに用いるアドレス認識方法
WO2006015245A2 (en) * 2004-07-29 2006-02-09 Modius, Inc. Universal configurable device gateway
US7613783B2 (en) 2004-08-17 2009-11-03 Schneider Automation Inc. Gateway having an input/output scanner
US7609719B2 (en) * 2004-10-12 2009-10-27 Electro Industries/Gauge Tech System and method for simultaneous communication on modbus and DNP 3.0 over Ethernet for electronic power meter
RU64403U1 (ru) * 2006-10-16 2007-06-27 "Закрытое Акционерное Общество "Корпоративный институт электротехнического приборостроения "Энергомера" Контроллер

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020124011A1 (en) * 2001-03-01 2002-09-05 Baxter Robert W. Methods, systems, and computer program products for communicating with a controller using a database interface
WO2007075105A1 (en) * 2005-12-28 2007-07-05 Siemens Aktiengesellschaft Automation network, automation device and electronic component, particularly a field device for an automation network, and a method for the transmission of operating data of an automation device between an automation system and a remote computer

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101977167A (zh) * 2010-10-25 2011-02-16 深圳市兆讯达科技实业有限公司 无线传感器网络接入Modbus总线的网关通信协议转换方法
CN105700493A (zh) * 2014-12-10 2016-06-22 通用电气公司 用于存储器映射利用的系统和方法
CN108254685A (zh) * 2016-12-29 2018-07-06 北京金风科创风电设备有限公司 风机的测试方法、辅助测试设备、主控装置及测试系统
CN110914768A (zh) * 2017-06-07 2020-03-24 布鲁克斯自动化(德国)有限公司 用于使用pc程序控制plc的方法
CN110914768B (zh) * 2017-06-07 2023-06-30 布鲁克斯自动化(德国)有限公司 用于使用pc程序控制plc的方法
CN107438097A (zh) * 2017-06-26 2017-12-05 北京五八信息技术有限公司 网络请求处理方法及装置
CN107438097B (zh) * 2017-06-26 2021-09-21 北京五八信息技术有限公司 网络请求处理方法及装置
CN110224910A (zh) * 2019-05-28 2019-09-10 江苏阿农物联网有限公司 基于Modbus的数据通信方法及系统

Also Published As

Publication number Publication date
EP2174196A1 (en) 2010-04-14
CA2694283A1 (en) 2009-01-29
WO2009013726A1 (en) 2009-01-29
KR20100050481A (ko) 2010-05-13
EP2296067A1 (en) 2011-03-16
US7894460B2 (en) 2011-02-22
AU2008278630B2 (en) 2013-05-16
RU2010107048A (ru) 2011-09-10
RU2474860C2 (ru) 2013-02-10
US20090028184A1 (en) 2009-01-29
JP2010534880A (ja) 2010-11-11
AU2008278630A1 (en) 2009-01-29

Similar Documents

Publication Publication Date Title
CN101765817A (zh) 可编程逻辑控制器协议转换器
US8359112B2 (en) Method for redundant controller synchronization for bump-less failover during normal and program mismatch conditions
CN101231610A (zh) Sata硬盘的监控装置及其监控方法
US20090082880A1 (en) Wireless device for a building control system
EP3201707B1 (en) Device hierarchy building for a remote terminal unit
CN102809935A (zh) 用于告警可视化的系统和方法
CN102692985B (zh) 远程管理式计算机系统的平稳带外电源控制方法和系统
CN102809953A (zh) 用于告警捕获和传输的系统及方法
EP2638443B1 (en) Local control network processor (lcnp) emulator for multi-generation control systems
US9170579B1 (en) System, method and computer program product for monitoring and controlling industrial energy equipment
CN101923320B (zh) 用于存储来自工业控制器的数据的系统和方法
GB2477238A (en) Redundant controllers with a synchronisation control program that determines whether all of the state information has been received.
US20090224885A1 (en) Radio frequency identification reader data integration device and method thereof
CN108985402A (zh) 一种raid卡信息获取方法及相关装置
CN107850890A (zh) 基于sd卡的rtu
KR101024423B1 (ko) 지능형 전자장치
CN111524053B (zh) 空气质量预报系统的信息采集方法、装置、设备及介质
CN115473761B (zh) 基于dcs系统的can总线的通信方法、系统、设备及介质
CN114257887A (zh) 一种数据通讯方法、系统、存储介质及电子设备
CN111435233A (zh) 一种智能网关控制器及控制方法
CN110764869A (zh) 一种基于多个虚拟系统的船舶生产用能状况实时监控系统
JP2003150242A5 (zh)
CN101197076A (zh) 建立工作感测器数据记录的方法及伺服系统

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C02 Deemed withdrawal of patent application after publication (patent law 2001)
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20100630