CN113573171B - 遥控遥调方法、装置及系统 - Google Patents
遥控遥调方法、装置及系统 Download PDFInfo
- Publication number
- CN113573171B CN113573171B CN202110794739.4A CN202110794739A CN113573171B CN 113573171 B CN113573171 B CN 113573171B CN 202110794739 A CN202110794739 A CN 202110794739A CN 113573171 B CN113573171 B CN 113573171B
- Authority
- CN
- China
- Prior art keywords
- control
- key
- value
- remote
- redis
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 52
- 238000004891 communication Methods 0.000 claims description 24
- 230000001105 regulatory effect Effects 0.000 claims 2
- 238000011161 development Methods 0.000 abstract description 6
- 230000003993 interaction Effects 0.000 description 13
- 238000010586 diagram Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 5
- 230000008569 process Effects 0.000 description 4
- 230000009286 beneficial effect Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 230000000903 blocking effect Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 230000011664 signaling Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 1
- 238000007667 floating Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q9/00—Arrangements in telecontrol or telemetry systems for selectively calling a substation from a main station, in which substation desired apparatus is selected for applying a control signal thereto or for obtaining measured values therefrom
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/14—Session management
- H04L67/141—Setup of application sessions
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Selective Calling Equipment (AREA)
- Telephonic Communication Services (AREA)
Abstract
本发明提供一种遥控遥调方法、装置及系统,其中该方法应用于实时数据采集控制系统中的Redis,包括:接收前置模块订阅的控制命令主题;确定外部应用发布控制命令主题后,通知前置模块有控制命令主题发布,以使得前置模块从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;接收并存储前置模块发送的key‑value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。通过本发明提供的遥控遥调方法、装置及系统,极大地丰富了外部应用的使用方式,提高了二次开发的效率,增强了产品的易用性。
Description
技术领域
本发明涉及电力系统控制技术领域,尤其涉及一种遥控遥调方法、装置及系统。
背景技术
IEC104规约由国际电工委员会制定,为远动信息的网络传输提供通信规约依据,在电力系统实时数据采集控制系统中应用非常广泛。IEC104规约规定了四遥信息的报文传输规则,四遥包括遥信、遥测、遥控、遥调。其中,遥测和遥信由远动侧对设备层进行数据采集后,统一上传至主站侧;遥控和遥调由主站侧下发至远动侧,再由远动侧下发给设备层执行。四遥上传下发功能通常由实时数据采集控制系统的前置模块实现。
随着电力系统的发展,出现了通过多种渠道远程下发遥控遥调命令的需求。现有的前置模块通常使用C++语言编写,提供C++接口供应用使用,如果希望使用其他编程语言下发控制命令,那么针对每种编程语言都需要额外的开发工作,不能灵活的满足多语言在不同场景远程下发控制命令的需求。
发明内容
针对现有技术存在的问题,本发明提供一种遥控遥调方法、装置及系统。
第一方面,本发明提供一种遥控遥调方法,应用于实时数据采集控制系统中的Redis,所述Redis分别与所述实时数据采集控制系统中的外部应用和前置模块建立通信连接,所述方法包括:
接收所述前置模块订阅的控制命令主题;
确定所述外部应用发布所述控制命令主题后,通知所述前置模块有所述控制命令主题发布,以使得所述前置模块从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至远动侧以控制目标控制点;
接收并存储所述前置模块发送的key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储所述前置模块发送的key-value键值对,包括:
接收并存储所述前置模块在获取所述第一控制参数后发送的第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储所述前置模块在收到所述远动侧回复的选择成功的消息后发送的第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述接收并存储所述前置模块发送的key-value键值对,还包括:
接收并存储所述前置模块在获取所述第二控制参数后发送的第三key-value键值对,所述第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
接收并存储所述前置模块在收到所述远动侧回复的执行成功的消息后发送的第四key-value键值对,所述第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储所述前置模块发送的key-value键值对,包括:
接收并存储所述前置模块在获取所述第一控制参数后发送的第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储所述前置模块在收到所述远动侧回复的选择失败的消息后发送的第五key-value键值对,所述第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
第二方面,本发明还提供一种遥控遥调方法,应用于实时数据采集控制系统中的前置模块,所述前置模块分别与所述实时数据采集控制系统中的Redis和远动侧建立通信连接,所述方法包括:
向所述Redis订阅控制命令主题;
接收到所述Redis的通知确定有外部应用在所述Redis中发布所述控制命令主题,则从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至所述远动侧以控制目标控制点;
向所述Redis发送key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向所述Redis发送key-value键值对,包括:
在获取所述第一控制参数后向所述Redis发送第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到所述远动侧回复的选择成功的消息后向所述Redis发送第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述向所述Redis发送key-value键值对,还包括:
在获取所述第二控制参数后向所述Redis发送第三key-value键值对,所述第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
在收到所述远动侧回复的执行成功的消息后向所述Redis发送第四key-value键值对,所述第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向所述Redis发送key-value键值对,包括:
在获取所述第一控制参数后向所述Redis发送第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到所述远动侧回复的选择失败的消息后向所述Redis发送第五key-value键值对,所述第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
第三方面,本发明还提供一种遥控遥调装置,应用于实时数据采集控制系统中的Redis,所述Redis分别与所述实时数据采集控制系统中的外部应用和前置模块建立通信连接,所述装置包括:
接收模块,用于接收所述前置模块订阅的控制命令主题;
通知模块,用于确定所述外部应用发布所述控制命令主题后,通知所述前置模块有所述控制命令主题发布,以使得所述前置模块从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至远动侧以控制目标控制点;
存储模块,用于接收并存储所述前置模块发送的key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态。
第四方面,本发明还提供一种遥控遥调装置,应用于实时数据采集控制系统中的前置模块,所述前置模块分别与所述实时数据采集控制系统中的Redis和远动侧建立通信连接,所述装置包括:
订阅模块,用于向所述Redis订阅控制命令主题;
获取模块,用于接收到所述Redis的通知确定有外部应用在所述Redis中发布所述控制命令主题,则从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至所述远动侧以控制目标控制点;
发送模块,用于向所述Redis发送key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态。
第五方面,本发明还提供一种实时数据采集控制系统,包括:
外部应用、Redis、前置模块和远动侧;
所述外部应用与所述Redis建立通信连接,用于在所述Redis中发布控制命令主题,所述控制命令主题附带控制参数;
所述Redis与所述前置模块建立通信连接,用于执行如上所述第一方面所述的遥控遥调方法的步骤;
所述前置模块与所述远动侧建立通信连接,用于执行如上所述第二方面所述的遥控遥调方法的步骤。
本发明提供的遥控遥调方法、装置及系统,通过使用Redis作为中间件,利用Redis的基础功能和发布订阅特性,形成了前置模块接收遥控遥调远程命令的一套通用接口,所有Redis支持的客户端语言都可访问这套接口,极大地丰富了外部应用的使用方式,提高了二次开发的效率,增强了产品的易用性。
附图说明
为了更清楚地说明本发明或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作一简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明提供的遥控遥调方法的流程示意图之一;
图2是本发明提供的实时数据采集控制系统的框架图;
图3是本发明提供的遥控命令远程下发的流程示意图之一;
图4是本发明提供的遥控命令远程下发的流程示意图之二;
图5是本发明提供的遥控遥调方法的流程示意图之二;
图6是本发明提供的遥控遥调装置的结构示意图之一;
图7是本发明提供的遥控遥调装置的结构示意图之二。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合本发明中的附图,对本发明中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
前置模块是电力系统实时数据采集控制系统中最重要且复杂的模块之一,前置模块的运行需要消耗较多的CPU(Central Processing Unit,中央处理器)资源、内存资源和网络资源,通常使用C++语言编写,在服务器后台运行。
人机交互界面也是实时数据采集控制系统的重要组成模块之一,通过人机交互界面,用户可以直观的监视实时数据的变化,并下发遥控遥调命令。PC(Personal Computer,个人计算机)端的人机交互界面分为两种模式:C/S模式和B/S模式。C/S模式即Client-Server模式,实现方式通常是一个独立运行操作的应用界面;B/S模式即Browser-Server模式,实现方式是通过网页监视和操作。这两种不同的人机交互界面模式与前置模块的数据交互方式有所不同。
C/S模式下的应用界面通常使用C++语言开发,可直接调用前置模块的接口进行数据监视和控制,而B/S模式通常使用Java语言开发,与前置模块存在跨语言数据交互问题,需要前置模块为其提供单独的访问接口,例如目前比较常用的Http(Hyper Text TransferProtocol,超文本传输协议)接口或JNA(Java Native Access,Java本地访问)方式。近年来,Python语言兴起,与传统C++模式下的后台服务进程数据交互也存在类似的问题。
另外,现有流程控制命令的下发和执行都耦合在前置模块内部,一旦出现问题,不方便定位原因。并且C++接口的调用通常为阻塞式,可能使软件处于无响应状态的时间过长,影响用户体验。
针对上述问题,本发明提供一种解决方案,引入Redis(Remote DictionaryServer,远程字典服务器)作为中间件,解决实时数据采集控制系统中前置模块与其他需要远程下发控制命令的模块之间的数据交互问题,并定义了控制命令下发的参数及整体交互流程。由于Redis支持丰富多样的客户端语言,用户可以根据实际场景的需求来选择方便自己使用的编程语言,按照接口要求发布Redis控制主题,并查询命令状态决定下一步操作流程即可,非常灵活。前置模块提供的不再是针对每种编程语言的单一接口,而是一套基于Redis的通用接口,达到了前置模块和外部应用整体解耦的目的,双方都只需要和Redis产生交互,不必关注对方的实现逻辑,交互流程也由阻塞式转变为非阻塞,更加灵活,用户体验更好,更能适应当前的业务需求。
图1为本发明提供的遥控遥调方法的流程示意图之一,该方法应用于实时数据采集控制系统中的Redis,Redis分别与实时数据采集控制系统中的外部应用和前置模块建立通信连接,如图1所示,该方法包括如下步骤:
步骤100、接收前置模块订阅的控制命令主题;
具体地,Redis是一个使用C语言编写的、开源的、支持网络交互的、可基于内存也可持久化的、高性能的键值对(key-value)数据库。
实时数据采集控制系统中的外部应用即可以远程下发控制命令的模块,用户可通过外部应用的人机交互界面直观地监视实时数据的变化,并下发遥控遥调命令。不同的外部应用可能根据实际应用场景的不同选择不同的语言进行编写,例如这些语言包括但不限于:Java、C++、Python等等。
实时数据采集控制系统中的前置模块与远动侧连接,可以在接收到外部应用下发的控制参数后,将控制命令通过IEC104通道下发至远动侧以控制目标遥控点或遥调点。前置模块通常使用C++语言编写。
本发明实施例中,为了解决实时数据采集控制系统中前置模块与外部应用之间因为编写语言的差异导致的数据交互问题,在电力系统的实时数据采集控制系统中引入Redis,分别与实时数据采集控制系统中的外部应用和前置模块建立通信连接。
图2为本发明提供的实时数据采集控制系统的框架图,如图2所示,基于Redis的发布订阅特性和基础功能,不仅可以在Redis的发布订阅区通过遥控遥调命令主题的订阅和发布实现外部应用和前置模块之间针对遥控遥调控制参数的下发和获取,还可以在Redis的命令状态区通过key-value值实现外部应用和前置模块针对遥控遥调命令状态的查询和管理,从而外部应用和前置模块都只需要和Redis产生交互,而不必关注对方的实现逻辑,前置模块不再需要针对每种编程语言都提供单一接口,而只需要一套基于Redis的通用接口即可。
具体地,外部应用和前置模块中均安装Redis服务并启动后,前置模块可以首先向Redis订阅一个主题,该主题用于外部应用和前置模块之间针对遥控遥调控制参数的下发和获取,可称为控制命令主题。Redis接收到前置模块订阅的控制命令主题(例如主题名称可以是“ykyt”)后,即开始持续监测是否有外部应用发布该控制命令主题。
步骤101、确定外部应用发布控制命令主题后,通知前置模块有控制命令主题发布,以使得前置模块从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;
具体地,外部应用需要远程下发遥控遥调命令时,可以通过IP(InternetProtocol,网际互连协议)地址和端口号确定与前置模块订阅控制命令主题相同的Redis服务,并直接访问,在Redis中发布前置模块已订阅的控制命令主题,控制命令主题同时附带控制参数。控制参数可以使用json格式描述,例如可以包含如下信息:
Redis确定有外部应用发布前置模块订阅的控制命令主题后,可以通知前置模块,从而前置模块收到Redis的通知后及时从Redis中获取控制命令主题附带的控制参数,并基于控制参数,将遥控或遥调的相关控制命令下发至远动侧以控制目标控制点,目标控制点即控制参数中所包含的遥控点ID(Identifier,标识)或遥调点ID对应的遥控点或遥调点。
步骤102、接收并存储前置模块发送的key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。
具体地,为了使外部应用能够及时获得控制命令的执行状态以执行下一步操作,前置模块可以向Redis发送key-value键值对,其中,key用于标识目标控制点在Redis中的唯一索引,并通过不同的value值来标识控制命令的执行状态。
例如,key可以采用如下命名规则:
控制类型 | key命名规则 | 举例 |
遥控 | yk_遥控点ID | yk_1 |
遥调 | yt_遥调点ID | yt_1 |
value值的含义可以采用如下枚举类型说明:
value值 | 含义 |
1 | 选择中 |
2 | 选择成功 |
3 | 选择失败 |
4 | 执行中 |
5 | 执行成功 |
6 | 执行失败 |
7 | 超时 |
Redis可以在接收到前置模块根据控制命令的执行状态发送的key-value键值对后,存储key-value键值对,以供外部应用查询获得控制命令的执行状态,来决定下一步的操作。
可选地,为了避免过多的key占用Redis空间,同时也为外部应用预留足够的访问时间,本发明实施例中,Redis可以为key设置一定时长的有效期,例如30分钟,超出有效期后Redis将该key删除。
本发明实施例提供的遥控遥调方法,通过使用Redis作为中间件,利用Redis的基础功能和发布订阅特性,形成了前置模块接收遥控遥调远程命令的一套通用接口,所有Redis支持的客户端语言都可访问这套接口,极大地丰富了外部应用的使用方式,提高了二次开发的效率,增强了产品的易用性。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储前置模块发送的key-value键值对,包括:
接收并存储前置模块在获取第一控制参数后发送的第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储前置模块在收到远动侧回复的选择成功的消息后发送的第二key-value键值对,第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
具体地,本发明实施例中,若外部应用发布控制命令主题时附带的控制参数包括用于遥控选择或遥调选择的第一控制参数,则前置模块获取到该第一控制参数后,可以根据该第一控制参数将用于遥控选择或遥调选择的第一控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第一key-value键值对,第一key-value键值对中的key用于标识该目标控制点在Redis中的唯一索引,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中,例如可以将该第一value值设置为1来表示控制命令的执行状态为选择中。
之后,若前置模块收到远动侧回复的选择成功的消息,则前置模块可以向Redis发送第二key-value键值对,以向Redis中写入第二value值来更新上述key对应的value值,该第二value值用于标识控制命令的执行状态为选择成功,例如可以将该第二value值设置为2来表示控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述接收并存储前置模块发送的key-value键值对,还包括:
接收并存储前置模块在获取第二控制参数后发送的第三key-value键值对,第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
接收并存储前置模块在收到远动侧回复的执行成功的消息后发送的第四key-value键值对,第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
具体地,本发明实施例中,外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为选择成功的第二value值后,外部应用可以继续发布控制命令主题,并在控制命令主题中附带用于遥控执行或遥调执行的第二控制参数,前置模块获取到该第二控制参数后,可以根据该第二控制参数将用于遥控执行或遥调执行的第二控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第三key-value键值对,以向Redis中写入第三value值来更新上述key对应的value值,该第三value值用于标识控制命令的执行状态为执行中,例如可以将该第三value值设置为4来表示控制命令的执行状态为执行中。
之后,若前置模块收到远动侧回复的执行成功的消息,则前置模块可以向Redis发送第四key-value键值对,以向Redis中写入第四value值来更新上述key对应的value值,该第四value值用于标识控制命令的执行状态为执行成功,例如可以将该第四value值设置为5来表示控制命令的执行状态为执行成功。
外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为执行成功的第四value值后,确定遥控或遥调命令执行成功,遥控或遥调流程结束。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储前置模块发送的key-value键值对,包括:
接收并存储前置模块在获取第一控制参数后发送的第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储前置模块在收到远动侧回复的选择失败的消息后发送的第五key-value键值对,第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
具体地,本发明实施例中,若外部应用发布控制命令主题时附带的控制参数包括用于遥控选择或遥调选择的第一控制参数,则前置模块获取到该第一控制参数后,可以根据该第一控制参数将用于遥控选择或遥调选择的第一控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第一key-value键值对,第一key-value键值对中的key用于标识该目标控制点在Redis中的唯一索引,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中,例如可以将该第一value值设置为1来表示控制命令的执行状态为选择中。
之后,若前置模块收到远动侧回复的选择失败的消息,则前置模块可以向Redis发送第五key-value键值对,以向Redis中写入第五value值来更新上述key对应的value值,该第五value值用于标识控制命令的执行状态为选择失败,例如可以将该第五value值设置为3来表示控制命令的执行状态为选择失败。
外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为选择失败的第五value值后,则外部应用不再继续发布控制命令主题,遥控或遥调流程结束。
下面通过具体实施例来对本发明提供的遥控遥调方法进行举例说明,由于遥控和遥调命令远程下发的整体流程完全一致,区别仅在于下发的目标值类型不同:遥控命令下发值为整型,遥调命令下发值为浮点型,因此以下实施例仅以遥控命令远程下发为例进行说明。
图3为本发明提供的遥控命令远程下发的流程示意图之一,如图3所示,以web侧使用Java语言下发远程遥控命令,遥控点ID为1,目标为控合,命令执行成功为例,整个流程包括如下步骤:
步骤300、前置模块订阅“ykyt”主题;
具体地,外部应用和前置模块均安装Redis服务并启动后,部署实时数据采集控制系统,启动前置服务,前置模块向Redis订阅控制命令主题“ykyt”,开启循环持续监测是否有相关主题发布。
步骤301、外部应用带参发布“ykyt”主题(遥控选择);
具体地,web侧使用Java语言访问相同的Redis服务,发布“ykyt”主题,同时附带控制参数。控制参数如下:
同时web侧开始循环监测key:“yk_1”的值以获得命令执行状态。
步骤302、Redis通知前置模块有主题发布;
具体地,外部应用带参发布“ykyt”主题后,Redis即通知前置模块有“ykyt”主题发布。
步骤303、前置模块新建命令状态为选择中;
具体地,前置模块收到通知有“ykyt”主题发布,即可从Redis中得到控制参数,基于该控制参数,前置模块首先向Redis写入一条字符串类型的信息,用于标识当前命令的状态,key=“yk_1”,value=“1”,此时web侧可以使用Java语言访问“yk_1”,得到命令状态。
步骤304、前置模块下发遥控选择报文请求;
具体地,前置模块得到控制参数后,根据遥控点ID定位到所属RTU(RemoteTerminal Unit,远动终端)及点号(即距遥控首地址的偏移量),通过IEC104通道下发遥控选择命令至远动侧。
上述步骤303和步骤304不分先后,可以并行执行。
步骤305、远动侧回复遥控选择请求成功;
具体地,远动侧若选择遥控点成功,则向前置模块回复遥控选择请求成功。
步骤306、前置模块更新命令状态为选择成功;
具体地,前置模块收到选择成功的报文,将“yk_1”的value重置为“2”。
步骤307、外部应用带参发布“ykyt”主题(遥控执行);
具体地,web侧监测到遥控选择命令成功,继续发布“ykyt”主题,同时附带控制参数。控制参数如下:
步骤308、Redis通知前置模块有主题发布;
具体地,外部应用带参发布“ykyt”主题后,Redis即通知前置模块有“ykyt”主题发布。
步骤309、前置模块更新命令状态为执行中;
具体地,前置模块收到通知有“ykyt”主题发布,即可从Redis中得到控制参数,知晓需要执行控制命令,同时确认命令状态为选择成功,则前置模块将“yk_1”的value重置为“4”。
步骤310、前置模块下发遥控执行报文请求;
具体地,前置模块得到控制参数后,知晓需要执行控制命令,同时确认命令状态为选择成功,则根据遥控点ID定位到所属RTU及点号,通过IEC104通道下发遥控执行命令至远动侧。
上述步骤309和步骤310不分先后,可以并行执行。
步骤311、远动侧回复遥控执行请求成功;
具体地,远动侧若遥控执行成功,则向前置模块回复遥控执行请求成功。
步骤312、前置模块更新命令状态为执行成功;
具体地,前置模块收到执行成功的报文,将“yk_1”的value重置为“5”。
步骤313、外部应用读取状态,流程结束;
具体地,web侧监测到命令执行成功,流程结束。
图4为本发明提供的遥控命令远程下发的流程示意图之二,如图4所示,以web侧使用Java语言下发远程遥控命令,选择失败为例,整个流程包括如下步骤:
步骤400、前置模块订阅“ykyt”主题;
具体地,外部应用和前置模块均安装Redis服务并启动后,部署实时数据采集控制系统,启动前置服务,前置模块向Redis订阅控制命令主题“ykyt”,开启循环持续监测是否有相关主题发布。
步骤401、外部应用带参发布“ykyt”主题(遥控选择);
具体地,web侧使用Java语言访问相同的Redis服务,发布“ykyt”主题,同时附带控制参数。控制参数如下:
同时web侧开始循环监测key:“yk_1”的值以获得命令执行状态。
步骤402、Redis通知前置模块有主题发布;
具体地,外部应用带参发布“ykyt”主题后,Redis即通知前置模块有“ykyt”主题发布。
步骤403、前置模块新建命令状态为选择中;
具体地,前置模块收到通知有“ykyt”主题发布,即可从Redis中得到控制参数,基于该控制参数,前置模块首先向Redis写入一条字符串类型的信息,用于标识当前命令的状态,key=“yk_1”,value=“1”,此时web侧可以使用Java语言访问“yk_1”,得到命令状态。
步骤404、前置模块下发遥控选择报文请求;
具体地,前置模块得到控制参数后,根据遥控点ID定位到所属RTU及点号(即距遥控首地址的偏移量),通过IEC104通道下发遥控选择命令至远动侧。
上述步骤403和步骤404不分先后,可以并行执行。
步骤405、远动侧回复遥控选择请求失败;
具体地,远动侧若选择遥控点失败,则向前置模块回复遥控选择请求失败,目标不可控。
步骤406、前置模块更新命令状态为选择失败;
具体地,前置模块收到选择失败的报文,将“yk_1”的value重置为“3”。
步骤407、外部应用读取状态,流程结束;
具体地,web侧监测到命令选择失败,流程结束。
图5为本发明提供的遥控遥调方法的流程示意图之二,该方法应用于实时数据采集控制系统中的前置模块,前置模块分别与实时数据采集控制系统中的Redis和远动侧建立通信连接,如图5所示,该方法包括如下步骤:
步骤500、向Redis订阅控制命令主题;
具体地,本发明实施例中,为了解决实时数据采集控制系统中前置模块与外部应用之间因为编写语言的差异导致的数据交互问题,在电力系统的实时数据采集控制系统中引入Redis,分别与实时数据采集控制系统中的外部应用和前置模块建立通信连接,从而外部应用和前置模块都只需要和Redis产生交互,而不必关注对方的实现逻辑,前置模块不再需要针对每种编程语言都提供单一接口,而只需要一套基于Redis的通用接口即可。
具体地,外部应用和前置模块中均安装Redis服务并启动后,前置模块可以首先向Redis订阅一个主题,该主题用于外部应用和前置模块之间针对遥控遥调控制参数的下发和获取,可称为控制命令主题。
步骤501、接收到Redis的通知确定有外部应用在Redis中发布控制命令主题,则从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;
具体地,外部应用需要远程下发遥控遥调命令时,可以通过IP地址和端口号确定与前置模块订阅控制命令主题相同的Redis服务,并直接访问,在Redis中发布前置模块已订阅的控制命令主题,控制命令主题同时附带控制参数。
Redis确定有外部应用发布前置模块订阅的控制命令主题后,可以通知前置模块,从而前置模块接收到Redis的通知确定有外部应用在Redis中发布控制命令主题,则从Redis中获取控制命令主题附带的控制参数,并基于控制参数,将遥控或遥调的相关控制命令下发至远动侧以控制目标控制点,目标控制点即控制参数中所包含的遥控点ID或遥调点ID对应的遥控点或遥调点。
步骤502、向Redis发送key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。
具体地,为了使外部应用能够及时获得控制命令的执行状态以执行下一步操作,前置模块可以向Redis发送key-value键值对,其中,key用于标识目标控制点在Redis中的唯一索引,并通过不同的value值来标识控制命令的执行状态。
本发明实施例提供的遥控遥调方法,通过使用Redis作为中间件,利用Redis的基础功能和发布订阅特性,形成了前置模块接收遥控遥调远程命令的一套通用接口,所有Redis支持的客户端语言都可访问这套接口,极大地丰富了外部应用的使用方式,提高了二次开发的效率,增强了产品的易用性。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向Redis发送key-value键值对,包括:
在获取第一控制参数后向Redis发送第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到远动侧回复的选择成功的消息后向Redis发送第二key-value键值对,第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
具体地,本发明实施例中,若外部应用发布控制命令主题时附带的控制参数包括用于遥控选择或遥调选择的第一控制参数,则前置模块获取到该第一控制参数后,可以根据该第一控制参数将用于遥控选择或遥调选择的第一控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第一key-value键值对,第一key-value键值对中的key用于标识该目标控制点在Redis中的唯一索引,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中。
之后,若前置模块收到远动侧回复的选择成功的消息,则前置模块可以向Redis发送第二key-value键值对,以向Redis中写入第二value值来更新上述key对应的value值,该第二value值用于标识控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述向Redis发送key-value键值对,还包括:
在获取第二控制参数后向Redis发送第三key-value键值对,第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
在收到远动侧回复的执行成功的消息后向Redis发送第四key-value键值对,第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
具体地,本发明实施例中,外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为选择成功的第二value值后,外部应用可以继续发布控制命令主题,并在控制命令主题中附带用于遥控执行或遥调执行的第二控制参数,前置模块获取到该第二控制参数后,可以根据该第二控制参数将用于遥控执行或遥调执行的第二控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第三key-value键值对,以向Redis中写入第三value值来更新上述key对应的value值,该第三value值用于标识控制命令的执行状态为执行中。
之后,若前置模块收到远动侧回复的执行成功的消息,则前置模块可以向Redis发送第四key-value键值对,以向Redis中写入第四value值来更新上述key对应的value值,该第四value值用于标识控制命令的执行状态为执行成功。
外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为执行成功的第四value值后,确定遥控或遥调命令执行成功,遥控或遥调流程结束。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向Redis发送key-value键值对,包括:
在获取第一控制参数后向Redis发送第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到远动侧回复的选择失败的消息后向Redis发送第五key-value键值对,第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
具体地,本发明实施例中,若外部应用发布控制命令主题时附带的控制参数包括用于遥控选择或遥调选择的第一控制参数,则前置模块获取到该第一控制参数后,可以根据该第一控制参数将用于遥控选择或遥调选择的第一控制命令下发至相应的远动侧以控制相应的目标控制点,并向Redis发送第一key-value键值对,第一key-value键值对中的key用于标识该目标控制点在Redis中的唯一索引,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中。
之后,若前置模块收到远动侧回复的选择失败的消息,则前置模块可以向Redis发送第五key-value键值对,以向Redis中写入第五value值来更新上述key对应的value值,该第五value值用于标识控制命令的执行状态为选择失败。
外部应用通过Redis查询到上述key的value值更新为标识控制命令的执行状态为选择失败的第五value值后,则外部应用不再继续发布控制命令主题,遥控或遥调流程结束。
下面对本发明提供的遥控遥调装置进行描述,下文描述的遥控遥调装置与上文描述的遥控遥调方法可相互对应参照。
图6为本发明提供的遥控遥调装置的结构示意图之一,该装置应用于实时数据采集控制系统中的Redis,Redis分别与实时数据采集控制系统中的外部应用和前置模块建立通信连接,如图6所示,该装置包括:
接收模块600,用于接收前置模块订阅的控制命令主题;
通知模块610,用于确定外部应用发布控制命令主题后,通知前置模块有控制命令主题发布,以使得前置模块从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;
存储模块620,用于接收并存储前置模块发送的key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述存储模块620,用于:接收并存储前置模块在获取第一控制参数后发送的第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;接收并存储前置模块在收到远动侧回复的选择成功的消息后发送的第二key-value键值对,第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述存储模块620,还用于:接收并存储前置模块在获取第二控制参数后发送的第三key-value键值对,第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;接收并存储前置模块在收到远动侧回复的执行成功的消息后发送的第四key-value键值对,第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述存储模块620,用于:接收并存储前置模块在获取第一控制参数后发送的第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;接收并存储前置模块在收到远动侧回复的选择失败的消息后发送的第五key-value键值对,第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
图7为本发明提供的遥控遥调装置的结构示意图之二,该装置应用于实时数据采集控制系统中的前置模块,前置模块分别与实时数据采集控制系统中的Redis和远动侧建立通信连接,如图7所示,该装置包括:
订阅模块700,用于向Redis订阅控制命令主题;
获取模块710,用于接收到Redis的通知确定有外部应用在Redis中发布控制命令主题,则从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;
发送模块720,用于向Redis发送key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述发送模块720,用于:在获取第一控制参数后向Redis发送第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;在收到远动侧回复的选择成功的消息后向Redis发送第二key-value键值对,第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
可选地,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述发送模块720,还用于:在获取第二控制参数后向Redis发送第三key-value键值对,第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;在收到远动侧回复的执行成功的消息后向Redis发送第四key-value键值对,第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
可选地,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述发送模块720,用于:在获取第一控制参数后向Redis发送第一key-value键值对,第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;在收到远动侧回复的选择失败的消息后向Redis发送第五key-value键值对,第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
在此需要说明的是,本发明提供的上述装置,能够实现上述方法实施例所实现的所有方法步骤,且能够达到相同的技术效果,在此不再对本实施例中与方法实施例相同的部分及有益效果进行具体赘述。
另一方面,本发明还提供一种实时数据采集控制系统,包括:
外部应用、Redis、前置模块和远动侧;
外部应用与Redis建立通信连接,用于在Redis中发布控制命令主题,控制命令主题附带控制参数;
Redis与前置模块建立通信连接,用于执行上述各实施例提供的任一所述遥控遥调方法的步骤,例如:接收前置模块订阅的控制命令主题;确定外部应用发布控制命令主题后,通知前置模块有控制命令主题发布,以使得前置模块从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;接收并存储前置模块发送的key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态;
前置模块与远动侧建立通信连接,用于上述各实施例提供的任一所述遥控遥调方法的步骤,例如:向Redis订阅控制命令主题;接收到Redis的通知确定有外部应用在Redis中发布控制命令主题,则从Redis中获取控制命令主题附带的控制参数,并基于控制参数,发送控制命令至远动侧以控制目标控制点;向Redis发送key-value键值对;其中,key用于标识目标控制点在Redis中的唯一索引,value的值用于标识控制命令的执行状态。
在此需要说明的是,本发明提供的上述系统,能够实现上述方法实施例所实现的所有方法步骤,且能够达到相同的技术效果,在此不再对本实施例中与方法实施例相同的部分及有益效果进行具体赘述。
以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性的劳动的情况下,即可以理解并实施。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
Claims (9)
1.一种遥控遥调方法,其特征在于,应用于实时数据采集控制系统中的Redis,所述Redis分别与所述实时数据采集控制系统中的外部应用和前置模块建立通信连接,所述方法包括:
接收所述前置模块订阅的控制命令主题;
确定所述外部应用发布所述控制命令主题后,通知所述前置模块有所述控制命令主题发布,以使得所述前置模块从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至远动侧以控制目标控制点;
接收并存储所述前置模块发送的key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态;
所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储所述前置模块发送的key-value键值对,包括:
接收并存储所述前置模块在获取所述第一控制参数后发送的第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储所述前置模块在收到所述远动侧回复的选择成功的消息后发送的第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
2.根据权利要求1所述的遥控遥调方法,其特征在于,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述接收并存储所述前置模块发送的key-value键值对,还包括:
接收并存储所述前置模块在获取所述第二控制参数后发送的第三key-value键值对,所述第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
接收并存储所述前置模块在收到所述远动侧回复的执行成功的消息后发送的第四key-value键值对,所述第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
3.根据权利要求1所述的遥控遥调方法,其特征在于,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储所述前置模块发送的key-value键值对,包括:
接收并存储所述前置模块在获取所述第一控制参数后发送的第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储所述前置模块在收到所述远动侧回复的选择失败的消息后发送的第五key-value键值对,所述第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
4.一种遥控遥调方法,其特征在于,应用于实时数据采集控制系统中的前置模块,所述前置模块分别与所述实时数据采集控制系统中的Redis和远动侧建立通信连接,所述方法包括:
向所述Redis订阅控制命令主题;
接收到所述Redis的通知确定有外部应用在所述Redis中发布所述控制命令主题,则从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至所述远动侧以控制目标控制点;
向所述Redis发送key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态;
所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向所述Redis发送key-value键值对,包括:
在获取所述第一控制参数后向所述Redis发送第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到所述远动侧回复的选择成功的消息后向所述Redis发送第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
5.根据权利要求4所述的遥控遥调方法,其特征在于,所述控制参数还包括用于遥控执行或遥调执行的第二控制参数,所述控制命令还包括用于遥控执行或遥调执行的第二控制命令;
所述向所述Redis发送key-value键值对,还包括:
在获取所述第二控制参数后向所述Redis发送第三key-value键值对,所述第三key-value键值对中的第三value值用于标识控制命令的执行状态为执行中;
在收到所述远动侧回复的执行成功的消息后向所述Redis发送第四key-value键值对,所述第四key-value键值对中的第四value值用于标识控制命令的执行状态为执行成功。
6.根据权利要求4所述的遥控遥调方法,其特征在于,所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向所述Redis发送key-value键值对,包括:
在获取所述第一控制参数后向所述Redis发送第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到所述远动侧回复的选择失败的消息后向所述Redis发送第五key-value键值对,所述第五key-value键值对中的第五value值用于标识控制命令的执行状态为选择失败。
7.一种遥控遥调装置,其特征在于,应用于实时数据采集控制系统中的Redis,所述Redis分别与所述实时数据采集控制系统中的外部应用和前置模块建立通信连接,所述装置包括:
接收模块,用于接收所述前置模块订阅的控制命令主题;
通知模块,用于确定所述外部应用发布所述控制命令主题后,通知所述前置模块有所述控制命令主题发布,以使得所述前置模块从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至远动侧以控制目标控制点;
存储模块,用于接收并存储所述前置模块发送的key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态;
所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述接收并存储所述前置模块发送的key-value键值对,包括:
接收并存储所述前置模块在获取所述第一控制参数后发送的第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
接收并存储所述前置模块在收到所述远动侧回复的选择成功的消息后发送的第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
8.一种遥控遥调装置,其特征在于,应用于实时数据采集控制系统中的前置模块,所述前置模块分别与所述实时数据采集控制系统中的Redis和远动侧建立通信连接,所述装置包括:
订阅模块,用于向所述Redis订阅控制命令主题;
获取模块,用于接收到所述Redis的通知确定有外部应用在所述Redis中发布所述控制命令主题,则从所述Redis中获取所述控制命令主题附带的控制参数,并基于所述控制参数,发送控制命令至所述远动侧以控制目标控制点;
发送模块,用于向所述Redis发送key-value键值对;其中,所述key用于标识所述目标控制点在所述Redis中的唯一索引,所述value的值用于标识所述控制命令的执行状态;
所述控制参数包括用于遥控选择或遥调选择的第一控制参数,所述控制命令包括用于遥控选择或遥调选择的第一控制命令;
所述向所述Redis发送key-value键值对,包括:
在获取所述第一控制参数后向所述Redis发送第一key-value键值对,所述第一key-value键值对中的第一value值用于标识控制命令的执行状态为选择中;
在收到所述远动侧回复的选择成功的消息后向所述Redis发送第二key-value键值对,所述第二key-value键值对中的第二value值用于标识控制命令的执行状态为选择成功。
9.一种实时数据采集控制系统,其特征在于,包括:
外部应用、Redis、前置模块和远动侧;
所述外部应用与所述Redis建立通信连接,用于在所述Redis中发布控制命令主题,所述控制命令主题附带控制参数;
所述Redis与所述前置模块建立通信连接,用于执行如权利要求1至3任一项所述遥控遥调方法的步骤;
所述前置模块与所述远动侧建立通信连接,用于执行如权利要求4至6任一项所述遥控遥调方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110794739.4A CN113573171B (zh) | 2021-07-14 | 2021-07-14 | 遥控遥调方法、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110794739.4A CN113573171B (zh) | 2021-07-14 | 2021-07-14 | 遥控遥调方法、装置及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113573171A CN113573171A (zh) | 2021-10-29 |
CN113573171B true CN113573171B (zh) | 2024-05-31 |
Family
ID=78164777
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110794739.4A Active CN113573171B (zh) | 2021-07-14 | 2021-07-14 | 遥控遥调方法、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113573171B (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107247797A (zh) * | 2017-06-26 | 2017-10-13 | 国电南瑞科技股份有限公司 | 基于Redis的电力调度自动化系统中时标量测数据存储系统和方法 |
CN107995051A (zh) * | 2017-12-29 | 2018-05-04 | 国网安徽省电力有限公司 | 智能变电站二次设备可视化运维模块信息交互系统和方法 |
CN109739919A (zh) * | 2019-01-04 | 2019-05-10 | 广东电网有限责任公司 | 一种用于电力系统的前置机和采集系统 |
CN110839064A (zh) * | 2019-10-24 | 2020-02-25 | 苏宁云计算有限公司 | 一种分布式系统执行脚本的方法及装置 |
CN111586090A (zh) * | 2020-03-25 | 2020-08-25 | 杭州传化智能制造科技有限公司 | 工业数据采集的方法、系统、计算机设备和可读存储介质 |
CN111835786A (zh) * | 2020-07-23 | 2020-10-27 | 杨承 | 一种对多规约设备数据采集、设备控制的系统及实现方法 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2014113509A2 (en) * | 2013-01-15 | 2014-07-24 | Muzzley | Appliance control system and method |
CA3054798C (en) * | 2017-02-28 | 2024-04-30 | Lutron Technology Company Llc | Communicating with and controlling load control systems |
-
2021
- 2021-07-14 CN CN202110794739.4A patent/CN113573171B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107247797A (zh) * | 2017-06-26 | 2017-10-13 | 国电南瑞科技股份有限公司 | 基于Redis的电力调度自动化系统中时标量测数据存储系统和方法 |
CN107995051A (zh) * | 2017-12-29 | 2018-05-04 | 国网安徽省电力有限公司 | 智能变电站二次设备可视化运维模块信息交互系统和方法 |
CN109739919A (zh) * | 2019-01-04 | 2019-05-10 | 广东电网有限责任公司 | 一种用于电力系统的前置机和采集系统 |
CN110839064A (zh) * | 2019-10-24 | 2020-02-25 | 苏宁云计算有限公司 | 一种分布式系统执行脚本的方法及装置 |
CN111586090A (zh) * | 2020-03-25 | 2020-08-25 | 杭州传化智能制造科技有限公司 | 工业数据采集的方法、系统、计算机设备和可读存储介质 |
CN111835786A (zh) * | 2020-07-23 | 2020-10-27 | 杨承 | 一种对多规约设备数据采集、设备控制的系统及实现方法 |
Non-Patent Citations (2)
Title |
---|
Proposed design and modeling of smart energy dashboard system by implementing IoT(Internet of Things)based on mobile devices;Syaiful Ahdan;《IEEEXplore》;全文 * |
工控系统Web实时通信的设计与实现;王寿福;;廊坊师范学院学报(自然科学版)(第06期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN113573171A (zh) | 2021-10-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106453288B (zh) | 一种支持异步模式的分布式微服务框架系统及其实现方法 | |
CN110266810B (zh) | 基于mqtt协议的消息接收方法、设备及存储介质 | |
CN108768826A (zh) | 基于MQTT和Kafka高并发场景下的消息路由方法 | |
CN111600936B (zh) | 一种适用于泛在电力物联网边缘终端的基于多容器的非对称处理系统 | |
WO1994020917A1 (en) | Remote limit-setting information distribution system | |
CN114328618A (zh) | 一种缓存数据同步方法、装置、设备及存储介质 | |
CN101521606B (zh) | 日志信息处理方法、日志服务器与通信系统 | |
CN112256246A (zh) | 一种用于电力系统中支持跨语言调用的微服务集成架构 | |
EP2521307A1 (en) | Device management method, system and device | |
CN112751937A (zh) | 分布式边缘智能蓝牙Mesh网关系统及实现方法 | |
CN109947081B (zh) | 网联车辆控制方法及装置 | |
CN113867958A (zh) | 一种任务角标推送的方法、装置、设备及可读介质 | |
CN113573171B (zh) | 遥控遥调方法、装置及系统 | |
CN104270432B (zh) | 基于钻井行业实时数据服务系统及数据交互方法 | |
CN113630366A (zh) | 一种物联网设备接入方法及系统 | |
CN112995723B (zh) | 一种epg数据管理方法及epg服务器 | |
CN102955801A (zh) | 基于分布式数据库系统的数据控制方法及系统 | |
US11758017B2 (en) | Data acquisition method, service provider, service consumer and network functional entity | |
CN115378989B (zh) | 基于唤醒通道的mqtt主题订阅系统、方法、终端及介质 | |
CN104052723A (zh) | 信息处理方法和服务器 | |
CN114025005B (zh) | 一种数据通讯方法、系统、电子设备及存储介质 | |
CN113297148B (zh) | 业务日志数据的采集方法、装置、设备及可读存储介质 | |
CN113965620A (zh) | 一种基于mqtt和redis的消息推送系统 | |
CN114817317A (zh) | 一种新能源发电监控系统 | |
CN112235184A (zh) | 一种基于事件驱动的信息推送方法、装置及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |