CN112804298B - 减少跨区流量的方法、装置、计算机设备和可读存储介质 - Google Patents
减少跨区流量的方法、装置、计算机设备和可读存储介质 Download PDFInfo
- Publication number
- CN112804298B CN112804298B CN202011599565.8A CN202011599565A CN112804298B CN 112804298 B CN112804298 B CN 112804298B CN 202011599565 A CN202011599565 A CN 202011599565A CN 112804298 B CN112804298 B CN 112804298B
- Authority
- CN
- China
- Prior art keywords
- consumption
- available area
- area information
- consumer
- cross
- 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
Images
Classifications
-
- 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/01—Protocols
- H04L67/12—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
-
- 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/50—Network services
- H04L67/55—Push-based network services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/12—Messaging; Mailboxes; Announcements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/24—Accounting or billing
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本申请涉及一种减少跨区流量的方法、装置、计算机设备和可读存储介质,其中方法包括:接收消费端发送的消息消费请求;获取消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;根据可用区信息比较结果,优先允许与自身的可用区信息一致的消费端的消费请求,解决了相关技术中的跨区流量较大以及数据传输延时的问题。
Description
技术领域
本申请涉及互联网技术领域,特别是涉及一种减少跨区流量的方法、装置、计算机设备和可读存储介质。
背景技术
在物联网(Internet of Things,IoT)领域,进行联网的智能设备需要频繁的将设备的状态数据实时上报至云端,以便完成数据收集、计算和展示。这些实时数据的传递需要使用消息队列来完成,而消息队列的服务端和消费端往往都是分布在不同可用区里的多个计算节点。这就导致流量会跨区传递,造成跨区流量的费用以及数据传递的时延增加。
目前,在消息队列中,开源的版本中还没有实现控制消息是否被同一个可用区的消费端消费,而是采取随机的策略,这样消息可能会被不同可用区的消费端消费,造成不必要的跨区流量传递以及数据传输时延。
发明内容
本申请提供一种减少跨区流量的方法、装置、计算机设备和可读存储介质,以至少解决相关技术中的跨区流量较大以及数据传输时延的问题。
第一方面,本申请实施例提供了一种减少跨区流量的方法,应用于服务端,所述方法包括:
接收消费端发送的消息消费请求;
获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
比较所述消费端的可用区信息是否与自身的可用区信息一致;
根据可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求。
在其中一些实施例中,所述根据可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求包括:
若所述消费端的可用区信息与自身的可用区信息一致,则发送消息消费请求对应的消息至所述消费端;
若所述消费端的可用区信息与自身的可用区信息不一致,则获取所述消费端对应的预设跨区消费比例;
根据所述消费端的可用区信息和所述预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息。
在其中一些实施例中,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端的第一数量;
根据所述第一数量和所述预设跨区消费比例,在所述第一数量的消费端中确定出可跨区消费的消费端。
在其中一些实施例中,每一可用区的所述消费端包括多个消费节点,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端对应的消费节点的第二数量;
根据所述第二数量的消费节点和所述预设跨区消费比例,在所述第二数量的消费节点中确定出可跨区消费的消费节点。
在其中一些实施例中,所述方法还包括:对确定出的可跨区消费的消费端进行标记;在接收到消费端发送的消息消费请求后,获取所述消费端的标记信息;根据所述消费端的标记信息,确定是否允许所述消费端的消费请求。
在其中一些实施例中,所述方法还包括:检测所述消费端与所述服务端的连接状态;根据所述连接状态,指示用户调整所述预设跨区消费比例。
在其中一些实施例中,所述获取所述消费端的可用区信息包括:在与所述消费端建立连接时,获取所述消费端的可用区信息。
第二方面,本申请实施例提供了一种减少跨区流量的装置,所述装置包括:
接收模块,用于接收消费端发送的消息消费请求;
获取模块,用于获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
比较模块,用于比较所述消费端的可用区信息是否与自身的可用区信息一致;
确定模块,用于根据可用区信息比较结果,优先允许与自身的可用区信息一致的所述消费端的消费请求。
第三方面,本申请实施例提供了一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的减少跨区流量的方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上述第一方面所述的减少跨区流量的方法。
相比于相关技术,本申请实施例提供的减少跨区流量的方法,应用于服务端,包括:接收消费端发送的消息消费请求;获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;根据可用区信息比较结果,优先允许与自身的可用区信息一致的所述消费端的消费请求,解决了相关技术中的跨区流量较大,数据传输延时的问题。
本申请的一个或多个实施例的细节在以下附图和描述中提出,以使本申请的其他特征、目的和优点更加简明易懂。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1为一个实施例中提供的减少跨区流量方法的流程图;
图2为一个实施例中提供的NSQ消息队列消费端和服务端的连接示意图;
图3为一个优选实施例提供的减少跨区流量方法的交互示意图;
图4为一个实施例中提供的减少跨区流量装置的结构框图;
图5为一个实施例中计算机设备的内部结构图。
具体实施方式
为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行描述和说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。基于本申请提供的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。
显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域的普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图将本申请应用于其他类似情景。此外,还可以理解的是,虽然这种开发过程中所作出的努力可能是复杂并且冗长的,然而对于与本申请公开的内容相关的本领域的普通技术人员而言,在本申请揭露的技术内容的基础上进行的一些设计,制造或者生产等变更只是常规的技术手段,不应当理解为本申请公开的内容不充分。
在本申请中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域普通技术人员显式地和隐式地理解的是,本申请所描述的实施例在不冲突的情况下,可以与其它实施例相结合。
除非另作定义,本申请所涉及的技术术语或者科学术语应当为本申请所属技术领域内具有一般技能的人士所理解的通常意义。本申请所涉及的“一”、“一个”、“一种”、“该”等类似词语并不表示数量限制,可表示单数或复数。本申请所涉及的术语“包括”、“包含”、“具有”以及它们任何变形,意图在于覆盖不排他的包含;例如包含了一系列步骤或模块(单元)的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可以还包括没有列出的步骤或单元,或可以还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。本申请所涉及的“连接”、“相连”、“耦接”等类似的词语并非限定于物理的或者机械的连接,而是可以包括电气的连接,不管是直接的还是间接的。本申请所涉及的“多个”是指两个或两个以上。“和/或”描述关联对象的关联关系,表示可以存在三种关系,例如,“A和/或B”可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。本申请所涉及的术语“第一”、“第二”、“第三”等仅仅是区别类似的对象,不代表针对对象的特定排序。
图1为一个实施例提供的减少跨区流量的方法,如图1所示,减少跨区流量的方法包括步骤110至步骤140;其中:
步骤110,接收消费端发送的消息消费请求;
步骤120,获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
步骤130,比较所述消费端的可用区信息是否与自身的可用区信息一致;
步骤140,根据可用区信息比较结果,优先允许与自身的可用区信息一致的所述消费端的消费请求。
本申请中提供的方法应用于减少消息队列的跨区流量传输。消息队列是生产消费的模式,把数据放到消息队列的为生产端,从消息队列里边取数据的为消费端。生产端把消息生产出来推送到服务端,然后消费端去服务端去消费消息。消费端和服务端是成对出现的,服务端可以是云端。在IoT领域,进行联网的智能设备需要频繁的将智能设备的状态数据实时上报至云端,以便完成数据收集、计算和展示。其中,智能设备作为生产端,云端作为服务端,客户端即可以作为消费端,也可以作为生产端。消息队列可以是NSQ消息队列、Kafka消息队列。具体消息队列的类型本申请不作限制。以下本申请均以消息队列为NSQ消息队列为例进行说明。
NSQ消息队列的消费端和服务端的连接方式如图2所示:订阅同一个主题(topic)的所有消费端节点(消费端集群)会和该topic下服务端的所有分区(partition)建立连接。Nsqd是NSQ消息队列的一部分,用来接收、缓存、投递消息给客户端。服务启动后,有两个端口,一个提供给客户端,另一个是HTTP API。如图2所示,实线表示消费端(Consumerclient)和服务端(Nsqd server)在同一个可用区内,不会产生跨区流量;虚线表示消费端和服务端不在同一个可用区内,将会造成跨区消费,产生跨区流量。
本申请中,优先允许与自身的可用区信息一致的所述消费端的消费请求可以理解为:若共有10个消费端与服务端建立连接,其中4个消费端与服务端处于同可用区,6个消费端与服务端的可用区不同,则服务端优选允许4个同可用区消费端的消费请求,将请求的消息发送至消费端。换句话说,当有同可用区和不同可用区的消费端向服务端发送消息请求,则所有同可用区的消费端均可以消费消息时,不同可用区的消费端才有可能消费服务端的消息。
现有技术中,在NSQ消息队列中,开源的版本中还没有实现控制消息是否被同一个可用区的消费端消费,而是采取随机的策略,这就可能导致消息会被不同可用区的消费端消费,造成不必要的跨区流量传递。在其他的消息队列中,例如Kafka消息队列,在实现消息同可用区消费时,消费端先尝试从服务端进行消费,如果消费端和服务端是在同一个可用区则正常消费;如果消费端和服务端不在同一个可用区,则该跨区服务端把同可用区的服务端地址发送给消费端,消费端拿到新的同可用区的地址之后和服务端地址重新建立连接,然后进行消费。这就导致最坏的情况下,一次消息的消费需要至少两次的网络建连接才能消费,造成不必要的系统开销和消息延时。
与现有技术相比,本申请提供的减少跨区流量的方法,服务端通过获取消费端的可用区信息,根据消费端的可用区与自身可用区的一致性对比结果,决策是否允许消费端消费该服务端的消息,优先把消息投递给同一可用区的消费节点以减少消息队列消费端跨区流量,从而节省了流量费用和数据传输时延。
在其中一些实施例中,根据可用区信息比较结果,确定是否允许所述消费端消费所述服务端的消息包括:
若所述消费端的可用区信息与自身的可用区信息一致,则发送消息消费请求对应的消息至所述消费端;
若所述消费端的可用区信息与自身的可用区信息不一致,则获取所述消费端对应的预设跨区消费比例;
根据所述消费端的可用区信息和所述预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息。
消费端发起从服务端消费消息的请求,该请求具体可以是指定消费服务端中某一topic下的某一分区(partition)的消息。服务端在接收到消费端的消息请求后,对消费端的信息进行验证。获取发送消息消费请求的消费端的可用区信息,以确定该消费端的所属可用区,可用区是指服务器所在的区域。比较消费端的可用区信息与服务端的可用区信息是否一致,若一致,即消费端与服务端在同一可用区,则允许该消费端消费该服务端内的消息,服务端将消费端请求的消息发送至该消费端。若不一致,则可以直接禁止该消费端的消息消费请求,也可以根据预先设置策略选择其中的部分不同区的消费端允许跨区消费。
具体地,根据预先设置策略选择其中的部分不同区的消费端允许跨区消费过程如下:
在消费端连接服务端时消费端将其可用区信息上报给服务端,服务端统计记录所有连接的客户端的可用区信息。用户可以在配置中心自定义配置跨区消费的比例,服务端定时从配置中心获取用户设定的跨区消费比例,根据记录的所有客户端的可用区信息和获取到的跨区消费比例,在与服务端不同可用区区的消费端中选择其中的部分的消费端允许其跨区消费。
用户设定的跨区消费比例可以在[0%,100%]之间。可以理解的是,若跨区消费比例设置为0%,则完全禁止消费端的跨区消费;若跨区消费比例设置为100%,则完全允许跨区消费。通常跨区消费比例设置在10%-30%之间。
在其中一些实施例中,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端的第一数量;
根据所述第一数量和所述预设跨区消费比例,在所述第一数量的消费端中确定出可跨区消费的消费端。
本实施例中,在根据消费端的可用区信息和预设跨区消费比例确定出可跨区消费的消费端后,则确定出的消费端中的所有消费节点均允许跨区消费。
例如,服务端的可用区为A区,若连接至服务端的消费端数量为10,根据消费端的可用区信息得知,其中2个消费端的可用区为A区,与服务端处于同可用区,另外8个消费端与服务端的可用区不同。则服务端根据预设跨区消费比例在8个消费端中确定出可跨区消费的服务端。具体确定过程可以是随机选择。每一可用区的所述消费端包括多个消费节点,确定出的可跨区消费的服务端中的所有消费节点均可以消费处于A区服务端的消息。
在其中一些实施例中,每一可用区的所述消费端包括多个消费节点,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端对应的消费节点的第二数量;
根据所述第二数量的消费节点和所述预设跨区消费比例,在所述第二数量的消费节点中确定出可跨区消费的消费节点。
本实施例中,在根据消费端的可用区信息得到与服务端不同区的消费端数量,然后进一步获取每一消费端中的消费节点数量,得到与服务端不同区的所有消费节点的数量,根据预设跨区消费比例,在与服务端不同区的所有消费节点中确定出可跨区消费的消费节点。
例如,服务端的可用区为A区,若连接至服务端的消费端数量为10,根据消费端的可用区信息得知,其中2个消费端的可用区为A区,与服务端处于同可用区,另外8个消费端与服务端的可用区不同。与服务端不同区的8个消费端假设均有10个消费节点,则与服务端不同区的所有消费节点的数量为8×10=80个,根据预设跨区消费比例在80个消费节点中选择可跨区消费的消费节点。若预设跨区消费比例设置为20%,则可跨区消费的消费节点数量为80×20%=16个。这16个消费节点可以在80个消费节点中随机选择。
在其中一些实施例中,该方法还包括:对确定出的可跨区消费的消费端进行标记;在接收到消费端发送的消息消费请求后,获取所述消费端的标记信息;根据所述消费端的标记信息,确定是否允许所述消费端的消费请求。
标记信息可以是预设字符,例如字符0表示该消费端不允许跨区消费,字符1表示该消费端允许跨区消费。可以理解的是,也可以采用其他方式对消费端进行标记,本申请不作限定。
本实施例通过预先对连接至服务端的消费端进行标记,当接收到消费端的消息消费请求后,获取消费端携带的标记信息,根据标记信息就可以直接确定是否允许该消费端消费消息。
在其中一些实施例中,该方法还包括:检测所述消费端与所述服务端的连接状态;根据所述连接状态,指示用户调整所述预设跨区消费比例。
消费端与服务端的连接状态可能会发生变化,例如初始有10个消费端与服务端连接,其中5个消费端消费A分区的消息,若有其中1个消费端挂掉,断开了与服务端的连接,则可以增大该分区的跨区消费比例,以防止A分区的消息堆积。若A分区新接入了客户端,则可以适当减小该分区的跨区消费比例,尽可能减小跨区消费,从而降低跨区流量。
服务端定时在配置中心获取预设跨区消费比例,并根据最新的预设跨区消费比例和消费端数量更新可跨区消费的消费端或消费节点。
为例更好地说明本申请提供的减少跨区流量的方法,以下以NSQ消息队列的具体实施例进行说明,如图3所示:
首先管理员根据实际业务情况随时调整跨可用区流量百分比;消费端在原先服务端与消费端连接模型的基础上,获取自身的可用区信息并在与服务端连接过程中上报自身的可用区信息;NSQ服务端在内存中保留所有客户端(客户端是消费端和生产端的总称)的可用区信息;NSQ服务端定时从配置中心获取管理员设定的跨可用区百分比配置(跨区消费比例),并结合内存当中消费端的可用区信息,计算出各个消费端是否允许消费该服务端上的消息,并对消费客户端进行标记;消费端发起从该服务端消费消息的请求;NSQ服务端对该消费端进行校验,判定该消费端是否允许消费消息,如果允许消费端消费则顺利从服务端获取请求的消息,否则终止流程。
应该理解的是,虽然图1的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,图1中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些子步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
本实施例还提供了一种基于减少跨区流量的装置,该装置用于实现上述实施例及优选实施方式,已经进行过说明的不再赘述。如下所使用的,术语“模块”、“单元”、“子单元”等可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
在一个实施例中,如图4所示,提供了一种减少跨区流量的装置,包括:接收模块410、获取模块420、比较模块430和确定模块440,其中:
接收模块410,用于接收消费端发送的消息消费请求;
获取模块420,用于获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
比较模块430,用于比较所述消费端的可用区信息是否与自身的可用区信息一致,得到可用区信息比较结果;
确定模块440,用于根据可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求。
本实施例提供的减少跨区流量的装置,服务端通过获取消费端的可用区信息,根据消费端的可用区与自身可用区的一致性对比结果,决策是否允许消费端消费该服务端的消息,优先把消息投递给同一可用区的消费节点以减少消息队列消费端跨区流量,从而节省了流量费用和数据传输时延。
在其中一些实施例中,确定模块440还用于若所述消费端的可用区信息与自身的可用区信息一致,则发送消息消费请求对应的消息至所述消费端;若所述消费端的可用区信息与自身的可用区信息不一致,则获取所述消费端对应的预设跨区消费比例;根据所述消费端的可用区信息和所述预设跨区消费比例,确定是否允许所述消费端消费所述服务端的消息。
在其中一些实施例中,确定模块440还用于:获取连接所述服务端的每一所述消费端的可用区信息;根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端的第一数量;根据所述第一数量和所述预设跨区消费比例,在所述第一数量的消费端中确定出可跨区消费的消费端。
在其中一些实施例中,每一可用区的所述消费端包括多个消费节点,确定模块440还用于:获取连接所述服务端的每一所述消费端的可用区信息;根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端对应的消费节点的第二数量;根据所述第二数量的消费节点和所述预设跨区消费比例,在所述第二数量的消费节点中确定出可跨区消费的消费节点。
在其中一些实施例中,该装置还包括标记模块,用于对确定出的可跨区消费的消费端进行标记;以使服务端在接收到消费端发送的消息消费请求后,获取所述消费端的标记信息;根据所述消费端的标记信息,确定是否允许所述消费端的消费请求。
在其中一些实施例中,该装置还包括调整模块:检测所述消费端与所述服务端的连接状态;根据所述连接状态,指示用户调整所述预设跨区消费比例。
在其中一些实施例中,在与所述消费端建立连接时,获取模块420获取所述消费端的可用区信息。
关于减少跨区流量装置的具体限定可以参见上文中对于减少跨区流量方法的限定,在此不再赘述。上述减少跨区流量装置中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
另外,结合图1描述的本申请实施例减少跨区流量方法可以由计算机设备来实现。图5为根据本申请实施例的计算机设备的硬件结构示意图。
计算机设备可以包括处理器51以及存储有计算机程序指令的存储器52。
具体地,上述处理器51可以包括中央处理器(CPU),或者特定集成电路(Application Specific Integrated Circuit,简称为ASIC),或者可以被配置成实施本申请实施例的一个或多个集成电路。
其中,存储器52可以包括用于数据或指令的大容量存储器。举例来说而非限制,存储器52可包括硬盘驱动器(Hard Disk Drive,简称为HDD)、软盘驱动器、固态驱动器(SolidState Drive,简称为SSD)、闪存、光盘、磁光盘、磁带或通用串行总线(Universal SerialBus,简称为USB)驱动器或者两个或更多个以上这些的组合。在合适的情况下,存储器52可包括可移除或不可移除(或固定)的介质。在合适的情况下,存储器52可在数据处理装置的内部或外部。在特定实施例中,存储器52是非易失性(Non-Volatile)存储器。在特定实施例中,存储器52包括只读存储器(Read-Only Memory,简称为ROM)和随机存取存储器(RandomAccess Memory,简称为RAM)。在合适的情况下,该ROM可以是掩模编程的ROM、可编程ROM(Programmable Read-Only Memory,简称为PROM)、可擦除PROM(Erasable ProgrammableRead-Only Memory,简称为EPROM)、电可擦除PROM(Electrically Erasable ProgrammableRead-Only Memory,简称为EEPROM)、电可改写ROM(Electrically Alterable Read-OnlyMemory,简称为EAROM)或闪存(FLASH)或者两个或更多个以上这些的组合。在合适的情况下,该RAM可以是静态随机存取存储器(Static Random-Access Memory,简称为SRAM)或动态随机存取存储器(Dynamic Random Access Memory,简称为DRAM),其中,DRAM可以是快速页模式动态随机存取存储器(Fast Page Mode Dynamic Random Access Memory,简称为FPMDRAM)、扩展数据输出动态随机存取存储器(Extended Date Out Dynamic RandomAccess Memory,简称为EDODRAM)、同步动态随机存取内存(Synchronous Dynamic Random-Access Memory,简称SDRAM)等。
存储器52可以用来存储或者缓存需要处理和/或通信使用的各种数据文件,以及处理器51所执行的可能的计算机程序指令。
处理器51通过读取并执行存储器52中存储的计算机程序指令,以实现上述实施例中的任意一种减少跨区流量方法。
在其中一些实施例中,计算机设备还可包括通信接口53和总线50。其中,如图5所示,处理器51、存储器52、通信接口53通过总线50连接并完成相互间的通信。
通信接口53用于实现本申请实施例中各模块、装置、单元和/或设备之间的通信。通信接口53还可以实现与其他部件例如:外接设备、图像/数据采集设备、数据库、外部存储以及图像/数据处理工作站等之间进行数据通信。
总线50包括硬件、软件或两者,将计算机设备的部件彼此耦接在一起。总线50包括但不限于以下至少之一:数据总线(Data Bus)、地址总线(Address Bus)、控制总线(Control Bus)、扩展总线(Expansion Bus)、局部总线(Local Bus)。举例来说而非限制,总线50可包括图形加速接口(Accelerated Graphics Port,简称为AGP)或其他图形总线、增强工业标准架构(Extended Industry Standard Architecture,简称为EISA)总线、前端总线(Front Side Bus,简称为FSB)、超传输(Hyper Transport,简称为HT)互连、工业标准架构(Industry Standard Architecture,简称为ISA)总线、无线带宽(InfiniBand)互连、低引脚数(Low Pin Count,简称为LPC)总线、存储器总线、微信道架构(Micro ChannelArchitecture,简称为MCA)总线、外围组件互连(Peripheral Component Interconnect,简称为PCI)总线、PCI-Express(PCI-X)总线、串行高级技术附件(Serial AdvancedTechnology Attachment,简称为SATA)总线、视频电子标准协会局部(Video ElectronicsStandards Association Local Bus,简称为VLB)总线或其他合适的总线或者两个或更多个以上这些的组合。在合适的情况下,总线50可包括一个或多个总线。尽管本申请实施例描述和示出了特定的总线,但本申请考虑任何合适的总线或互连。
该计算机设备可以基于获取到的程序指令,执行本申请实施例中的减少跨区流量方法,从而实现结合图2描述的减少跨区流量的方法。
另外,结合上述实施例中的减少跨区流量的方法,本申请实施例可提供一种计算机可读存储介质来实现。该计算机可读存储介质上存储有计算机程序指令;该计算机程序指令被处理器执行时实现上述实施例中的任意一种减少跨区流量的方法。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对申请专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。
Claims (9)
1.一种减少跨区流量的方法,应用于服务端,其特征在于,所述方法包括:
接收消费端发送的消息消费请求;
获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
比较所述消费端的可用区信息是否与自身的可用区信息一致,得到可用区信息比较结果;
根据所述可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求;
其中:所述根据可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求包括:
若所述消费端的可用区信息与自身的可用区信息一致,则发送消息消费请求对应的消息至所述消费端;
若所述消费端的可用区信息与自身的可用区信息不一致,则获取所述消费端对应的预设跨区消费比例;
根据所述消费端的可用区信息和所述预设跨区消费比例,确定是否允许所述消费端的消费请求;所述预设跨区消费比例设置在10%-30%之间。
2.根据权利要求1所述的方法,其特征在于,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端的消费请求包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端的第一数量;
根据所述第一数量和所述预设跨区消费比例,在所述第一数量的消费端中确定出可跨区消费的消费端。
3.根据权利要求1所述的方法,其特征在于,每一可用区的所述消费端包括多个消费节点,所述根据所述消费端的可用区信息和预设跨区消费比例,确定是否允许所述消费端的消费请求包括:
获取连接所述服务端的每一所述消费端的可用区信息;
根据每一所述消费端的可用区信息,得到与所述服务端可用区不同的消费端对应的消费节点的第二数量;
根据所述第二数量的消费节点和所述预设跨区消费比例,在所述第二数量的消费节点中确定出可跨区消费的消费节点。
4.根据权利要求2所述的方法,其特征在于,所述方法还包括:
对确定出的可跨区消费的消费端进行标记;
在接收到消费端发送的消息消费请求后,获取所述消费端的标记信息;
根据所述消费端的标记信息,确定是否允许所述消费端的消费请求。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
检测所述消费端与所述服务端的连接状态;
根据所述连接状态,指示用户调整所述预设跨区消费比例。
6.根据权利要求1所述的方法,其特征在于,所述获取所述消费端的可用区信息包括:
在与所述消费端建立连接时,获取所述消费端的可用区信息。
7.一种减少跨区流量的装置,其特征在于,所述装置包括:
接收模块,用于接收消费端发送的消息消费请求;
获取模块,用于获取所述消费端的可用区信息,所述可用区信息用于标识所述消费端所在的可用区;
比较模块,用于比较所述消费端的可用区信息是否与自身的可用区信息一致,得到可用区信息比较结果;
确定模块,用于根据所述可用区信息比较结果,优先允许与自身可用区信息一致的所述消费端的消费请求;若所述消费端的可用区信息与自身的可用区信息一致,则发送消息消费请求对应的消息至所述消费端;
若所述消费端的可用区信息与自身的可用区信息不一致,则获取所述消费端对应的预设跨区消费比例;
根据所述消费端的可用区信息和所述预设跨区消费比例,确定是否允许所述消费端的消费请求;所述预设跨区消费比例设置在10%-30%之间。
8.一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,其特征在于,所述处理器执行所述计算机程序时实现权利要求1至6中任一项所述方法的步骤。
9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至6中任一项所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011599565.8A CN112804298B (zh) | 2020-12-29 | 2020-12-29 | 减少跨区流量的方法、装置、计算机设备和可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011599565.8A CN112804298B (zh) | 2020-12-29 | 2020-12-29 | 减少跨区流量的方法、装置、计算机设备和可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112804298A CN112804298A (zh) | 2021-05-14 |
CN112804298B true CN112804298B (zh) | 2023-05-02 |
Family
ID=75804173
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011599565.8A Active CN112804298B (zh) | 2020-12-29 | 2020-12-29 | 减少跨区流量的方法、装置、计算机设备和可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112804298B (zh) |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107197017A (zh) * | 2017-05-23 | 2017-09-22 | 努比亚技术有限公司 | 一种基于消费队列的消费方法、终端及计算机可读存储介质 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105162665B (zh) * | 2015-08-31 | 2019-01-11 | 小米科技有限责任公司 | 服务器接入方法及装置 |
WO2017063677A1 (en) * | 2015-10-13 | 2017-04-20 | Telefonaktiebolaget Lm Ericsson (Publ) | Adaptive precision for reporting consumption of streamed content |
US10499066B2 (en) * | 2017-04-14 | 2019-12-03 | Nokia Technologies Oy | Method and apparatus for improving efficiency of content delivery based on consumption data relative to spatial data |
CN108111527A (zh) * | 2017-12-29 | 2018-06-01 | 深圳市艾特智能科技有限公司 | 智能家居客户端访问请求处理方法、系统、存储介质及计算机设备 |
CN111741041B (zh) * | 2019-07-10 | 2023-05-12 | 北京京东尚科信息技术有限公司 | 消息处理方法及其装置、电子设备及计算机可读介质 |
CN110809045B (zh) * | 2019-11-05 | 2022-12-13 | 深圳市网心科技有限公司 | 一种数据通信方法及其相关设备 |
-
2020
- 2020-12-29 CN CN202011599565.8A patent/CN112804298B/zh active Active
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107197017A (zh) * | 2017-05-23 | 2017-09-22 | 努比亚技术有限公司 | 一种基于消费队列的消费方法、终端及计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN112804298A (zh) | 2021-05-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9392081B2 (en) | Method and device for sending requests | |
CN111756674B (zh) | 网络通信方法、系统、设备及计算机可读存储介质 | |
TW201822013A (zh) | 伺服器負載均衡的方法、裝置及伺服器設備 | |
CN113485822A (zh) | 内存管理方法、系统、客户端、服务器及存储介质 | |
CN110324405B (zh) | 消息发送方法、装置、系统及计算机可读存储介质 | |
CN111490947A (zh) | 数据包发送方法、数据包接收方法、系统、设备及介质 | |
CN111629371B (zh) | 投屏方法和系统 | |
CN110764688A (zh) | 对数据进行处理的方法和装置 | |
CN113163003A (zh) | 文件传输方法、云端服务器、客户端以及雾节点路由器 | |
CN113452770B (zh) | 数据同步方法、装置、计算机设备及存储介质 | |
CN112732560B (zh) | 文件描述符泄露风险的检测方法及装置 | |
CN112822299B (zh) | 基于rdma的数据传输方法、装置及电子设备 | |
CN106686635B (zh) | 基于无线接入点的控制和配置协议的数据传输方法和装置 | |
CN109471713B (zh) | 用于查询信息的方法和装置 | |
CN112804298B (zh) | 减少跨区流量的方法、装置、计算机设备和可读存储介质 | |
CN111404842B (zh) | 数据传输方法、装置及计算机存储介质 | |
CN108111431B (zh) | 业务数据发送方法、装置、计算设备及计算机可读存储介质 | |
CN112769960B (zh) | 一种基于Nginx服务器的主动流量控制方法及系统 | |
CN114363379A (zh) | 车辆数据传输的方法、装置、电子设备及介质 | |
CN113157415A (zh) | 农场渲染方法、装置、电子设备和存储介质 | |
CN112686599A (zh) | 请求响应方法、装置、系统、电子设备和计算机可读介质 | |
CN112055058A (zh) | 数据的存储方法、装置及计算机可读存储介质 | |
CN114979153B (zh) | 负载均衡方法、计算机设备及存储装置 | |
CN113873036B (zh) | 一种通信方法、装置、服务器及存储介质 | |
CN109491948B (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 |