CN112910975A - 请求的处理方法、装置和电子设备 - Google Patents
请求的处理方法、装置和电子设备 Download PDFInfo
- Publication number
- CN112910975A CN112910975A CN202110084723.4A CN202110084723A CN112910975A CN 112910975 A CN112910975 A CN 112910975A CN 202110084723 A CN202110084723 A CN 202110084723A CN 112910975 A CN112910975 A CN 112910975A
- Authority
- CN
- China
- Prior art keywords
- request
- target
- traffic
- restrictor
- determining
- 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
- 238000003672 processing method Methods 0.000 title description 10
- 238000000034 method Methods 0.000 claims abstract description 38
- 238000012545 processing Methods 0.000 claims abstract description 28
- 230000004044 response Effects 0.000 claims description 24
- 238000004590 computer program Methods 0.000 claims description 9
- 238000012216 screening Methods 0.000 claims description 5
- 238000010586 diagram Methods 0.000 description 11
- 230000006870 function Effects 0.000 description 9
- 238000004891 communication Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 8
- 230000003287 optical effect Effects 0.000 description 6
- 238000005516 engineering process Methods 0.000 description 5
- 238000011161 development Methods 0.000 description 4
- 230000010365 information processing Effects 0.000 description 3
- 238000004364 calculation method Methods 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 230000003111 delayed effect Effects 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 230000002159 abnormal effect Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012958 reprocessing Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
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/50—Network services
- H04L67/60—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本公开实施例公开了的请求的处理方法、装置和电子设备,通过为每一个上层业务均设置对应的业务限流器,因此,在接收到请求时,会根据请求的类型确定目标请求待进入的业务限流器,而业务限流器可以对针对具体每个业务的请求进行限流;也即,保证针对每个业务的请求量均在一定的阈值范围内,从而可以使得针对某一个上层业务的请求均不会出现暴增的情况,也就保证了针对各个上层业务均可能被处理,换言之,也就避免了请求量激增,而造成某类上层业务无法被处理的现象。
Description
技术领域
本公开涉及互联网技术领域,尤其涉及一种请求的处理方法、装置和电子设备。
背景技术
随着网络技术的革新,互联网服务得到了长足的发展,而在微服务架构下,为了确保系统的文档性和可用性,在系统的入口处会根据系统的承载能力对访问接口进行限流,从而以达到保护系统的安全稳定运行的目的。
发明内容
提供该公开内容部分以便以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。该公开内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
本公开实施例提供了一种请求的处理方法、装置和电子设备,可以避免因为某类业务的请求量突然暴增,而造成其它业务的请求无法被处理的现象。
第一方面,本公开实施例提供了一种请求的处理方法,包括:响应于接收到目标请求,确定上述目标请求对应的目标请求类型;从至少一个业务限流器中,确定与上述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,上述目标请求类型与上述目标业务限流器对应;利用上述目标业务限流器确定是否输出上述目标请求。
第二方面,本公开实施例提供了一种请求的处理装置,包括:第一确定单元,用于响应于接收到目标请求,确定上述目标请求对应的目标请求类型;第二确定单元,用于从至少一个业务限流器中,确定出与上述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,上述目标请求类型与上述目标业务限流器对应;筛选单元,利用上述目标业务限流器确定是否输出上述目标请求。
第三方面,本公开实施例提供了一种电子设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当上述一个或多个程序被上述一个或多个处理器执行,使得上述一个或多个处理器实现如第一方面上述的请求的处理方法。
第四方面,本公开实施例提供了一种计算机可读介质,其上存储有计算机程序,该程序被处理器执行时实现如第一方面上述的请求的处理方法的步骤。
本公开实施例提供的请求的处理方法、装置和电子设备,通过为每一个上层业务均设置对应的业务限流器,因此,在接收到请求时,会根据请求的类型确定目标请求待进入的业务限流器,而业务限流器可以对针对具体每个业务的请求进行限流;也即,保证针对每个业务的请求量均在一定的阈值范围内,从而可以使得针对某一个上层业务的请求均不会出现暴增的情况,也就保证了针对各个上层业务均可能被处理,换言之,也就避免了请求量激增,而造成某类上层业务无法被处理的现象。
附图说明
结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。
图1是根据本公开的请求的处理方法的一个实施例的流程图;
图2是根据本公开的请求的处理方法的一个实施例的限流器的连接示意图;
图3是根据本公开的请求的处理装置的一个实施例的结构示意图;
图4是本公开的一个实施例的请求的处理方法可以应用于其中的示例性系统架构;
图5是根据本公开实施例提供的电子设备的基本结构的示意图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
应当理解,本公开的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本公开的范围在此方面不受限制。
本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
请参考图1,其示出了根据本公开的请求的处理方法的一个实施例的流程。该请求的处理方法可以应用于终端设备。
为了更好的理解本公开所提供的思想,在介绍本公开所提供思想之前,先对本公开的应用场景进行简单的阐述。
互联网技术和业务的快速发展,会使得上层业务的发展速度与底层数据之间的发展速度出现不匹配的现象。举例说明,某一用于浏览新闻的应用,在该应用开始创建时,上层业务可能仅有用于观看新闻的业务,而低层数据则可能包括用于展示新闻窗口的数据、用于记录新闻内容(时间、对象等)的数据等。而随着技术的进步,该应用的上层业务可以还可以观看直播、观看小视频等,若此时为新增加的业务又增加全部的底层数据,则可能延迟这些上层业务更新换代的时间。因此,新增加的业务也可以利用一些原有的底层数据,例如,新增加的业务可以利用原有的用于记录新闻内容(时间、对象等)的数据等。再如,某一直播应用,在该直播应用开始创建时,为主播打赏的礼物仅有礼物A,而后,又增加了礼物B、礼物C等,因此,礼物B、礼物C则与礼物A共用用于记录礼物结算方式的数据、用于记录打赏方式方面的数据等。又如,某一打车应用,在打车应用最开始创建时,上层业务可能仅有打快车的业务,底层数据可能包括用于路程计算的数据、用于费用计算的数据、用于费用结算的数据等。而随着时代的发展,可能该应用的上层业务会发展出打专车的业务、拼车的业务等,而此时,若为这新增两个业务又新增全部的底层数据,无疑会延缓这些上层业务更新换代的时间。因此,新增的上层业务,也会利用一些原有的底层数据。例如,新增的专车业务和拼车业务,也可以利用原有的用于路程计算的数据、用于费用计算的数据、用于费用结算的数据等。
为了实现上层业务与底层数据的匹配,会进行中台代建,从而保证新增加的上层业务也可利用一些原有的底层数据,但是,随着上层业务的快速发展,为了保证每个上层业务的请求都能被顺利处理,还需要对上层业务的请求量进行限制,从而避免某一个上层业务的请求量过大,而造成其他上层业务的请求无法被底层数据处理的情况。为了实现这一目的,本公开提供了如图1所示该请求的处理方法,包括以下步骤:
步骤101,响应于接收到目标请求,确定目标请求对应的目标请求类型。
在本实施例中,目标请求类型可以理解为用于指示需要请求的业务类型或者具体业务。作为示例,当应用为新闻应用时,请求类型可以包括请求文字新闻、请求视频直播、请求小视频等,再如,应用为打车应用时,请求类型可以包括请求快车业务、请求拼车业务、请求专车业务等中的一个或者多个。
步骤102,从至少一个业务限流器中,确定与目标请求对应的目标业务限流器。
在这里,业务限流器与请求类型对应,目标请求类型与目标业务限流器对应。
在本实施例中,即可根据目标请求对应的请求类型确定出与目标请求对应的目标业务限流器。
作为示例,业务限流器与请求类型可以为一一对应关系,也即,一个业务限流器可以对应一个请求类型,换言之,也可以理解为一种类型请求业务对应了一个业务限流器。
步骤103,利用目标限流器确定是否输出目标请求。
步骤101-步骤103,通过为每种类型的业务请求均设定一个业务限流器,可以使得每种类型的业务请求均保持在一定的阈值范围内,从而不会因为某一业务类型的请求量突然暴增,而造成其它业务类型的请求无法被处理的现象。
在一些实施例中,一个应用有多个不同的上层业务,因此,为了避免某一个上层业务的请求量突然暴增,而造成该应用其它上层业务的请求无法被处理的现象,可以针对每个上层业务的请求均设定一个限流器。换言之,由于每一个请求类型均对应一个业务限流器,从而可以确保针对每一个上层业务的请求,均不会超过预先设定的阈值。
例如,某个应用有3个上层业务(上层业务A、上层业务B、上层业务C),则可以针对这3个上层业务的请求量进行限定,也即,可以为这3个上层业务均可以设置一个业务限流器,而每个上层业务各自对应的限流器中设置了该上层业务的请求量阈值。如,针对上层业务A设定一个请求量阈值A、针对上层业务B设定一个请求量阈值B、针对上层业务C设定一个请求量阈值C。
需要说明的是,请求量阈值A、请求量阈值B、请求量阈值C的具体数值可以根据实际情况进行设定,且请求量阈值A、请求量阈值B、请求量阈值C的具体数值可以相同也可以不同。
若某个用户需要应用上层业务A,因此,则可以发送一个请求应用上层业务A的请求,此时,则可以通过与上层业务A对应的业务限流器对该请求进行筛选。作为示例,当与上层业务A对应的业务限流器中的请求量已经大于预设值时,则可以不输出该请求,以确保其它业务(上层业务B、上层业务C)的请求可以被处理。在一些实施例中,不输出该请求可以理解为直接拒绝该请求,也即,请求服务终止。在一些实施例中,不输出该请求也可以理解为该请求进行排序,也即,该请求可能会被执行,仅是,当前并不执行该请求,当限流器中的请求量在预设时间段内小于了请求量阈值,则该请求还可被执行,换言之,此时可以理解为请求服务中止。
可以看出,通过为每一个上层业务均设置对应的业务限流器,因此,在接收到请求时,会根据请求的类型确定目标请求待进入的业务限流器,而业务限流器可以对针对具体每个业务的请求进行限流;也即,保证针对每个业务的请求量均在一定的阈值范围内,从而可以使得针对某一个上层业务的请求均不会出现暴增的情况,也就保证了针对各个上层业务均可能被处理,换言之,也就避免了某些上层业务无法被处理的现象。
在一些实施例中,步骤103(利用目标限流器确定是否输出目标请求)具体可以包括:
目标业务限流器响应于确定当前业务请求量小于目标业务限流器的请求量阈值,目标业务限流器确定输出目标请求。
目标业务限流器响应于确定当前业务请求量不小于目标业务限流器的请求量阈值,目标业务限流器确定不输出目标请求。
在一些实施例中,目标业务限流器的当前业务请求量小于目标业务限流器的请求量阈值时,则可以表征底层数据(处理器用于处理请求的部分)此时还可以处理与目标请求类型相关的请求业务,因此,此时可以目标业务限流器可以输出目标请求。而当目标业务限流器的当前业务请求量不小于目标业务限流器的请求量阈值时,则可以表征此时再处理目标业务类型的请求,则可能会导致针对其它业务的请求无法被处理,进而目标业务限流器将不输出目标请求,以保证其它请求可以被顺利处理。
需要说明的是,目标业务限流器的请求量阈值可以根据实际应用场景进行限定。此处并不对目标业务限流器的请求量阈值进行限定。
在一些实施例中,可以通过如下方式确定目标业务限流器的请求量阈值:
获得目标业务限流器的配置参数,根据第一限流器的请求量阈值和获得的配置参数,确定目标业务限流器的请求量阈值。
在这里,配置参数可以包括目标业务限流器的请求量阈值与第一限流器的请求量阈值的比例关系。
在这里,第一限流器用于接收业务限流器输出的请求。
在一些实施例中,当底层数据一次性处理大量的待处理请求时,则可能导致底层数据一时无法处理完这些请求。换言之,处理器一次性处理较多的业务请求时,则可能出现处理缓慢的现象,导致该应用出现卡顿的现象,甚至可能使得该应用对应的终端出现宕机的现象。因此,为了缓解处理器在处理业务请求时的压力,可以对进入处理器被处理的请求的总量进行限制。
在一些实施例中,第一限流器限定了能够被处理的请求的总量,而业务限流器则限定了处理器最多能处理单类上层业务的请求的总量。因此,第一限流器的请求量阈值可以大于业务限流器的请求量阈值。换言之,第一限流器的设定是为了缓解处理器的处理压力,业务限流器的设定可以使得处理器可以同时处理不同业务类型的请求。
在一些实施例中,目标业务限流器的请求量阈值可以根据历史情况进行设定。相应的,每个业务限流器的请求量阈值均可以根据历史情况进行设定,例如,可以根据在历史一段时间内,接收到的针对每个上层业务的请求量来设定各业务限流器的请求量阈值。如在历史一段时间内,同时在业务限流器A中(上层业务A对应的限流器)存在的上层业务A的请求数量为500,同时在业务限流器B中(上层业务B对应的限流器)存在的上层业务A的请求数量为1000,同时在业务限流器C中(上层业务C对应的限流器)存在的上层业务C的请求数量为1500,由此可见,则可以将业务限流器A的请求量阈值:业务限流器B的请求量阈值:业务限流器C的请求量阈值设置为1:2:3。若第一限流器的请求量阈值为6000,则业务限流器A的请求量阈值可以为1000,业务限流器B的请求量阈值可以为2000,业务限流器C的请求量阈值可以为3000。当然,再具体实时方式中,还可以根据其他方式设定各个业务限流器的请求量阈值。
作为示例,还可以人为设定某一业务限流器的请求量阈值,也即,工作人员可以根据实际需要,为每个业务限流器设定配置参数。
例如,当某个上层业务可能会突然增加访问时(以应用为新闻应用举例,当直播业务举办活动时,则可能访问直播业务的请求将会增加),可以先将该上层业务对应的业务限流器的请求量阈值设置得稍微大一些,则可以使得较多针对该上层业务的请求能被处理。
在一些实施例中,第一限流器的限流阈值可以根据处理器的处理能力进行设定(可以根据处理器一次性可以处理的最大请求量进行设定),当然,在具体实施方式中,第一限流器的限流阈值也可根据其它方式进行限定,如,工作人员进行设定。在此并不对第一限流器的限流阈值进行限定,仅需根据实际情况进行合理设定即可。
在一些实施例中,获取目标业务限流器的请求量阈值与第一限流器的请求量阈值的预设比例值,根据第一限流器的请求量阈值的预设比例值,确定目标业务限流器的请求量阈值。
在一些实施例中,目标业务限流器可能是一个新上线的业务,因此,可能没有关于目标业务请求的历史数据作为参考。此时,则可以利用业务限流器的请求量阈值与第一限流器的请求量阈值之间的预设比例值,确定出目业务员限流器的请求量阈值。作为示例,预设比例值可以为设定为80%。
相应的,在一个应用推广初期,多个上层业务可能没有历史数据用于参考,也即,无法根据历史数据设定配置参数。此时,可以根据业务限流器的请求量阈值与第一限流器的请求量阈值之间的比例关系,确定出每个业务限流器的请求量阈值。当然,在具体实施方式中,业务限流器的请求量阈值与第一限流器的请求量阈值的预设比例值可以根据实际情况进行限定。
在一些实施例中,在目标限流器输出目标请求之后,可以利用第一限流器判断是否输出目标请求。
在这里,第一限流器用于接收业务限流器输出的请求。
在一些实施例中,由于设置第一限流器的目的是为了保证底层数据可以流畅的处理请求,因此,当此时的请求量小于预设的请求量阈值时,则可以输出目标请求,而请求量不小于预设的请求量阈值时,则可以不输出目标请求,从而处理器可以高效的处理请求。
在一些实施例中,第一限流器响应于确定当前请求量不小于预设第一数量阈值,第一限流器根据目标请求类型判断是否输出目标请求。
在本实施例中,第一数量阈值可以小于等于第一限流器的请求量阈值。
在一些实施例中,第一限流器的请求量阈值可以理解为处理器最大执行能力,而第一数量阈值的设定是为了满足一些重要的上层业务,例如,应用为新闻应用,重要的上层业务可以理解为窗口业务;再如,应用为打车应用时,重要的上层业务可以理解为结算业务。也即,当达到第一数量阈值之后,不是重要的上层业务,第一限流器将不会进行输出,而重要的上层业务则可以继续进行输出。换言之,当请求量没有达到第一限流器的请求量阈值时,第一限流器会目标请求,而当请求量达到第一数量阈值时,则可以根据目标请求的请求类型确定是否输出该目标请求。
在一些实施例中,第一限流器响应于确定目标请求类型为第一预设请求类型,输出目标请求至第二限流器,第一限流器响应于确定目标请求类型不为第一预设请求类型,不输出目标请求。
在这里,第二限流器用于接收请求类型为第一预设请求类型的请求。
在一些实施例中,第一预设请求类型中的请求类型可以理解为重要上层业务对应的请求类型。举例说明,某个应用对应三个上层业务(上层业务A、上层业务B、上层业务C),如上层业务A是重要的上层业务,当第一限流器的请求量达到第一数量阈值之后,若目标请求是针对上层业务A的请求,则第一限流器会输出目标请求,若标请求是针对上层业务B的请求,则第一限流器不会输出目标请求。而与上层业务A对应的请求类型则在第一预设请求类型内。
在一些实施例中,当第一限流器响应于确定目标请求类型为第一预设请求类型,输出目标请求至第二限流器之后,利用第二限流器判断是否输出目标请求。
在一些实施例中,第二限流器也对应了一个限流阈值,而第二限流器的限流阈值也可根据实际情况进行设定。作为示例,第二限流器的限流阈值加上第一数量阈值,可以不小于第一限流器的限流阈值。而为第二限流器设定限流阈值,也可保证处理器不会超负荷运行,从而保证了请求被处理的效率。
在一些实施例中,在步骤101(确定目标请求所指示的目标请求类型)之后,响应于确定第二预设请求类型集合不包括目标请求类型,利用第三限流器丢弃目标请求。
在这里,第二预设请求类型集合包括至少一个业务限流器中每个业务限流器对应的请求类型,通过上述第三限流器输出的请求进入业务限流器。
在一些实施例中,由于每一个上层业务均设置了对应的业务限流器,而每个上层业务对应的请求的请求类型均包括在第二预设请求类型集合内,若目标请求在第二预设请求类型集合内,则可以表征目标请求是一个非法请求,此时则可以直接将目标请求进行丢弃。
在一些实施例中,将目标请求进行丢弃可以理解为直接拒绝目标请求。
为了更好的理解本公开所提供的思想,请参阅图2,图2提供了本公开个限流器的连接示意图,目标请求被处理,至少需要经过三个限流器(第三限流器、业务限流器和第一限流器),而具体进入那个业务限流器则可以根据目标请求的类型进行判断。若第一限流器中的当前业务请求量不小于第一数量阈值,且目标请求类型在预设第一请求类型集合内,目标请求还会进入第二限流层进行筛选。可以看出,在本公开中,通过设置第三限流器,可以丢弃非正常的请求,通过设置业务限流器,可以保证没类上层业务均能被处理,通过设置第一限流器,可以缓解处理器的处理压力,而通过设置第二限流器,则可以保证重要的业务可以被优先处理。通过这样的设计,在保证多个业务都能被处理的同时,保证了重要客户可以被优先处理,并可以提升处理器处理请求的效率。
进一步参考图3,作为对上述各图所示方法的实现,本公开提供了一种请求的处理装置的一个实施例,该装置实施例与图1所示的请求的处理方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图3所示,本实施例的请求的处理装置包括:
第一确定单元301,用于响应于接收到目标请求,确定上述目标请求对应的目标请求类型;第二确定单元302,用于从至少一个业务限流器中,确定出与上述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,上述目标请求类型与上述目标业务限流器对应;筛选单元303,利用上述目标业务限流器确定是否输出上述目标请求。
在一些实施例中,上述目标业务限流器响应于确定当前业务请求量小于上述目标业务限流器的请求量阈值,上述目标业务限流器确定输出上述目标请求;上述目标业务限流器响应于确定当前业务请求量不小于上述目标业务限流器的请求量阈值,上述目标业务限流器确定不输出上述目标请求。
在一些实施例中,通过如下方式确定上述目标业务限流器的请求量阈值:获得上述目标业务限流器的配置参数,其中,配置参数包括上述目标业务限流器的请求量阈值与第一限流器的请求量阈值的比例关系,上述第一限流器用于接收业务限流器输出的请求;根据上述第一限流器的请求量阈值和获得的配置参数,确定上述目标业务限流器的请求量阈值。
在一些实施例中,在上述目标限流器输出上述目标请求之后,上述装置还包括输出单元304,用于利用第一限流器判断是否输出上述目标请求,其中,上述第一限流器用于接收业务限流器输出的请求。
在一些实施例中,上述第一限流器响应于确定当前请求量不小于预设第一数量阈值,上述第一限流器根据上述目标请求类型判断是否输出上述目标请求。
在一些实施例中,上述第一限流器响应于确定上述目标请求类型为第一预设请求类型,输出上述目标请求至第二限流器,其中,上述第二限流器用于接收请求类型为上述第一预设请求类型的请求;上述第一限流器响应于确定上述目标请求类型不为上述第一预设请求类型,不输出上述目标请求。
在一些实施例中,上述输出单元304具体还用于利用上述第二限流器判断是否输出上述目标请求。
在一些实施例中,在确定上述目标请求所指示的目标请求类型之后,上述输出单元304具体还用于:响应于确定第二预设请求类型集合不包括上述目标请求类型,利用第三限流器丢弃上述目标请求,其中,上述第二预设请求类型集合包括上述至少一个业务限流器中每个业务限流器对应的请求类型,通过上述第三限流器输出的请求进入业务限流器。
请参考图4,图4示出了本公开的一个实施例的请求的处理方法可以应用于其中的示例性系统架构。
如图4所示,系统架构可以包括终端设备401、402、403,网络404,服务器405。网络404可以用以在终端设备401、402、403和服务器405之间提供通信链路的介质。网络404可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
终端设备401、402、403可以通过网络404与服务器405交互,以接收或发送消息等。终端设备401、402、403上可以安装有各种客户端应用,例如网页浏览器应用、搜索类应用、新闻资讯类应用。终端设备401、402、403中的客户端应用可以接收用户的指令,并根据用户的指令完成相应的功能,例如根据用户的指令在信息中添加相应信息。
终端设备401、402、403可以是硬件,也可以是软件。当终端设备401、402、403为硬件时,可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture Experts Group Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving Picture Experts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。当终端设备401、402、403为软件时,可以安装在上述所列举的电子设备中。其可以实现成多个软件或软件模块(例如用来提供分布式服务的软件或软件模块),也可以实现成单个软件或软件模块。在此不做具体限定。
服务器405可以是提供各种服务的服务器,例如接收终端设备401、402、403发送的信息获取请求,根据信息获取请求通过各种方式获取信息获取请求对应的展示信息。并展示信息的相关数据发送给终端设备401、402、403。
需要说明的是,本公开实施例所提供的信息处理方法可以由终端设备执行,相应地,请求的处理装置可以设置在终端设备401、402、403中。此外,本公开实施例所提供的信息处理方法还可以由服务器404执行,相应地,信息处理装置可以设置于服务器405中。
应该理解,图4中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图5,其示出了适于用来实现本公开实施例的电子设备(例如图4中的终端设备或服务器)的结构示意图。本公开实施例中的终端设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图5示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图5所示,电子设备可以包括处理装置(例如中央处理器、图形处理器等)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储装置408加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理。在RAM 503中,还存储有电子设备500操作所需的各种程序和数据。处理装置501、ROM502以及RAM503通过总线504彼此相连。输入/输出(I/O)接口504也连接至总线504。
通常,以下装置可以连接至I/O接口505:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置506;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置507;包括例如磁带、硬盘等的存储装置508;以及通信装置509。通信装置509可以允许电子设备与其他设备进行无线或有线通信以交换数据。虽然图5示出了具有各种装置的电子设备,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置509从网络上被下载和安装,或者从存储装置508被安装,或者从ROM502被安装。在该计算机程序被处理装置501执行时,执行本公开实施例的方法中限定的上述功能。
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
在一些实施方式中,客户端、服务器可以利用诸如HTTP(HyperText TransferProtocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“LAN”),广域网(“WAN”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:响应于接收到目标请求,确定上述目标请求对应的目标请求类型;从至少一个业务限流器中,确定与上述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,上述目标请求类型与上述目标业务限流器对应;利用上述目标业务限流器确定是否输出上述目标请求。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括但不限于面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,单元的名称在某种情况下并不构成对该单元本身的限定,例如,第一确定单元401还可以被描述为“确定上述目标请求对应的目标请求类型”。
本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、片上系统(SOC)、复杂可编程逻辑设备(CPLD)等等。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本公开的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。
Claims (11)
1.一种请求的处理方法,其特征在于,包括:
响应于接收到目标请求,确定所述目标请求对应的目标请求类型;
从至少一个业务限流器中,确定与所述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,所述目标请求类型与所述目标业务限流器对应;
利用所述目标业务限流器确定是否输出所述目标请求。
2.根据权利要求1所述方法,其特征在于,所述利用所述目标业务限流器确定是否输出所述目标请求,包括:
所述目标业务限流器响应于确定当前业务请求量小于所述目标业务限流器的请求量阈值,所述目标业务限流器确定输出所述目标请求;
所述目标业务限流器响应于确定当前业务请求量不小于所述目标业务限流器的请求量阈值,所述目标业务限流器确定不输出所述目标请求。
3.根据权利要求2所述方法,其特征在于,通过如下方式确定所述目标业务限流器的请求量阈值:
获得所述目标业务限流器的配置参数,其中,配置参数包括所述目标业务限流器的请求量阈值与第一限流器的请求量阈值的比例关系,所述第一限流器用于接收业务限流器输出的请求;
根据所述第一限流器的请求量阈值和获得的配置参数,确定所述目标业务限流器的请求量阈值。
4.根据权利要求2所述方法,其特征在于,在所述目标限流器输出所述目标请求之后,所述方法还包括:
利用第一限流器判断是否输出所述目标请求,其中,所述第一限流器用于接收业务限流器输出的请求。
5.根据权利要求4所述方法,其特征在于,所述利用第一限流器判断是否输出所述目标请求,包括:
所述第一限流器响应于确定当前请求量不小于预设第一数量阈值,所述第一限流器根据所述目标请求类型判断是否输出所述目标请求。
6.根据权利要求5所述方法,其特征在于,所述第一限流器根据所述目标请求类型判断是否输出所述目标请求,包括:
所述第一限流器响应于确定所述目标请求类型为第一预设请求类型,输出所述目标请求至第二限流器,其中,所述第二限流器用于接收请求类型为所述第一预设请求类型的请求;
所述第一限流器响应于确定所述目标请求类型不为所述第一预设请求类型,不输出所述目标请求。
7.根据权利要求6所述的方法,其特征在于,在所述输出所述目标请求至第二限流器之后,所述方法还包括:
利用所述第二限流器判断是否输出所述目标请求。
8.根据权利要求1所述方法,其特征在于,在确定所述目标请求所指示的目标请求类型之后,所述方法还包括:
响应于确定第二预设请求类型集合不包括所述目标请求类型,利用第三限流器丢弃所述目标请求,其中,所述第二预设请求类型集合包括所述至少一个业务限流器中每个业务限流器对应的请求类型,所述第三限流器输出的请求进入业务限流器。
9.一种请求的处理装置,其特征在于,包括:
第一确定单元,用于响应于接收到目标请求,确定所述目标请求对应的目标请求类型;
第二确定单元,用于从至少一个业务限流器中,确定出与所述目标请求对应的目标业务限流器,其中,业务限流器与请求类型对应,所述目标请求类型与所述目标业务限流器对应;
筛选单元,利用所述目标业务限流器对所述目标请求进行筛选处理。
10.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-8中任一所述的方法。
11.一种计算机可读介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-8中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110084723.4A CN112910975A (zh) | 2021-01-21 | 2021-01-21 | 请求的处理方法、装置和电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110084723.4A CN112910975A (zh) | 2021-01-21 | 2021-01-21 | 请求的处理方法、装置和电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112910975A true CN112910975A (zh) | 2021-06-04 |
Family
ID=76118244
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110084723.4A Pending CN112910975A (zh) | 2021-01-21 | 2021-01-21 | 请求的处理方法、装置和电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112910975A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113518041A (zh) * | 2021-06-15 | 2021-10-19 | 新华三大数据技术有限公司 | 一种报文处理方法及装置 |
CN115037799A (zh) * | 2022-06-01 | 2022-09-09 | 阿里巴巴(中国)有限公司 | 限流方法、装置、设备及介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20190182168A1 (en) * | 2017-12-11 | 2019-06-13 | International Business Machines Corporation | Dynamic throttling thresholds |
CN110061930A (zh) * | 2019-02-01 | 2019-07-26 | 阿里巴巴集团控股有限公司 | 一种数据流量的限制、限流值的确定方法和装置 |
CN111600930A (zh) * | 2020-04-09 | 2020-08-28 | 网宿科技股份有限公司 | 微服务请求的流量管理方法、装置、服务器及存储介质 |
CN111831448A (zh) * | 2020-07-16 | 2020-10-27 | 北京字节跳动网络技术有限公司 | 请求的处理方法、装置和电子设备 |
-
2021
- 2021-01-21 CN CN202110084723.4A patent/CN112910975A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20190182168A1 (en) * | 2017-12-11 | 2019-06-13 | International Business Machines Corporation | Dynamic throttling thresholds |
CN110061930A (zh) * | 2019-02-01 | 2019-07-26 | 阿里巴巴集团控股有限公司 | 一种数据流量的限制、限流值的确定方法和装置 |
CN111600930A (zh) * | 2020-04-09 | 2020-08-28 | 网宿科技股份有限公司 | 微服务请求的流量管理方法、装置、服务器及存储介质 |
CN111831448A (zh) * | 2020-07-16 | 2020-10-27 | 北京字节跳动网络技术有限公司 | 请求的处理方法、装置和电子设备 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113518041A (zh) * | 2021-06-15 | 2021-10-19 | 新华三大数据技术有限公司 | 一种报文处理方法及装置 |
CN113518041B (zh) * | 2021-06-15 | 2023-05-16 | 新华三大数据技术有限公司 | 一种报文处理方法及装置 |
CN115037799A (zh) * | 2022-06-01 | 2022-09-09 | 阿里巴巴(中国)有限公司 | 限流方法、装置、设备及介质 |
CN115037799B (zh) * | 2022-06-01 | 2024-01-05 | 阿里巴巴(中国)有限公司 | 限流方法、装置、设备及介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112379982B (zh) | 任务处理方法、装置、电子设备及计算机可读存储介质 | |
CN110633126B (zh) | 信息显示方法、装置和电子设备 | |
CN111246228B (zh) | 直播间礼物资源更新方法、装置、介质及电子设备 | |
CN112910975A (zh) | 请求的处理方法、装置和电子设备 | |
CN111596991A (zh) | 交互操作执行方法、装置和电子设备 | |
CN111163324A (zh) | 信息处理方法、装置和电子设备 | |
CN111596992B (zh) | 导航栏展示方法、装置和电子设备 | |
CN111831448A (zh) | 请求的处理方法、装置和电子设备 | |
CN111798251A (zh) | 房源数据的验证方法、装置和电子设备 | |
CN111259291A (zh) | 视图展示方法、装置和电子设备 | |
CN115600964A (zh) | 语音审批方法、装置及相关设备 | |
CN114745276B (zh) | 交换机带宽调整方法、装置、电子设备和计算机可读介质 | |
CN115378878B (zh) | Cdn的调度方法、装置、设备及存储介质 | |
CN111756833B (zh) | 节点处理方法、装置、电子设备及计算机可读介质 | |
CN113660699A (zh) | 一种智能集群联网方法、装置及电子设备 | |
CN113518183A (zh) | 摄像头调用方法、装置和电子设备 | |
CN111538721A (zh) | 账号处理方法、装置、电子设备及计算机可读存储介质 | |
CN112162682A (zh) | 内容显示方法、装置、电子设备及计算机可读存储介质 | |
CN112214665A (zh) | 内容展示方法、装置、电子设备及计算机可读存储介质 | |
CN115379243B (zh) | Cdn的调度方法、装置、设备及存储介质 | |
CN116800834B (zh) | 虚拟礼物合并方法、装置、电子设备和计算机可读介质 | |
CN111625707B (zh) | 推荐应答方法、装置、介质和设备 | |
CN116107930A (zh) | 缓存数据发送方法、装置、电子设备和计算机可读介质 | |
CN117156401A (zh) | 数据传输方法、装置、可读介质及电子设备 | |
CN117880608A (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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20210604 |
|
RJ01 | Rejection of invention patent application after publication |