CN108600121A - 网络终端设备中实现单用户上行、下行限速的方法及设备 - Google Patents
网络终端设备中实现单用户上行、下行限速的方法及设备 Download PDFInfo
- Publication number
- CN108600121A CN108600121A CN201810274288.XA CN201810274288A CN108600121A CN 108600121 A CN108600121 A CN 108600121A CN 201810274288 A CN201810274288 A CN 201810274288A CN 108600121 A CN108600121 A CN 108600121A
- Authority
- CN
- China
- Prior art keywords
- user
- speed limit
- data packet
- downlink
- network
- 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
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/70—Admission control; Resource allocation
- H04L47/76—Admission control; Resource allocation using dynamic resource allocation, e.g. in-call renegotiation requested by the user or requested by the network in response to changing network conditions
- H04L47/762—Admission control; Resource allocation using dynamic resource allocation, e.g. in-call renegotiation requested by the user or requested by the network in response to changing network conditions triggered by the network
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种网络终端设备中实现单用户上行、下行限速的方法及设备,涉及网络终端设备的QoS领域。该方法包括:当有上行数据包进入或有下行数据包将离开时,网络终端设备将判断该数据包对应的用户是否为新用户,若是则为其建立限速数据库;当后续再有上行数据包进入或有下行数据包将离开时,网络终端设配判断数据包与基准时刻的时刻差是否超过指定时间,若是,则根据指定时间内用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;否则,根据计算的时刻差内的速率以及配置的限速值来确定是否转发该数据包。本发明能有效解决因某个用户占用过大网络带宽,导致其他用户网络服务体验变差的问题。
Description
技术领域
本发明涉及网络终端设备的QoS(Quality of Service,服务质量)领域,具体来讲是一种网络终端设备中实现单用户上行、下行限速的方法及设备。
背景技术
网络终端设备(network terminal equipment)是一种专用于网络计算环境下的终端设备。一般来说,用户会通过连接网络终端设备来获取网络服务。但是,实际应用中,当网络带宽有限,而用户数又增大到一定程度时,可能会存在某个用户占用过大的网络带宽,导致其他用户的网络服务体验变差的问题。
因此,本领域技术人员亟需一种方案能根据实际用户需求,单独配置和限定各个用户能使用的上行、下行最大带宽,以解决上述技术问题。
发明内容
本发明的目的是为了克服上述背景技术的不足,提供一种网络终端设备中实现单用户上行、下行限速的方法及设备,能根据实际用户需求,单独配置和限定各个用户能使用的上行、下行最大带宽,有效解决了因某个用户占用过大的网络带宽,导致其他用户的网络服务体验变差的问题。
为达到以上目的,本发明提供一种网络终端设备中实现单用户上行、下行限速的方法,包括以下步骤:
A、当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备将判断该数据包对应的用户是否为新用户,若是新用户,则为其建立限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;否则,直接进入步骤B;
B、当后续再有上行数据包进入或有下行数据包将离开时,网络终端设配将比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
在上述技术方案的基础上,步骤A中建立的限速数据库包括以下数据段:该用户的MAC地址、该用户的基准时刻、限速值、指定时间内该用户上行或下行字节数变量;其中,该用户的基准时刻初始化为该数据包到达的时刻,限速值供用户进行配置,指定时间内该用户上行或下行字节数变量初始化为该数据包的长度。
在上述技术方案的基础上,所述网络终端设备通过挂载钩子函数的方式,来实现步骤A和步骤B的操作。
在上述技术方案的基础上,步骤A具体包括以下操作:
A1、当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备首先检测该数据包对应的用户是否为新用户,若为新用户,转入步骤A2;若不为新用户,则直接转入步骤B;
A2、网络终端设备为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
在上述技术方案的基础上,步骤B具体包括以下操作:
B1、当后续再有上行数据包进入或有下行数据包将离开时,网络终端设配将遍历所有用户,找到该数据包对应用户的限速数据库,转入步骤B2;
B2、将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,如果时刻差未超过指定时间,转入步骤B3;如果时刻差超过指定时间,则转入步骤B4;
B3、将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包;
B4、计算该用户在该时刻差内的速率;用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;再判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
本发明还提供一种实现上述方法的网络终端设备,包括新用户限速数据库建立模块和单用户上下行限速处理模块;
所述新用户限速数据库建立模块用于:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,判断该数据包对应的用户是否为新用户,若是新用户,则为其建立相关的限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;
所述单用户上下行限速处理模块用于:当后续再有上行数据包进入或有下行数据包将离开网络终端时,比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
在上述技术方案的基础上,所述限速数据库包括以下数据段:该用户的MAC地址、该用户的基准时刻、限速值、指定时间内该用户上行或下行字节数变量;其中,该用户的基准时刻初始化为该数据包到达的时刻,限速值供用户进行配置,指定时间内该用户上行或下行字节数变量初始化为该数据包的长度。
在上述技术方案的基础上,所述新用户限速数据库建立模块、所述单用户上下行限速处理模块均通过挂载钩子函数的方式来实现各自功能。
在上述技术方案的基础上,所述新用户限速数据库建立模块建立新用户限速数据库的具体流程为:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,首先检测该数据包对应的用户是否为新用户,若为新用户,则为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
在上述技术方案的基础上,所述单用户上下行限速处理模块进行限速处理的具体流程为:
当后续再有上行数据包进入或有下行数据包将离开时,遍历所有用户,找到该数据包对应用户的限速数据库,并将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,
如果时刻差未超过指定时间,将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包;
如果时刻差超过指定时间,则计算该用户在该时刻差内的速率;用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;再判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
本发明的有益效果在于:
(1)本发明中,会为每个用户建立相应的限速数据库,通过该限速数据库记录指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;当后续再有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设配将比较该数据包达到的时刻与该数据包对应用户的限速数据库中记录的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是通过或丢弃该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是通过或丢弃数据包。
与现有技术相比,本发明就能根据实际用户需求,通过限速值来单独配置和限定各个用户能使用的上、下行最大带宽,从而达到避免因某个用户占用过大的网络带宽而导致其他用户的网络服务体验变差的目的。
(2)本发明中,可以根据用户需求对单个用户上、下行带宽最大值进行修改和配置(即,限速值为可灵活配置的可变值),使用更加灵活、方便,能满足各种使用需求。
(3)本发明的网络终端设备是通过挂载钩子函数的方式,来实现单用户上、下行限速的功能的,即通过软件来实现,无需增设额外硬件设备,使得适用范围广,操作更加简单。
附图说明
图1为本发明实施例中网络终端设备中实现单用户上行、下行限速的方法流程图;
图2为本发明实施例中建立的限速数据库的示意图;
图3为本发明实施例中挂载钩子函数的示意图;
图4上行限速实例的示意图;
图5为本发明实施例中网络终端设备的结构框图。
具体实施方式
本发明针对现有技术中当网络带宽有限,而用户数又增大到一定程度时,可能会存在某个用户占用过大的网络带宽,导致其他用户的网络服务体验变差的问题,提供了一种网络终端设备中实现单用户上行、下行限速的方法及设备,能根据实际用户需求,单独配置和限定各个用户能使用的上行、下行最大带宽,有效解决了因某个用户占用过大的网络带宽,导致其他用户的网络服务体验变差的问题。
其主要的设计思路为:为每个用户建立相应的限速数据库,通过该限速数据库记录指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;当后续再有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设配将比较该数据包达到的时刻与该数据包对应用户的限速数据库中记录的基准时刻,若时刻差未超过指定时间(即小于等于指定时间),则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发(即,是通过或丢弃)该数据包;若时刻差超过指定时间(即大于指定时间),则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。通过上述方法,就能根据实际用户需求,通过限速值来单独配置和限定各个用户能使用的上、下行最大带宽,从而达到避免因某个用户占用过大的网络带宽而导致其他用户的网络服务体验变差的目的。
为使本发明要解决的技术问题、技术方案和优点更加清楚,下面将结合说明书附图以及具体的实施例对本发明的技术方案进行详细的说明。
实施例一
参见图1所示,本实施例提供了一种网络终端设备中实现单用户上行、下行限速的方法,该方法包括以下步骤:
A、新用户限速数据库的建立:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备将判断该数据包(即上行数据包或下行数据包)对应的用户是否为新用户,若是,则为其建立相关的限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;否则,直接进入步骤B;
B、单用户上下行限速的处理:当后续再有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设配将比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间(即小于等于指定时间),则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发(即,是通过或丢弃)该数据包;若时刻差超过指定时间(即大于指定时间),则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
进一步地,在本实施例中,如图2所示,步骤A中建立的限速数据库包括以下数据段:该用户的MAC(Medium Access Control,介质访问控制)地址、该用户的基准时刻(初始化为该数据包到达的时刻)、限速值(以Byte/s为单位,供用户进行配置),指定时间内该用户上行或下行字节数变量(初始化为该数据包的长度,即初始化为步骤A中进入或将离开的数据包的长度)。
并且,步骤A、B中所述的指定时间设置为1秒钟;即,步骤A中,限速数据库记录有1秒钟内该用户上行或下行字节数变量,步骤B中,若时刻差未超过1秒钟,则根据1秒钟内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过1秒钟,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。可以理解的是,在实际实施过程中,该指定时间可根据实际情况由开发人员自行设置,本实施例不做具体限定。
另外,本实施例中,所述网络终端设备为安装嵌入式操作系统的网络终端设备,当然实际应用中,该方法还可适用于其他操作系统的网络终端设备中,本实施例不做具体限定。
更进一步地,本实施例中,所述网络终端设备是通过挂载钩子函数的方式,来实现步骤A(新用户限速数据库的建立)和步骤B(单用户上下行限速的处理)的操作。具体来说,由于用户通过网络终端设备获取网络服务时,分别存在上行和下行数据链路,因此,本实施例的网络终端设备会在上行数据包从用户侧进入网络终端设备之后或下行数据包发出网络终端设备之前的数据路径中,挂载钩子函数,通过该钩子函数来实现步骤A和步骤B的操作,即针对单个用户进行上行、下行限速的功能。更具体地,如图3所示,本实施例中,所挂载的钩子函数为两个:上行钩子函数A和下行钩子函数B,通过上行钩子函数A来实现针对单个用户进行上行限速的功能,通过下行钩子函数B来实现针对单个用户进行下行限速的功能。当然实际应用中还可采用除挂载钩子函数以外的方式,只要该方式能使得网络终端设备能实现上述步骤A、B的操作,具备对单个用户进行上行、下行限速的功能即可,本实施例不做具体限定。
实施例二
本实施例提供的一种网络终端设备中实现单用户上行、下行限速的方法,其基本步骤与实施例一相同,不同之处在于:该方法的步骤A具体包括以下操作:
步骤A1、当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备首先检测该数据包对应的用户是否为新用户,若为新用户,转入步骤A2;若不为新用户,则直接转入步骤B。
步骤A2、网络终端设备为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
实施例三
本实施例提供的一种网络终端设备中实现单用户上行、下行限速的方法,其基本步骤与实施例一相同,不同之处在于:该方法的步骤B具体包括以下操作:
步骤B1、当后续再有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设配将遍历所有用户,找到该数据包对应用户的限速数据库,转入步骤B2。
步骤B2、将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,如果时刻差未超过指定时间,转入步骤B3;如果时刻差超过指定时间,则转入步骤B4。
步骤B3、将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量(当前记录的指定时间内该用户上行或下行字节数变量=限速数据库中记录的指定时间内该用户上行或下行字节数变量+该数据包的长度)是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
步骤B4、计算该用户在该时刻差内的速率,计算公式为:该用户在该时刻差内的速率=(限速数据库中记录的指定时间内该用户上行或下行字节数变量+该数据包长度)/时刻差);再用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;并判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
为了更清楚的理解上述实施例1~3的方法,下面以进行上行限速操作且指定时间为1秒为例,对本发明的方法进行举例说明。
S1:如图4所示,当从上行链路中进来一个数据包Packet A时,网络终端设备首先检测数据包Packet A对应的用户是否为新用户,
若为新用户则为其建立相关的数据库,该数据库中包括以下数据段:Mac_address(该用户的mac地址)、Rate(限速值、以Byte/s为单位,供用户进行配置)、Reference_Time(基准时刻,初始化为数据包Packet A的到达时刻t1)、Passed_Bytes(该用户的1秒内上行字节数变量,初始化为数据包Packet A的长度);并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的Rate中;
若不为新用户,则直接转入S2。
S2:当后续从上行链路中又进入数据包Packet B,网络终端设配先遍历所有用户,找到该数据包对应用户的限速数据库(假设此次对应用户也是步骤S1中的用户),再将该数据包到达的时刻t2与该用户的限速数据库中的基准时刻Reference_Time进行比较,若时刻差(t2-Reference_Time)未超过1秒,则将该用户的限速数据库中的Passed_Bytes增加该数据包的长度,不更新该用户Reference_Time,并判断当前Passed_Bytes是否大于Rate,若是,则丢弃该数据包,否则通过该数据包;
当后续从上行链路中又进入数据包Packet C,网络终端设配先遍历所有用户,找到该数据包对应用户的限速数据库(假设此次对应用户也是步骤S1中的用户),再将该数据包到达的时刻t3与该用户的限速数据库中的基准时刻Reference_Time进行比较,若时刻差(t3-Reference_Time)超过1秒,则计算用户在该时刻差内的速率,该速率=(该用户的Passed_Bytes+数据包Packet C的长度)/(t3-Reference_Time);再用t3赋值该用户的Reference_Time,清零该用户的Passed_Bytes;然后判断计算的用户在该时刻差内的速率是否大于Rate,若是,则将该数据包丢弃,否则通过该数据包。
经过上述操作可以看出,本发明实施例就能根据实际用户需求,通过限速值来单独配置和限定各个用户能使用的上、下行最大带宽,从而达到避免因某个用户占用过大的网络带宽而导致其他用户的网络服务体验变差的目的。
实施例四
基于同一发明构思,参见图5所示,本发明实施例还提供了一种实现上述方法的网络终端设备。该网络终端设备包括新用户限速数据库建立模块和单用户上下行限速处理模块。
其中,新用户限速数据库建立模块用于:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,判断该数据包对应的用户是否为新用户,若是新用户,则为其建立相关的限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值。单用户上下行限速处理模块用于:当后续再有上行数据包进入或有下行数据包将离开网络终端时,比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
进一步地,在实际应用中,所述新用户限速数据库建立模块、所述单用户上下行限速处理模块均可以通过挂载钩子函数的方式来实现各自功能。
更进一步地,在一种可选的实施方式中,所述新用户限速数据库建立模块建立新用户限速数据库的具体流程为:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,首先检测该数据包对应的用户是否为新用户,若为新用户,则为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
再进一步地,在一种可选的实施方式中,所述单用户上下行限速处理模块进行限速处理的具体流程为:
当后续再有上行数据包进入或有下行数据包将离开时,遍历所有用户,找到该数据包对应用户的限速数据库,并将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,如果时刻差未超过指定时间,将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包;如果时刻差超过指定时间,则计算该用户在该时刻差内的速率;用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;再判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
需要说明的是:上述实施例提供的网络终端设备在实现单用户上行、下行限速的方法时,仅以上述各功能模块的划分进行举例说明,实际应用中,可根据需要而将上述功能分配由不同功能模块完成,即将设备的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。
本发明不局限于上述实施方式,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也视为本发明的保护范围之内。本说明书中未作详细描述的内容属于本领域专业技术人员公知的现有技术。
Claims (10)
1.一种网络终端设备中实现单用户上行、下行限速的方法,其特征在于,该方法包括以下步骤:
A、当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备将判断该数据包对应的用户是否为新用户,若是新用户,则为其建立限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;否则,直接进入步骤B;
B、当后续再有上行数据包进入或有下行数据包将离开时,网络终端设配将比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
2.如权利要求1所述的网络终端设备中实现单用户上行、下行限速的方法,其特征在于:步骤A中建立的限速数据库包括以下数据段:该用户的MAC地址、该用户的基准时刻、限速值、指定时间内该用户上行或下行字节数变量;其中,该用户的基准时刻初始化为该数据包到达的时刻,限速值供用户进行配置,指定时间内该用户上行或下行字节数变量初始化为该数据包的长度。
3.如权利要求1所述的网络终端设备中实现单用户上行、下行限速的方法,其特征在于:所述网络终端设备通过挂载钩子函数的方式,来实现步骤A和步骤B的操作。
4.如权利要求1所述的网络终端设备中实现单用户上行、下行限速的方法,其特征在于,步骤A具体包括以下操作:
A1、当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,网络终端设备首先检测该数据包对应的用户是否为新用户,若为新用户,转入步骤A2;若不为新用户,则直接转入步骤B;
A2、网络终端设备为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
5.如权利要求1所述的网络终端设备中实现单用户上行、下行限速的方法,其特征在于,步骤B具体包括以下操作:
B1、当后续再有上行数据包进入或有下行数据包将离开时,网络终端设配将遍历所有用户,找到该数据包对应用户的限速数据库,转入步骤B2;
B2、将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,如果时刻差未超过指定时间,转入步骤B3;如果时刻差超过指定时间,则转入步骤B4;
B3、将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包;
B4、计算该用户在该时刻差内的速率;用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;再判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
6.一种实现权利要求1所述方法的网络终端设备,其特征在于:该网络终端设备包括新用户限速数据库建立模块和单用户上下行限速处理模块;
所述新用户限速数据库建立模块用于:当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,判断该数据包对应的用户是否为新用户,若是新用户,则为其建立相关的限速数据库,该限速数据库记录有指定时间内该用户上行或下行字节数变量、该用户的基准时刻以及根据用户需求配置的限速值;
所述单用户上下行限速处理模块用于:当后续再有上行数据包进入或有下行数据包将离开网络终端时,比较该数据包达到的时刻与该数据包对应用户的基准时刻,若时刻差未超过指定时间,则根据指定时间内该用户上行或下行字节数以及配置的限速值来确定是否转发该数据包;若时刻差超过指定时间,则更新该用户的基准时刻,并根据计算的该用户在时刻差内的速率以及配置的限速值来确定是否转发该数据包。
7.如权利要求6所述的网络终端设备,其特征在于,所述限速数据库包括以下数据段:该用户的MAC地址、该用户的基准时刻、限速值、指定时间内该用户上行或下行字节数变量;其中,该用户的基准时刻初始化为该数据包到达的时刻,限速值供用户进行配置,指定时间内该用户上行或下行字节数变量初始化为该数据包的长度。
8.如权利要求6所述的网络终端设备,其特征在于:所述新用户限速数据库建立模块、所述单用户上下行限速处理模块均通过挂载钩子函数的方式来实现各自功能。
9.如权利要求6所述的网络终端设备,其特征在于:所述新用户限速数据库建立模块建立新用户限速数据库的具体流程为:
当有上行数据包进入网络终端设备或有下行数据包将离开网络终端时,首先检测该数据包对应的用户是否为新用户,若为新用户,则为该用户建立相关的限速数据库;并利用网络终端设备底层向应用层提供配置接口,使应用层通过该配置接口依据用户需求来配置该用户的限速值,并将配置的限速值保存到该用户的限速数据库的限速值域中。
10.如权利要求6所述的网络终端设备,其特征在于:所述单用户上下行限速处理模块进行限速处理的具体流程为:
当后续再有上行数据包进入或有下行数据包将离开时,遍历所有用户,找到该数据包对应用户的限速数据库,并将该数据包到达的时刻与该用户的限速数据库中的基准时刻进行比较,
如果时刻差未超过指定时间,将该用户的限速数据库中记录的指定时间内该用户上行或下行字节数变量加上该数据包的长度;判断当前记录的指定时间内该用户上行或下行字节数变量是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包;
如果时刻差超过指定时间,则计算该用户在该时刻差内的速率;用该数据包到达的时刻更新该用户的限速数据库中记录的基准时刻,同时清零限速数据库中记录的指定时间内该用户上行或下行字节数变量;再判断计算的该用户在该时刻差内的速率是否大于配置的限速值,若是,则将该数据包丢弃;否则,通过该数据包。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810274288.XA CN108600121A (zh) | 2018-03-29 | 2018-03-29 | 网络终端设备中实现单用户上行、下行限速的方法及设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810274288.XA CN108600121A (zh) | 2018-03-29 | 2018-03-29 | 网络终端设备中实现单用户上行、下行限速的方法及设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108600121A true CN108600121A (zh) | 2018-09-28 |
Family
ID=63623951
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810274288.XA Pending CN108600121A (zh) | 2018-03-29 | 2018-03-29 | 网络终端设备中实现单用户上行、下行限速的方法及设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108600121A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109547353A (zh) * | 2018-11-21 | 2019-03-29 | 深圳市吉祥腾达科技有限公司 | 一种通过ip地址段对上下行限速的方法 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101119314A (zh) * | 2007-09-14 | 2008-02-06 | 中国科学院计算技术研究所 | 一种多模终端业务流的控制系统和装置以及方法 |
CN101359979A (zh) * | 2008-08-01 | 2009-02-04 | 中国联合通信有限公司 | 一种基于终端的链路丢包率控制方法及系统 |
CN101873640A (zh) * | 2010-05-27 | 2010-10-27 | 华为终端有限公司 | 流量处理方法、装置和移动终端 |
CN102118320A (zh) * | 2011-04-18 | 2011-07-06 | 北京神州数码思特奇信息技术股份有限公司 | 一种协议识别和流量控制方法 |
CN104009928A (zh) * | 2014-05-26 | 2014-08-27 | 深圳市共进电子股份有限公司 | 一种对数据流进行限速的方法及装置 |
CN105141542A (zh) * | 2015-09-18 | 2015-12-09 | 北京百度网讯科技有限公司 | 基于tcp通信协议的拥塞窗口的控制算法和系统 |
-
2018
- 2018-03-29 CN CN201810274288.XA patent/CN108600121A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101119314A (zh) * | 2007-09-14 | 2008-02-06 | 中国科学院计算技术研究所 | 一种多模终端业务流的控制系统和装置以及方法 |
CN101359979A (zh) * | 2008-08-01 | 2009-02-04 | 中国联合通信有限公司 | 一种基于终端的链路丢包率控制方法及系统 |
CN101873640A (zh) * | 2010-05-27 | 2010-10-27 | 华为终端有限公司 | 流量处理方法、装置和移动终端 |
CN102118320A (zh) * | 2011-04-18 | 2011-07-06 | 北京神州数码思特奇信息技术股份有限公司 | 一种协议识别和流量控制方法 |
CN104009928A (zh) * | 2014-05-26 | 2014-08-27 | 深圳市共进电子股份有限公司 | 一种对数据流进行限速的方法及装置 |
CN105141542A (zh) * | 2015-09-18 | 2015-12-09 | 北京百度网讯科技有限公司 | 基于tcp通信协议的拥塞窗口的控制算法和系统 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109547353A (zh) * | 2018-11-21 | 2019-03-29 | 深圳市吉祥腾达科技有限公司 | 一种通过ip地址段对上下行限速的方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6938766B2 (ja) | パケット制御方法およびネットワーク装置 | |
CN103385033B (zh) | 用于在网络单元中分配会话束的方法和设备 | |
CN104202264B (zh) | 云化数据中心网络的承载资源分配方法、装置及系统 | |
CA2507941C (en) | Method for verifying function of redundant standby packet forwarder | |
CN1875585B (zh) | 利用mac限制来控制动态未知l2泛滥的方法和系统 | |
CN106992938A (zh) | 一种网络流量动态调度分配方法及系统 | |
EP2993840A1 (en) | Stream forwarding method, device and system | |
CN106375384A (zh) | 一种虚拟网络环境中镜像网络流量的管理系统和控制方法 | |
CN108337179B (zh) | 链路流量控制方法及装置 | |
WO2018010555A1 (zh) | 一种北向接口lte业务自动配置方法、北向接口装置及存储介质 | |
CN108616402A (zh) | 一种远端设备的管理方法及系统 | |
Hu et al. | Towards" full containerization" in containerized network function virtualization | |
CN108833267A (zh) | 智能工业网关 | |
CN106063201A (zh) | 服务器、控制设备、管理设备、通信系统、通信方法、控制方法、管理方法和程序 | |
WO2020078381A1 (zh) | 数据汇聚方法、装置、设备、存储介质和系统 | |
CN107329811A (zh) | 一种数据中心功耗调节方法及装置 | |
CN108600121A (zh) | 网络终端设备中实现单用户上行、下行限速的方法及设备 | |
CN103560918B (zh) | 一种管理cpe端口的方法及系统 | |
Josbert et al. | Solution for industrial networks: Resilience-based sdn technology | |
CA2015405C (en) | Packet synchronization utilizing a multi-length packet format including check sequence (s) | |
JP7135217B2 (ja) | パケットスケジューリング方法、関連するデバイス、およびコンピュータ記憶媒体 | |
CN107734508A (zh) | 一种分组传送网接入环拆环方法和装置 | |
CN110708209A (zh) | 虚拟机流量采集方法、装置、电子设备及存储介质 | |
CN103117953B (zh) | 一种QoS配置方法和设备 | |
Groskinsky et al. | An investigation of adaptive capacity control schemes in a dynamic traffic environment |
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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20180928 |