CN113448725A - 一种数据推送的方法、装置、终端及存储介质 - Google Patents
一种数据推送的方法、装置、终端及存储介质 Download PDFInfo
- Publication number
- CN113448725A CN113448725A CN202110587408.3A CN202110587408A CN113448725A CN 113448725 A CN113448725 A CN 113448725A CN 202110587408 A CN202110587408 A CN 202110587408A CN 113448725 A CN113448725 A CN 113448725A
- Authority
- CN
- China
- Prior art keywords
- data
- pushing
- current data
- queue
- source terminal
- 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
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/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/5038—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the execution order of a plurality of tasks, e.g. taking priority or time dependency constraints into consideration
-
- 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
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明公开一种数据推送的方法、装置、终端及存储介质,其中,一种数据推送的方法,包括:结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;所述结点将所述当前数据放置到对应所述识别信息的推送列队中;推送列队将所述当前数据进行推送。通过将当前数据基于数据来源终端进行分类以便将同一个数据来源终端的数据分配给同一个推送列进行处理,避免数据推送乱序。
Description
技术领域
本发明涉及数据处理技术领域,尤其涉及一种数据推送的方法、装置、终端及存储介质。
背景技术
在大数据的时代背景下,随着城市的飞速发展,各种数据信息层出不穷,在这个信息***的时代里,用户如何能够快速明了地获得自己所关注的各方面的数据信息显得越来越重要。
例如在集群业务推送场景中,用户数据来源终端设备会定时向我们的GCS服务器(GPSCollectingSystem)上报数据信息,然后服务器会向监控订阅方推送该些数据信息。但是在现有技术中,由于服务器属于集群式服务,服务器的数据推送处理一般是选择一个空闲的二级推送列队将数据推送到订阅方。因此同一个数据来源终端先后上报的数据信息可能会被不同的推送列队处理,导致之前先上报的数据还在排队等待处理,后上传的数据以及被推送到订阅方,造成数据推送乱序。
因此,现有技术还有待提升。
发明内容
为了解决现有技术中同一个数据来源终端先后上报的数据信息可能会被不同的推送列队处理造成数据推送乱序的问题,本发明提出一种数据推送的方法、装置、终端及存储介质,将数据进行分类以便将同一个数据来源终端的数据分配给同一个推送列进行处理,避免数据推送乱序。
本发明通过以下技术方案实现的:
第一方面,本发明提出一种数据推送的方法,包括:
结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
推送列队将所述当前数据进行推送。
通过接收所述当前数据并获取对应的所述当前数据的数据来源终端的识别信息,确定数据的来源终端设备,然后将所述当前数据放入到对应所述识别信息(数据来源终端)的推送列队中,也就是保证将来自同一个数据来源终端的数据都在一个推送列队中被处理,避免了推送乱序,同时避免数据分配时选择空闲的推送列队进行分配造成有的推送列队数据挤压有的推送列队空闲且所有的数据推送太过杂乱没有条理、推送列队工作不合理的缺陷,保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率。
在本发明的其中一种实施方案中,所述结点将所述当前数据放置到对应所述识别信息的推送列队中包括:
对所述识别信息进行哈希计算并取整数的哈希值;
计算所述哈希值与推送列队总数的商得余数;
将所述当前数据放置到对应所述余数的推送列队。
通过求取所述识别信息的哈希值,并且所述哈希值为整数,便于计算所述所述哈希值与所述推送列队总数的商的余数,且通过计算所述哈希值与推送列队总数的商得余数后根据余数将所述数据放置到对应余数推送列队,由于不同的数据来源终端的识别信息是不一样的,所以对应所述数据来源终端的哈希值也是唯一的,通过使用所述推送列队总数为除数,然后基于余数推荐保证了所有的推送列队都能被分配到来自不同的数据来源终端的待推送的数据,避免推送列队空闲浪费或待推送的数据积压,进一步保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率以及数据推送的有序性。
在本发明的其中一种实施方案中,所述将所述当前数据放置到对应所述余数的推送列队包括:
获取对应所述结点的推送列队的列队编号;
将所述当前数据放入与所述余数相匹配的数据编号对应推送列队中。
通过获取对应所述结点的推送列队的列队编号,便于所述推送列队与所述余数匹配后对应将所述当前数据进行分配,使得所述当前数据被分配过程更加简便,进一步保证了数据推送的有序性。
在本发明的其中一种实施方案中,所述识别信息为所述当前数据来源终端的设备ID信息。
在本发明的其中一种实施方案中,所述结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息包括:
GCS结点接收数据来源终端的当前数据;
基于所述当前数据获取对应的数据来源终端的设备ID信息。
在本发明的其中一种实施方案中,所述推送列队将所述当前数据进行推送包括:
推送列队获取对应所述数据来源终端的订阅端;
推送列队将所述当前数据发送到对应的订阅方。
通过所述推送列队进行数据处理将所述当前数据推送到相应的订阅方。
在本发明的其中一种实施方案中,所述推送列队将所述当前数据进行推送还包括:
当所述推送列队内存在待推送的历史数据时,所述当前数据和所述历史数据按照接收顺序依次进行推送处理。
通过设置同一个推送列队内的待推送的历史数据时按照接收的先后顺序依次进行推送处理,避免同一推送列队内的数据推送混乱,进一步保证了数据推送的有序性。
第二方面,本发明还提供一种数据推送装置,包括:
数据接收模块:用于结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
数据分配模块:用于所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
数据推送模块:用于推送列队将所述当前数据进行推送。
第三方面,本发明还提供一种终端,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于执行如上述1-7任意一项所述的方法。
第四方面,本发明还提供一种计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如上述1-7任意一项所述的方法。
本发明的有益效果在于:
本发明通过一种数据推送的方法、装置、终端及存储介质,通过接收数据并获取对应的所述当前数据的数据来源终端的识别信息,确定数据的来源终端设备,然后将所述当前数据放入到对应所述识别信息(数据来源终端)的推送列队中,也就是保证将来自同一个数据来源终端的数据都在一个推送列队中被处理,避免了推送乱序,同时避免数据分配时选择空闲的推送列队进行分配造成有的推送列队数据挤压有的推送列队空闲且所有的数据推送太过杂乱没有条理、推送列队工作不合理的缺陷,保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率。
附图说明
图1是本发明数据推送的方法一种实施方案结构示意图;
图2是本发明图1数据推送的方法实施方案中步骤S100的结构示意图;
图3是本发明图1数据推送的方法实施方案步骤S200的结构示意图;
图4是本发明图1数据推送的方法实施方案步骤S300的结构示意图;
图5是本发明数据推送装置的模块连接结构示意图;
图6是本发明一种数据推送终端结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。
本发明以设备GPS监控的业务为场景进行实施方案的描述,在现有技术中,用户终端设备(数据来源终端)会定时向我们的GCS服务器(GPSCollectingSystem)上报其自身的GPS点位,然后GCS服务器会向监控订阅方推送该设备的位置信息。出于均衡负载的需要,GCS服务器属于集群式服务,设备的每次上报请求可能由集群内不同的GCS结点处理,并广播到集群内其他的GCS结点,以便于向该结点上挂载的监控订阅方推送设备位置信息。GCS结点在接收到来自集群内的GPS广播事件时并不会直接推送给相关的监控订阅方,因为推送的过程会延缓对后续事件的处理,为了实现更高的并发性,GCS结点在接收到广播消息后会把该消息交由进程内二级队列单元处理,然后自身继续处理下一个集群消息;目前所述二级列队单元被选中处理推送的方式主要是选择一个空闲的二级队列单元处理当前的GPS消息,那有可能导致对于同一个设备的GPS推送乱序,即该设备的上一个点位仍然积压在队列A中等待处理,而该设备的下一个点位可能被队列B迅速处理。因此本发明中提出本发明提出一种数据推送的方法、装置、终端及存储介质,通过将数据进行分类以便将同一个数据来源终端的数据分配给同一个推送列进行处理,避免数据推送乱序。具体实施方案参见如下:
示例性方法
参见图1,本发明提供一种数据推送的方法,包括:
步骤S100:结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息。
具体的,所述当前数据为数据来源终端实时传输的当前数据,可以为需要推送传输的初始数据由后续处理步骤进行二次整理后进行推送,也可以为需要传输推送的最终数据,可由所述数据来源终端进行采集获取,所述数据来源终端可以为对应所述数据类型的各类采集设备,通过将服务器实现与所述采集设备进行数据交换实现接收,所述当前数据可以是天气数据、温度数据、空气质量数据等,在本市实施方案中所述数据为GPS点位数据,通过GPS数据采集设备进行采集。
进一步的,所述数据来源终端的识别信息可以为数据来源终端的设备编号、设备代码等,在本实施方案中,所述识别信息为所述数据来源终端的设备ID信息。具体可以在服务器收到所述数据之后根据所述数据的来源进行获取也可以将所述数据来源中的设备ID信息被携带在所述数据中,所述服务器通过提取数据中的所述设备ID信息进行获取,具体本发明不做具体的限定,可以根据实际运用方便进行调整。
具体的,参见图2,在上述实施方案的基础上,所述步骤S100还包括:
步骤S101:GCS结点接收数据来源终端的当前数据;
步骤S102:基于所述当前数据获取对应的数据来源终端的设备ID信息。
具体的,在服务器中包含多个所述GCS节点,每个GCS节点包括多个二级列队(所述二级列队为本实施方案中的推送列队)每个所述GCS节点用于处理各种不同的集群信息,每个所述GCS节点的处理设备或是处理事项类型可以通过预设进行分配,本实施方案中以其中的一个所述GCS节点为例,数据来源信息直接将所述数据传输到对应的所述GCS节点,使得数据传输的调理性,避免数据混乱。且在一个GCS结点内,会存在多个并行工作的二级队列单元(推送列队),它们的任务就是把所述数据(在本实施方案中为GPS点位信息)推送给挂载在当前结点上的相关的监控订阅方,具体的,所述订阅方的推送目标地址可以在订阅方订阅时获取,并通过在发出所述当前数据时将地址信息附带在所述当前数据中,或者将所述订阅方的地址信息与所述数据来源终端进行对应,建立所述订阅方与所述数据来源终端之间的对应关系或者地址链接,订阅方的目标地址信息可以携带在当前数据中,通过所述二级列队单元获取该地址信息并进行推送,也可以在上述任一个处理步骤中对应关系以获取地址信息,然后通过将地址信息附着在所述当前数据上,通过所述二级列队单元获取该地址信息并进行推送,具体可以根据实际情况进行设置,本发明不做具体的限定。
步骤S200:所述结点将所述当前数据放置到对应所述识别信息的推送列队中。
具体的,所述结点将所述当前数据放置到对应所述识别信息的推送列队中,主要用于将数据来源终端相同的所述数据放置到相同推送列队,也就是说将同一个数据来源终端传输来的数据都分配到同一个推送列队中被处理,避免推送乱序。
具体的,参见图3,在上述实施方案的基础上,所述步骤S200还包括:
步骤S201:对所述识别信息进行哈希计算并取整数的哈希值;
步骤S202:计算所述哈希值与推送列队总数的商得余数;
步骤S203:将所述当前数据放置到对应所述余数的推送列队。
具体的,同一数据来源终端的设备ID信息经过Hash算法计算后的得到的哈希值是不会变的,所以每次Hash取余后的余数都是相同的,所以可以保证同一个设备能够进入同一队列,保证了GCS服务器在集群环境中能够保证有序的推送数据,特别是在本实施方中,所述数据为GPS点位信息,这种实时GPS点位推送服务需要报每个时刻的点位是要按上报时间去推送给客户端,例如我要从A到B点,在地图上看到位置移动一定是先A到B的顺序,但是在我们我们集群环境由于网络、主机性能等方面的影响导致不同的所述推送列队处理效率不同会导致数据推送乱序,直接推送给客户端是会出现B到A的情况。所以我们通过取余数保证同一设备上报过来的位置是一定能到同一GCS服务里的同一个队列,从而保证位置是A到B的顺序,保证了数据的有效性。进一步的,在上述实施方案的基础上,所述步骤S将所述当前数据放置到对应所述余数的推送列队包括:获取对应所述结点的推送列队的列队编号;将所述当前数据放入与所述余数相匹配的数据编号对应推送列队中。
通过获取对应所述结点的所述推送列队的列队编号,便于所述推送列队与所述余数匹配进行分配,使得当前数据被分配过程更加简便,进一步保证了数据推送的有序性。
具体的,所述列队编号没有排序的意义,只是专门的对应所述余数的区分编号码,可以是0、1、2、3、4等***数字,也可以是罗马数字,或者是分别对应所述余数的自定义字符,具体本发明不做限定。
具体的,我们假设一个设备Id信息=3的设备上报待推送的当前数据到GCS节点上,而GCS节点内有4个推送队列,那么我们将该设备Id信息进行Hash后与推送队列总数(4)进行取余数可得到余数3,于是我们将该当前数据放入列队编号为3的推送列队进行推送,往后只要GCS结点中的推送队列总数不变,该设备都只会放进列队编号为3的推送队列,通过其推送给订阅方,保证了推送有序性。当所述推送列队总数发生变化时,也可以根据改变了的所述余数将新接收到的数据来源终端的数据放置到对应的列队,具体可以根据实际情况进行调整。
在本发明的其他实施方案中,所述结点也可以只在初次接收来自数据来源终端的当前数据时计算上述余数或者在结点推送列队总数变化时计算上述余数,后续实时接收到的当前数据可以先检测之前同一数据来源终端的历史数据被放置在哪个推送列队进行推送处理,然后基于历史数据的推送路径将所述当前数据放置到对应的推送列队中处理。通过求取所述识别信息的哈希值,并且去哈希值为整数,便于计算所述所述哈希值与所述推送列队总数的商的余数,且通过计算所述哈希值与推送列队总数的商得余数后根据余数将所述数据放置到对应余数推送列队,通过使用所述推送列队总数为除数,然后基于余数推荐保证了所有的推送列队都能被分配到待推送的数据,避免推送列队空闲浪费,进一步保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率以及数据推送的有序性。
步骤S300:推送列队将所述当前数据进行推送。
进一步的,在上时实施方案的基础上,参见图4,所述步骤S300包括:
步骤S301:推送列队获取对应所述数据来源终端的订阅端;
步骤S302:推送列队将所述当前数据发送到对应的订阅方。
通过所述推送列队进行数据处理将所述当前数据推送到相应的订阅方。
具体的,当推送列队内存在待推送的历史数据时,所述当前数据和所述历史数据按照接收顺序依次进行推送处理。通过设置同一个推送列队内的待推送历史数据和所述当前数据按照依次按照接收的先后顺序进行处理,避免同一推送列队内的数据推送混乱,进一步保证了数据推送的有序性。
具体的,所述历史数据为数据来源终端的接收所述当前数据之前被放置到推送列队中的排队等待被推送到订阅方的数据,所述历史数据可能为来自不同的数据来源终端的数据(一个推送列队可以处理来自多个数据来源终端的数据),也可以为来自同一数据来源终端的数据,均按照时间先后顺序来进行推送。
具体的,所述订阅方挂载在上述GCS结点上,所述推送列队通过获取订阅方设备ID或是识别账号、推送路径等,然后后将所述数据分别发送给不同的订阅方,订阅方终端就会收到所述数据。
所述数据推送的方法通过接收当前数据并获取对应的数据来源终端的识别信息,确定数据的来源设备,然后将所述当前数据放入到对应所述识别信息(数据来源终端)的推送列队中,也就是保证将来自同一个数据来源终端的数据都在一个推送列队中被处理,避免了推送乱序,同时避免数据分配时选择空闲的推送列队进行分配造成有的推送列队数据挤压有的推送列队空闲且所有的数据推送太过杂乱没有条理、推送列队工作不合理的缺陷,保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率。
应该理解的是,上述流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些子步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
示例性装置
参见图5,本发明还提供一种数据推送装置,包括:
数据接收模块100:用于结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
数据分配模块200:用于所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
数据推送模块300:用于用于推送列队将所述当前数据进行推送。
在本发明的其中一种实施方案中,所述数据接收模块100具体包括:
用于GCS结点接收数据来源终端的当前数据;以及用于基于所述当前数据获取对应的数据来源终端的设备ID信息。
在本发明的其中一种实施方案中,所述数据分配模块200还包括:
哈希模块:用于对所述识别信息进行哈希计算并取整数的哈希值;
余数计算模块:用于计算所述哈希值与推送列队总数的商得余数;
放置模块:用于将所述当前数据放置到对应所述余数的推送列队。
在本发明的其中一种实施方案中,所述放置模块具体用于获取对应所述结点的推送列队的列队编号;将所述当前数据放入与所述余数相匹配的数据编号对应推送列队中。
在本发明的其中一种实施方案中,所述数据推送模块300还包括:
订阅端获取模块:用于推送列队获取对应所述当前数据的订阅端;
数据推送子模块:用于推送列队将当前数据发送到对应的订阅方。
上述各个实施例,数据推送装置通过接收当前数据并获取对应的数据来源终端的识别信息,确定数据的来源设备,然后将所述当前数据放入到对应所述识别信息(数据来源终端)的推送列队中,也就是保证将来自同一个数据来源终端的数据都在一个推送列队中被处理,避免了推送乱序,同时避免数据分配时选择空闲的推送列队进行分配造成有的推送列队数据挤压有的推送列队空闲且所有的数据推送太过杂乱没有条理、推送列队工作不合理的缺陷,保证了数据分配的条理性以及推送列队处理的合理性同时保证工作效率。
关于信息推送数据推送装置的具体限定可以参见上文中对于数据推送方法的限定,在此不再赘述。上述数据推送装置中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
基于上述实施例,本发明还提供了一种终端,其原理框图可以如图6所示。该智能终端包括通过***总线连接的处理器、存储器、网络接口、显示屏。其中,该终端的处理器用于提供计算和控制能力。该终端的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作***和计算机程序。该内存储器为非易失性存储介质中的操作***和计算机程序的运行提供环境。该终端的网络接口用于与外部的终端通过网络连接通信。该计算机程序被处理器执行时以实现数据推送的方法。该终端的显示屏可以是液晶显示屏或者电子墨水显示屏,还可包括智能终端的温度传感器,该智能终端的温度传感器是预先在智能终端内部设置,用于检测内部设备的当前运行温度。
本领域技术人员可以理解,图6中示出的原理框图,仅仅是与本发明方案相关的部分结构的框图,并不构成对本发明方案所应用于其上的智能终端的限定,具体的智能终端可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
在一个实施例中,提供了一种终端,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
推送列队将所述当前数据进行推送。
在本发明的其中一种实施方案中,所述结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息指令包括:
GCS结点接收数据来源终端的当前数据;
基于所述当前数据获取对应的数据来源终端的设备ID信息。
在本发明的其中一种实施方案中,所述所述结点将所述当前数据放置到对应所述识别信息的推送列队中指令包括:
对所述识别信息进行哈希计算并取整数的哈希值;
计算所述哈希值与推送列队总数的商得余数;
将所述当前数据放置到对应所述余数的推送列队。
在本发明的其中一种实施方案中,所述将所述当前数据放置到对应所述余数的推送列队指令还包括:
获取对应所述结点的推送列队的列队编号;
将所述当前数据放入与所述余数相匹配的数据编号对应推送列队中。
在本发明的其中一种实施方案中,所述推送列队将所述当前数据进行推送指令具体还包括:
推送列队获取对应所述数据来源终端的订阅端;
推送列队将所述当前数据发送到对应的订阅方。
上述实施例,计算机可读存储介质通过其存储的计算机程序,实现了数据有序推送的目的,将数据进行分类以便将同一个数据来源终端的数据分配给同一个推送列进行处理,避免数据推送乱序。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本发明所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink)DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。以上实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
应当理解的是,基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
Claims (10)
1.一种数据推送的方法,其特征在于,包括:
结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
推送列队将所述当前数据进行推送。
2.根据权利要求1所述的数据推送的方法,其特征在于,所述结点将所述当前数据放置到对应所述识别信息的推送列队中包括:
对所述识别信息进行哈希计算并取整数的哈希值;
计算所述哈希值与推送列队总数的商得余数;
将所述当前数据放置到对应所述余数的推送列队。
3.根据权利要求2所述的数据推送的方法,其特征在于,所述将所述当前数据放置到对应所述余数的推送列队包括:
获取对应所述结点的推送列队的列队编号;
将所述当前数据放入与所述余数相匹配的数据编号对应推送列队中。
4.根据权利要求1或2所述的数据推送的方法,其特征在于,所述识别信息为所述当前数据来源终端的设备ID信息。
5.根据权利要求4所述的数据推送的方法,其特征在于,所述结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息包括:
GCS结点接收数据来源终端的当前数据;
基于所述当前数据获取对应的数据来源终端的设备ID信息。
6.根据权利要求1或5所述的数据推送的方法,其特征在于,所述推送列队将所述当前数据进行推送包括:
推送列队获取对应所述数据来源终端的订阅端;
推送列队将当前数据发送到对应的订阅方。
7.根据权利要求6所述的数据推送的方法,其特征在于,所述推送列队将所述当前数据进行推送还包括:
当所述推送列队内存在待推送的历史数据时,所述当前数据和所述历史数据按照接收顺序依次进行推送处理。
8.一种数据推送装置,其特征在于,包括:
数据接收模块:用于结点接收当前数据并获取对应所述当前数据的数据来源终端的识别信息;
数据分配模块:用于所述结点将所述当前数据放置到对应所述识别信息的推送列队中;
数据推送模块:用于推送列队将所述当前数据进行推送。
9.一种终端,其特征在于,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于执行如权利要求1-7任意一项所述的方法。
10.一种计算机可读存储介质,其特征在于,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1-7任意一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110587408.3A CN113448725A (zh) | 2021-05-27 | 2021-05-27 | 一种数据推送的方法、装置、终端及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110587408.3A CN113448725A (zh) | 2021-05-27 | 2021-05-27 | 一种数据推送的方法、装置、终端及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN113448725A true CN113448725A (zh) | 2021-09-28 |
Family
ID=77810242
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110587408.3A Pending CN113448725A (zh) | 2021-05-27 | 2021-05-27 | 一种数据推送的方法、装置、终端及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113448725A (zh) |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103986787A (zh) * | 2014-06-05 | 2014-08-13 | 合一网络技术(北京)有限公司 | 自动获取视频更新的方法和*** |
CN106656863A (zh) * | 2016-12-31 | 2017-05-10 | 广东欧珀移动通信有限公司 | 业务监控方法、装置和计算机设备 |
CN107465595A (zh) * | 2017-07-25 | 2017-12-12 | 腾讯科技(深圳)有限公司 | 设备消息播放控制方法、装置、消息播放设备及存储介质 |
CN109788053A (zh) * | 2019-01-04 | 2019-05-21 | 深圳壹账通智能科技有限公司 | 数据同步方法和*** |
CN109815028A (zh) * | 2018-12-27 | 2019-05-28 | 北京摩拜科技有限公司 | 数据同步的***、方法、装置和计算机存储介质 |
CN111131074A (zh) * | 2018-10-31 | 2020-05-08 | 中移(杭州)信息技术有限公司 | 一种数据处理方法、装置、***、服务器及可读存储介质 |
US10691359B1 (en) * | 2012-06-11 | 2020-06-23 | Solace Systems, Inc. | Messaging delivery system with last message queue |
CN112637046A (zh) * | 2020-12-18 | 2021-04-09 | 北京房天下嘉居网络技术有限公司 | 消息推送方法及路由装置 |
-
2021
- 2021-05-27 CN CN202110587408.3A patent/CN113448725A/zh active Pending
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10691359B1 (en) * | 2012-06-11 | 2020-06-23 | Solace Systems, Inc. | Messaging delivery system with last message queue |
CN103986787A (zh) * | 2014-06-05 | 2014-08-13 | 合一网络技术(北京)有限公司 | 自动获取视频更新的方法和*** |
CN106656863A (zh) * | 2016-12-31 | 2017-05-10 | 广东欧珀移动通信有限公司 | 业务监控方法、装置和计算机设备 |
CN107465595A (zh) * | 2017-07-25 | 2017-12-12 | 腾讯科技(深圳)有限公司 | 设备消息播放控制方法、装置、消息播放设备及存储介质 |
CN111131074A (zh) * | 2018-10-31 | 2020-05-08 | 中移(杭州)信息技术有限公司 | 一种数据处理方法、装置、***、服务器及可读存储介质 |
CN109815028A (zh) * | 2018-12-27 | 2019-05-28 | 北京摩拜科技有限公司 | 数据同步的***、方法、装置和计算机存储介质 |
CN109788053A (zh) * | 2019-01-04 | 2019-05-21 | 深圳壹账通智能科技有限公司 | 数据同步方法和*** |
CN112637046A (zh) * | 2020-12-18 | 2021-04-09 | 北京房天下嘉居网络技术有限公司 | 消息推送方法及路由装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110297711B (zh) | 批量数据处理方法、装置、计算机设备及存储介质 | |
CN107832126B (zh) | 一种线程的调整方法及其终端 | |
WO2020052322A1 (zh) | 数据处理的方法、装置和计算节点 | |
CN105119769B (zh) | 一种对周期性数据上报进行时间散列的*** | |
CN111651285A (zh) | 批量业务数据处理方法、装置、计算机设备和存储介质 | |
CN108446172B (zh) | 数据调取方法、装置、计算机设备和存储介质 | |
CN111813573B (zh) | 管理平台与机器人软件的通信方法及其相关设备 | |
CN105072139B (zh) | 推荐方法和装置 | |
CN108241539B (zh) | 基于分布式***的交互式大数据查询方法、装置、存储介质和终端设备 | |
CN104750690A (zh) | 一种查询处理方法、装置及*** | |
CN113742109B (zh) | 第三方服务对接方法、装置、设备及存储介质 | |
CN108881651B (zh) | 呼叫平台的数据处理方法、装置、设备及存储介质 | |
CN111159233A (zh) | 分布式缓存方法、***、计算机设备以及存储介质 | |
WO2021036319A1 (zh) | 数据清洗方法和*** | |
CN104158860A (zh) | 一种作业调度方法及作业调度*** | |
CN112396480B (zh) | 订单业务数据的处理方法、***、计算机设备和存储介质 | |
CN113672284A (zh) | 一种指令执行方法、***、电子设备以及存储介质 | |
CN113448725A (zh) | 一种数据推送的方法、装置、终端及存储介质 | |
CN110839061B (zh) | 数据分发方法、装置及存储介质 | |
CN115904729A (zh) | 一种连接分配的方法、装置、***、设备及介质 | |
CN115242718B (zh) | 集群限流方法、装置、设备及介质 | |
CN115658292A (zh) | 资源调度方法、装置、计算机设备和存储介质 | |
CN112860763B (zh) | 实时流数据处理方法、装置、计算机设备和存储介质 | |
CN112035760B (zh) | 一种任务分配方法及计算机设备 | |
CN113268327A (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 |