CN114090302A - 一种获取电梯实时数据的方法和装置 - Google Patents
一种获取电梯实时数据的方法和装置 Download PDFInfo
- Publication number
- CN114090302A CN114090302A CN202111437178.9A CN202111437178A CN114090302A CN 114090302 A CN114090302 A CN 114090302A CN 202111437178 A CN202111437178 A CN 202111437178A CN 114090302 A CN114090302 A CN 114090302A
- Authority
- CN
- China
- Prior art keywords
- elevator
- data
- service
- state data
- client
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 28
- 238000010586 diagram Methods 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5083—Techniques for rebalancing the load in a distributed system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/5013—Request control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/5017—Task decomposition
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Indicating And Signalling Devices For Elevators (AREA)
Abstract
本发明涉及一种获取电梯实时数据的方法和装置,其中该方法包括:通过读取状态服务持续从电梯获取实时的电梯状态数据;通过所述读取状态服务将所述电梯状态数据发送到kafka队列;若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。本方案中,将读取状态服务与提供数据服务分开实现,不仅解决功能实现的解耦而且不同服务能够采用灵活部署方式。
Description
技术领域
本发明涉及数据处理技术领域,具体涉及一种获取电梯实时数据的方法和设备。
背景技术
目前获取电梯状态的装置一般包括两个服务,其中一个是获取电梯实时运行状态的读取状态服务,功能是通过modbus协议等方式获取电梯状态;另一个是对外提供数据的服务,功能是通过websocket协议等方式对外提供接口;两个服务实现在同一进程中,部署采用简单的单一服务器运行。
但是现有的方式存在一些问题:具体的,由于两个服务器实现在同一个进程中,不仅功能耦合在一起造成功能实现和维护比较困难,而且限制了部署方式,只能采用单一的服务器运行。若不能按主备或均衡负载等高可用方式部署,那么对外提供的接口将承受不了大并发访问影响体验或延时很大不满足要求,同时服务运行崩溃不能恢复等问题使可靠性也不能得到保证。
由此,目前需要有一种更好的方法来解决现有技术中的问题。
发明内容
本发明提供一种获取电梯实时数据的方法和装置,能够解决现有技术中的技术问题。
本发明解决上述技术问题的技术方案如下:
本发明实施例提出了一种获取电梯实时数据的方法,包括:
通过读取状态服务持续从电梯获取实时的电梯状态数据;
通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,所述读取状态服务包括主读取状态服务与备用读取状态服务;
所述“通过读取状态服务持续从电梯获取实时的电梯状态数据”,包括:
选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
在一个具体的实施例中,所述kafka队列还连接有云平台;该方法包括:
通过所述kafka队列将所述电梯状态数据上传到所述云平台。
在一个具体的实施例中,所述提供数据服务的数量有多个;
所述“若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端”,包括:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,多个所述提供数据服务采用负载均衡的方式部署。
本发明实施例提出了一种获取电梯实时数据的装置,包括:
读取模块,用于通过读取状态服务持续从电梯获取实时的电梯状态数据;
发送模块,用于通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
推送模块,用于若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,所述读取状态服务包括主读取状态服务与备用读取状态服务;
所述读取模块,用于:选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
在一个具体的实施例中,所述kafka队列还连接有云平台;该装置包括:
云端模块,用于通过所述kafka队列将所述电梯状态数据上传到所述云平台。
在一个具体的实施例中,所述提供数据服务的数量有多个;
所述推送模块,用于:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,多个所述提供数据服务采用负载均衡的方式部署。
本发明的有益效果是:
本发明实施例提出了一种获取电梯实时数据的方法和装置,其中该方法包括:通过读取状态服务持续从电梯获取实时的电梯状态数据;通过所述读取状态服务将所述电梯状态数据发送到kafka队列;若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。本方案中,将读取状态服务与提供数据服务分开实现,不仅解决功能实现的解耦而且不同服务能够采用灵活部署方式。
附图说明
图1为本发明实施例提供的一种获取电梯实时数据的方法的流程示意图;
图2为本发明实施例提供的一种获取电梯实时数据的方法的系统结构意图;
图3为本发明实施例提供的一种获取电梯实时数据的装置的结构示意图;
图4为本发明实施例提供的一种获取电梯实时数据的装置的另一结构示意图。
图例说明:
201-读取模块;202-发送模块;203-推送模块;204-云端模块。
具体实施方式
以下结合附图对本发明的原理和特征进行描述,所举实例只用于解释本发明,并非用于限定本发明的范围。
本发明实施例提供的一种获取电梯实时数据的方法,如图1所示,包括以下步骤:
步骤S101、通过读取状态服务持续从电梯获取实时的电梯状态数据;
如图2所示,本方案中,将将提供数据服务和读取状态服务分为两个进程独立运行,服务间采用kafka消息队列通讯,两个服务功能上实现了解耦。也即事先部署kafka消息队列,用于两个服务间通讯。
首先,利用读取状态服务(lift-status server)持续从电梯侧读取电梯状态数据。
步骤S102、通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
在读取状态服务(lift-status server)获取到电梯状态数据之后,将电梯状态数据发送到kafka队列中。
步骤S103、若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
以此,若后续获取到客户端的数据请求,则通过提供数据服务(websocketserver)基于客户的请求,将电梯状态数据推送到客户端。
在一个具体的实施例中,为了进一步保证可靠性,所述读取状态服务包括主读取状态服务与备用读取状态服务;
由此,步骤S101中的所述“通过读取状态服务持续从电梯获取实时的电梯状态数据”,包括:
选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
具体的,设置两个读取状态服务(lift-status server),并区分主备,由于电梯状态数据只能由一个服务读取,所以采用主备的方式部署,主备服务间采用心跳的方式保证只有一个服务运行,保证了数据的唯一性的同时提高了服务的可靠性,不会因为任何一个服务运行崩溃等原因导致系统不能正常工作。
进一步的,所述kafka队列还连接有云平台;该方法包括:
通过所述kafka队列将所述电梯状态数据上传到所述云平台。
具体的,除了将电梯状态数据推送给客户端,还可以根据需要将电梯状态数据上传到云平台,以便后续使用。
此外,如图2所示,所述提供数据服务的数量有多个;
由此,步骤S103中的所述“若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端”,包括:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
具体的,提供数据服务(websocket server)的部署采用负载均衡的方式部署,保证大并发量的客户端访问的实时性,另外多个服务同时运行,保证了不会因为某些服务故障导致系统不能正常工作。
进一步的,多个所述提供数据服务采用负载均衡的方式部署。
具体的,如图2所示,(4)提供数据服务(websocket server)前端采用keepalived+Nginx实现分布式VIP(虚拟IP)部署,达到负载均衡的目的。
以此,本方案中,不同功能服务分开实现,不仅解决功能实现的解耦而且不同服务能够采用灵活部署方式。高可用方式部署能有效提高客户访问的并发量和实时性,同时也解决了系统可靠性的问题,不会出现系统异常的情况。
实施例2
为了对本发明进行进一步的说明,本发明实施例2还公开了一种获取电梯实时数据的装置,如图3所示,包括:
读取模块201,用于通过读取状态服务持续从电梯获取实时的电梯状态数据;
发送模块202,用于通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
推送模块203,用于若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,所述读取状态服务包括主读取状态服务与备用读取状态服务;
所述读取模块201,用于选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
在一个具体的实施例中,所述kafka队列还连接有云平台;该装置还包括:
云端模块204,用于通过所述kafka队列将所述电梯状态数据上传到所述云平台。
在一个具体的实施例中,所述提供数据服务的数量有多个;
所述推送模块203,用于:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
在一个具体的实施例中,多个所述提供数据服务采用负载均衡的方式部署。
本发明实施例提出了一种获取电梯实时数据的方法和装置,其中该方法包括:通过读取状态服务持续从电梯获取实时的电梯状态数据;通过所述读取状态服务将所述电梯状态数据发送到kafka队列;若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。本方案中,将读取状态服务与提供数据服务分开实现,不仅解决功能实现的解耦而且不同服务能够采用灵活部署方式。
以上,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到各种等效的修改或替换,这些修改或替换都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。
Claims (10)
1.一种获取电梯实时数据的方法,其特征在于,包括:
通过读取状态服务持续从电梯获取实时的电梯状态数据;
通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
2.如权利要求1所述的方法,其特征在于,所述读取状态服务包括主读取状态服务与备用读取状态服务;
所述“通过读取状态服务持续从电梯获取实时的电梯状态数据”,包括:
选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
3.如权利要求1所述的方法,其特征在于,所述kafka队列还连接有云平台;该方法包括:
通过所述kafka队列将所述电梯状态数据上传到所述云平台。
4.如权利要求1所述的方法,其特征在于,所述提供数据服务的数量有多个;
所述“若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端”,包括:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
5.如权利要求4所述的方法,其特征在于,多个所述提供数据服务采用负载均衡的方式部署。
6.一种获取电梯实时数据的装置,其特征在于,包括:
读取模块,用于通过读取状态服务持续从电梯获取实时的电梯状态数据;
发送模块,用于通过所述读取状态服务将所述电梯状态数据发送到kafka队列;
推送模块,用于若获取到客户端的请求,则通过提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
7.如权利要求6所述的装置,其特征在于,所述读取状态服务包括主读取状态服务与备用读取状态服务;
所述读取模块,用于:选择所述主读取状态服务持续从电梯获取实时的电梯状态数据;
若无法通过所述主读取状态服务获取到电梯状态数据,则选择所述备用读取状态服务持续从电梯获取实时的电梯状态数据。
8.如权利要求6所述的装置,其特征在于,所述kafka队列还连接有云平台;该装置包括:
云端模块,用于通过所述kafka队列将所述电梯状态数据上传到所述云平台。
9.如权利要求6所述的装置,其特征在于,所述提供数据服务的数量有多个;
所述推送模块,用于:
若获取到客户端的请求,则通过多个提供数据服务从所述kafka队列中获取所述电梯状态数据推送给所述客户端。
10.如权利要求9所述的装置,其特征在于,多个所述提供数据服务采用负载均衡的方式部署。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111437178.9A CN114090302A (zh) | 2021-11-29 | 2021-11-29 | 一种获取电梯实时数据的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111437178.9A CN114090302A (zh) | 2021-11-29 | 2021-11-29 | 一种获取电梯实时数据的方法和装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114090302A true CN114090302A (zh) | 2022-02-25 |
Family
ID=80305721
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111437178.9A Pending CN114090302A (zh) | 2021-11-29 | 2021-11-29 | 一种获取电梯实时数据的方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114090302A (zh) |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111080500A (zh) * | 2019-11-26 | 2020-04-28 | 武汉烽火众智数字技术有限责任公司 | 基于spark streaming的实时规则的布控预警方法及装置 |
-
2021
- 2021-11-29 CN CN202111437178.9A patent/CN114090302A/zh active Pending
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111080500A (zh) * | 2019-11-26 | 2020-04-28 | 武汉烽火众智数字技术有限责任公司 | 基于spark streaming的实时规则的布控预警方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9331870B2 (en) | Switch, information processing apparatus, and information processing system | |
CN112118315A (zh) | 数据处理系统、方法、装置、电子设备和存储介质 | |
CN107528891B (zh) | 一种基于WebSocket的自动集群方法及其系统 | |
US9697165B2 (en) | Server system for synchronizing memory data of motherboards | |
CN114024880B (zh) | 基于代理ip与流表的网络靶场探针采集方法与系统 | |
CN110868278B (zh) | 一种轨道交通综合监控系统通信前置机双机冗余的方法 | |
CN108712457A (zh) | 基于Nginx反向代理的后端服务器动态负载调整方法及装置 | |
US9762667B2 (en) | Distributed server election with imperfect clock synchronization | |
WO2021184992A1 (zh) | 一种镜像文件的上传方法、相关设备及计算机存储介质 | |
CN107800737A (zh) | 一种服务器集群中主节点的确定方法、装置及服务器集群 | |
CN115396529A (zh) | 多通道通信方法、装置、终端设备及存储介质 | |
CN114697391A (zh) | 数据处理方法、装置、设备以及存储介质 | |
CN112838935A (zh) | 一种电子数据交换方法和系统 | |
CN117041147B (zh) | 智能网卡设备、主机设备和方法及系统 | |
US7996594B2 (en) | Interrupt-driven link status feedback mechanism for embedded switches | |
CN112506682A (zh) | 业务服务器异常救济方法、装置和计算机可读存储介质 | |
CN114090302A (zh) | 一种获取电梯实时数据的方法和装置 | |
CN111131367B (zh) | 一种分布式接入服务处理方法及装置 | |
CN109302319B (zh) | 报文池分布式集群及其管理方法 | |
CN105025042B (zh) | 一种确定数据信息的方法及系统、代理服务器 | |
CN111092952A (zh) | 一种数据交互方法及相关产品 | |
CN114979144B (zh) | 云边通信方法、装置及电子设备 | |
CN114338477B (zh) | 一种通信链路监控方法、装置、设备及存储介质 | |
CN109445984A (zh) | 一种业务恢复方法、装置、仲裁服务器以及存储系统 | |
CN104092703B (zh) | 基于tsp服务的cti信号处理系统及其方法 |
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 |