Apparatus and method for providing load balancing of active traffic across multiple channels of a Data-Over-Cable (DOC) network are described.
Cable television networks typically comprise cables such as coaxial cables, optical fiber cables, or a Hybrid Fiber/Coaxial (HFC) cable system which interconnect cable modems (CMs) of subscribers to a headend of the cable network. Subscribers may use their cable modems and the cable network to connect to the Internet and/or other computer networks. The cable modems support data connection to the Internet and other computer networks via the cable network, and the cable networks provide bi-directional communication systems in which data can be sent downstream from the headend to a subscriber and upstream from a subscriber to the headend.
A Cable Modem Termination System (CMTS) is equipment that is located at the headend of the cable network and that is able to receive data packets from a data network and transmit the data packets downstream via the cable network to a cable modem attached to customer premises equipment (CPE). The customer premises equipment can send signals to the cable modem which, in turn, sends data packets upstream via the cable network to the CMTS. The CMTS then sends the data packets back to the appropriate host on the data network. An example of a CMTS is the Motorola Broadband Service Router 64000 (BSR 64000).
The term DOCSIS (Data Over Cable System Interface Specification) refers to a group of specifications that define industry standards for cable headend and cable modem equipment. The types of traffic, referred to as service flows, transmitted across a DOCSIS network can vary and may include, for instance, text-based Web browsing, file transferring, email communications, voice and video communications, and the like. Thus, for instance, customer premises equipment (CPE) may include a telephone or other device capable of sending and receiving video or voice signals via the cable modem and cable network. In such cases, the cable modem will typically have an internal or embedded Media Terminal Adapter (eMTA) which provides network interface functionality that accepts analog voice inputs or video signal and generates IP packets. Voice and video communications tend to require greater throughput rates for acceptable levels of service than that of the other service flows referenced above. The different types of service flows communicated over the cable network may have different Quality of Service parameters and requirements.
When a user registers a cable modem to use a DOCSIS-compliant network, a series of handshaking steps are initially executed during which the modem identifies itself and the network designates (among other parameters) the level of service and frequency (channel) that the cable modem may use. After registration is complete, the cable modem may periodically or occasionally request the creation of service flows and, if allowed, the allocation of bandwidth to transmit data to the CMTS in the upstream direction.
Typically, thousands of cable modems are connected to each CMTS, and a number of customer premises equipment (CPE), such as computers, Voice-over-Internet-Protocol (VoIP) compliant devices, wireless routers, portable hand-held devices, smartphones and the like, communicate with each cable modem at the subscriber location. Many users typically share a channel, or a group of channels, and their interests compete for the bandwidth of the channel. The full bandwidth available to the multi-channel network for data transmission comprises the sum of bandwidths of the individual channels. Overcrowding of traffic on any one channel will cause degraded performance to a user on that channel.
To address the need to distribute traffic across upstream and/or downstream channels, a CMTS can be set to implement algorithms to provide load balancing for traffic across multiple channels. The algorithms are applied to a set of cable modems using a set of channels referred to as a “load balancing group”. Three such techniques used for distributing voice, video, data and other traffic across upstream and downstream channels include manual, static and dynamic load balancing. For example, after registration, cable modems can be manually moved by the actions of operation personnel to balance the number of cable modems evenly among a defined group of upstream channels. In contrast, static upstream load balancing can be utilized to automatically move a newly registered cable modem to a least-loaded upstream channel. Conventionally, static load balancing has been based solely on cable modem count on each upstream channel. As a further alternative, dynamic load balancing can be used to automatically move cable modems from a channel with highest utilization to a channel with lowest utilization in an attempt to more evenly distribute active traffic across upstream and/or downstream channels within a defined load balancing group.
Conventionally, algorithms for dynamic load balancing have taken into account actual bandwidth utilization of each channel that is configured for a load balancing group, actual bandwidth utilized by each modem on the highest utilized channel, and pre-set utilization thresholds. For example, if one channel is operating at 70% utilization capacity and another is being operated only at 30% utilization capacity, dynamic load balancing may be automatically implemented to balance the traffic on the channels. However, if the delta between the two channels is relatively small (i.e., less than a pre-set threshold value), dynamic load balancing may not be implemented by the CMTS at a given point in time.
When thresholds are met and load balancing is performed by the CMTS, cable modems are caused to be moved across channels while they are actively passing traffic. This is achieved as discussed above by considering certain channel parameters, such as utilization, number of cable modems on the channel, or number of active service flow identifiers on the channel. With conventional load balancing techniques as discussed above, it is possible that a cable modem generating traffic that has service flows with relatively high Quality of Service (QoS) attributes and requirements may be selected for being moved to another channel. Quality of Service generally refers to the speed and reliability of data transmission and like performance parameters needed for an acceptable or guaranteed level of service. An example of one such QoS parameter is Minimum Reserved Rate (MRR). Conventional load balancing techniques ignore QoS parameters of modem service flows, relying only on the currently active utilization of the cable modem. Multiple movements of active cable modems according to conventional techniques across channels may result in an aggregation of currently inactive cable modems with high QoS requirements on the same channel. When any such aggregated, high-QoS cable modem becomes active, it may be unable to achieve its required QoS. This can result in service interruption for those cable modems or, alternatively, a required interruption of load balancing.
This disclosure describes a method of load balancing cable modems across multiple channels of a Data Over Cable System Interface Specification (DOCSIS) network. At least one Quality of Service (QoS) parameter for each service flow from a plurality of cable modems actively passing traffic across one channel of the load balancing group is collected. The at least one QoS parameter collected for each service flow is used to identify at least one cable modem having a service flow with an inferior grade of the at least one QoS parameter relative to a pre-defined threshold. The at least one cable modem having the service flow with the inferior grade of the at least one QoS parameter relative to the pre-defined threshold is selected for being moved from the one channel of the load balancing group to a different channel of the load balancing group for balancing load of active service flows across the channels of the load balancing group. The collecting, using and selecting steps of the method are performed automatically by an electronic communication device at a headend of the DOCSIS network communicating with the plurality of cable modems.
This disclosure also describes a signal processing electronic device for communicating with cable modems across channels of a load balancing group on a Data Over Cable System Interface Specification (DOCSIS) network. The signal processing electronic device has a processing unit configurable to run an algorithm for performing a load balancing operation for the cable modems across the channels of the load balancing group. The processing unit is configured to collect at least one Quality of Service (QoS) parameter for each service flow from the cable modems that are actively passing traffic across one channel of the load balancing group. The processing unit is also configured to identify at least one cable modem having a service flow with an inferior grade of the at least one QoS parameter relative to a pre-defined threshold and is further configured to select the at least one cable modem having the service flow with the inferior grade of the at least one QoS parameter relative to the pre-defined threshold from the cable modems of the load balancing group for being moved from the one channel to a different channel of the load balancing group for balancing load of active service flows across the channels of the load balancing group.
Yet further, this disclosure describes at least one non-transitory computer readable storage medium having computer program instructions stored thereon that are arranged to perform the above referenced operations.
Various features of the embodiments described in the following detailed description can be more fully appreciated when considered with reference to the accompanying figures, wherein the same numbers refer to the same elements.
For simplicity and illustrative purposes, the principles of the embodiments are described by referring mainly to examples thereof. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the embodiments. It will be apparent however, to one of ordinary skill in the art, that the embodiments may be practiced without limitation to these specific details. In some instances, well known methods and structures have not been described in detail so as not to unnecessarily obscure the embodiments.
At the headend, the CMTS 14 may be connected to numerous program providers, television networks and stations, Internet broadcasters/service providers, and the like 20 for providing content via the CMTS 14 to the cable modems 12 and CPE. Transmission of signals from the CMTS 14 to the cable modems 12 are considered downstream transmissions and signal transmissions from the cable modems 12 to the CMTS 14, which are typically in the form of burst type transmissions, are considered upstream transmissions.
As discussed above, when a cable modem 12 is registered with the CMTS 14, it is assigned to a load balancing group with perhaps hundreds of other cable modems. Such a group typically permits the cable modem 12 to be moved across multiple defined upstream and downstream channels. By way of example, a particular load balancing group may enable its modems to receive/transmit traffic flows on a total of four downstream channels and three or four upstream channels.
One of the functions typically performed by the CMTS 14 is to balance traffic across the multiple channels of a load balancing group. Conventionally, this may be accomplished by balancing the number of cable modems assigned to each channel (i.e., static load balancing) or by balancing and periodically re-balancing the total amount of active traffic on the channels (i.e., dynamic load balancing). For this purpose, the processing unit 24 or other processing unit of the CMTS 14 typically includes software, microprocessors, other modules, or the like for running and controlling load balancing operations.
The CMTS and its load balancing software, microprocessors, modules, or the like according to this disclosure balances traffic across channels by taking into account Quality of Service (QoS) parameters associated with the active traffic or cable modems with active traffic. Thus, candidates for load balancing are selected based on the value or values of their QoS parameter or parameters. In particular, candidates are selecting using a QoS parameter value that is generally of an inferior grade (e.g. a lower minimum reserved rate) compared to other candidates. The inferior grade candidates will have QoS requirements that are easier to satisfy when aggregated with other cable modems on a channel. An example of selecting an inferior grade QoS parameter would be to consider as candidates for moving only modems with service flows with a Minimum Reserved Rate (MRR) less than a particular threshold. Thus, during load balancing, Quality of Service parameters of active traffic are considered when selections are made by the CMTS with respect to which cable modems are to be moved from one channel to another channel within a load balancing group. More specifically, cable modems and/or active traffic that are classified as having “easier to satisfy” Quality of Service parameters are first considered to be moved across channels in an effort to re-balance load before cable modems and/or active traffic that have Quality of Service parameters that are more difficult to satisfy are considered.
By taking into account Quality of Service parameters during load balancing and not just the total number of cable modems per channel or amount of active traffic per channel, interruptions for customers subscribed to premium services with higher levels or grades of Quality of Service are reduced due to the reduced DOCSIS Upstream Channel Change (UCC) and DOCSIS Dynamic Channel Change (DCC) operations applied to these cable modems during load balancing events. In addition, the probability of realizing relatively-inactive future service flows on a channel or channels with relatively-high Quality of Service demands will necessarily be maximized better ensuring that the guaranteed Quality of Service levels are provided to the subscriber/customer.
For purposes of this disclosure, a service flow is a unidirectional flow of packets that provides a particular Quality of Service (QoS). The DOCSIS protocol classifies traffic into service flows with each service flow having its own set of QoS parameters. For example, DOCSIS service flow types for upstream service flows (from cable modem to CMTS) may include: a best effort service flow type; a non-real-time polling service (NRTPS) flow type; a real-time polling service (RTPS) flow type; an unsolicited grant service (UGS) flow type; and an unsolicited grant service with activity detection (UGS-AD) flow type. Simply for purposes of example, a best effort service flow type may be standard internet traffic such as web browsing, email, or instant messaging. An example of a NRTPS flow type may be standard Internet traffic that requires high throughput or variable-size data grants on a regular basis. An example of a RTPS flow type may be MPEG video, and an example of an UGS flow type may be VoIP.
DOCSIS defines QoS parameters for each of the above service flow types. By way of example, the QoS parameters for a best effort service flow type include traffic priority, request transmission policy, maximum sustained traffic rate, maximum traffic burst, minimum reserved traffic rate, and assumed minimum reserved-traffic-rate packet size. The QoS parameters for a NRTPS flow type include traffic priority, request transmission policy, maximum sustained traffic rate, maximum traffic burst, minimum reserved traffic rate, assumed minimum reserved-traffic-rate packet size, and nominal polling interval. The QoS parameters for a RTPS flow type include request transmission policy, maximum sustained traffic rate, maximum traffic burst, minimum reserved traffic rate, assumed minimum reserved-traffic-rate packet size, nominal polling interval, and tolerated poll jitter. The QoS parameters for an UGS flow type include request transmission policy, unsolicited grant size, grants per interval, nominal grant interval, and tolerated grant jitter. The QoS parameters for an UGS-AD flow type include request transmission policy, nominal polling interval, tolerated poll jitter, unsolicited grant size, grants per interval, nominal grant interval, and tolerated grant jitter.
According to the above recited definitions or other definitions, an algorithm set to run on the processing unit 24 or like unit on the CMTS 14 can be pre-set with one or more defined thresholds relative to one or more Quality of Service parameters that can be used to distinguish a cable modem and/or traffic type or a set of cable modems and/or traffic types that have so-called “easier to satisfy” Quality of Service parameters than another cable modem or set of cable modems within a load balancing group of cable modems. Thereafter, during the selection process performed by the CMTS 14 to identify cable modems to be moved from a first channel to a second channel, cable modems pre-selected as having active traffic with easier to satisfy Quality of Service parameters are first considered for being moved during a load balancing procedure. Only if rebalancing cannot be fully achieved solely with movement of cable modems considered as having easier to satisfy Quality of Service parameters are cable modems from the remaining cable modems of the load balancing group considered for selection for movement to re-balance load across the channels. If this occurs, a cable modem having active traffic with the easiest to satisfy Quality of Service parameters remaining is selected before a cable modem having relatively harder Quality of Service parameters is selected. The selection process is performed in iterations until the desired or pre-set level of re-balancing is achieved.
QoS parameters may also be considered when determining the number of times a cable modem can be moved to a different channel within a load balancing group during consecutive load balancing events. For example, dynamic load balancing may occur at intervals of about every five minutes, and any single cable modem may be limited from being moved repeatedly back-and forth between channels in a ping-pong manner during a given number of consecutive load balancing events. Here, a cable modem identified as having so-called easier to satisfy QoS parameters may be permitted to be moved up to five times during consecutive load balancing events; whereas, a cable modem considered as having harder to satisfy QoS parameters may only be permitted to be moved two times during consecutive load balancing events. Thus, after being moved in two consecutive load balancing operations, the cable modem is then prevented from being moved when the next load balancing operation occurs.
As discussed above, one of the steps of the load balancing method is to distinguish cable modems having service flows with so-called easier to satisfy Quality of Service parameters from cable modems having service flows with relatively harder to satisfy Quality of Service parameters. These decisions can be implemented by providing algorithms applied by the CMTS 14 defined by one or more set of rules for use in making load balancing selections. For example, a cable modem that does not have an eMTA may be placed in a list of cable modems identified as having easier to satisfy Quality of Service parameters as compared to a cable modem having an eMTA. This is because the eMTA is used for streaming voice or video communications, such as required for providing VoIP communicating services. This type of service flow generally has harder to satisfy Quality of Service parameters. Thus, cable modems without an eMTA may be considered for being moved to a different channel during load balancing operations before cable modems having eMTAs.
Of course, there are many other examples of rules for distinguishing cable modems having service flows with easier to satisfy Quality of Service parameters from other cable modems within a load balancing group. For instance, cable modems having service flows with fewer distinct Service Class Names or types will have QoS parameters that are easier to satisfy than a cable modem having service flows with more distinct Service Class Names or types, and cable modems having service flows with a lower total sum of Minimum Reserved Rate (MRR) will have QoS parameters that are easier to satisfy than a cable modem having service flows with a higher total sum of MRR.
The algorithms applied by the CMTS 14 can focus on each active service flow of a cable modem to select modems for movement across channels during load balancing. Here, a cable modem can be selected as having QoS parameters easier to satisfy than another cable modem based on each of its service flows being relatively easier to satisfy than the service flows of another modem. For example, a service flow that is without a defined MRR has QoS parameters that are easier to satisfy than a service flow with a defined MRR. Likewise, a service flow with a lower MRR has QoS parameters that are easier to satisfy than a service flow with a higher MRR. Also by way of example, a service flow that is without a defined jitter tolerance has QoS parameters that are easier to satisfy than a service flow with a defined jitter tolerance, and a service flow with a higher jitter tolerance has QoS parameters that are easier to satisfy than a service flow with a lower jitter tolerance.
As additional examples, a service flow that is without a defined maximum traffic rate has QoS parameters that are easier to satisfy than a service flow with a defined maximum traffic rate, and a service flow with a lower maximum traffic rate has QoS parameters that are easier to satisfy than a service flow with a higher maximum traffic rate. Still further, a service flow with a smaller total maximum traffic burst has QoS parameters that are easier to satisfy than a service flow with a higher total maximum traffic burst; a service flow with fewer Unsolicited Grant Service (UGS) grants per interval has QoS parameters that are easier to satisfy than a service flow with more UGS grants per interval; and a service flow with a smaller UGS grant interval has QoS parameters that are easier to satisfy than a service flow with a larger UGS grants interval. Of course, these provide just a few examples.
A method for considering QoS parameters during load balancing is shown in the flowchart of
At runtime of the load balancing algorithm, the CMTS 14 detects whether or not a pre-defined amount of imbalance exists on a channel of highest utilization. (See step 52). If not, the CMTS 14 continues to detect for imbalances or checks for imbalances at a next pre-defined interval. (See step 54). However, if a pre-defined imbalance exists, the CMTS begins selecting cable modems for UCC or DCC for purposes of re-balancing the load across the channels of the load balancing group. Thus, the CMTS begins collecting a pre-defined QoS parameter for each service flow of cable modems actively passing traffic across the channel of highest utilization. (See step 56.)
According to one embodiment, a “First List” is defined as including all the cable modems assign to pass traffic across a particular channel. From this “First List”, cable modems that provide a Quality of Service that is better or superior to the pre-set thresholds for QoS parameters are removed from the “First List” and placed in a “Second List” or second subset. In this manner, only cable modems that do not meet the quality thresholds and/or are considered as having inferior grades of service with “easier to satisfy” QoS parameters remain in the “First List”, or first subset for being considered as a candidate to be moved across channels in a load balancing effort. (See step 58.)
For purposes of example, the “Second List” can be compiled as follows. For each cable modem in the “First List”: (a) identify the cable modem's active service flow identifiers (SFIDs) on which there is active traffic; (b) for each such SFID, obtain the service flow attributes (i.e., QoS parameters and values thereof); and (c) if the service flow attributes of any of the SFIDs of the cable modem are of a quality that surpass the thresholds as defined by the rules stored in the algorithm of the CMTS, then move the cable modem to the “Second List”, if not, permit the cable modem to remain in the “First List”.
After the First and Second Lists are compiled, an attempt is made to achieve a pre-defined level of load balancing by applying UCC and/or DCC operations to at least some or possible all of the cable modems listed in the “First List” (i.e., list of cable modems considered to have easier to satisfy QoS parameters). (See steps 62 and 66.) If the pre-defined level of re-balancing has been achieved (see steps 68 and 70), the current load balancing operation can be terminated and the process can return to detecting for imbalance (see steps 72 and 52). Alternatively, if after all cable modems in the “First List” have been moved across channels (see step 60) and the pre-defined level of re-balancing has not be achieved (see steps 68 and 70), a needed number of the cable modems in the “Second List” are moved to another channel (see steps 64 and 66) until the pre-defined level of re-balancing has been achieved. Here, a cable modem in the “Second List” that has the easiest to satisfy QoS parameter of all the remaining cable modems in the “Second List” is the first to be moved. This process continues with the remaining cable modems in the “Second List” until the pre-defined level of re-balancing is achieved.
The above described “QoS-aware” load balancing algorithm can be run in conjunction with other algorithms and rules set for the CMTS. For instance, algorithms defining the threshold for when the next load balancing operation begins or ends, how many consecutive movements of a cable modem is permitted before the cable modem is not permitted to be moved, or which cable modems are always prevented from being moved can be used in conjunction with the “QoS-aware” load balancing algorithm. Further, the “QoS-aware” load balancing algorithm can be applied to all cable modems on all channels or only certain pre-defined cable modems or pre-defined channels.
A specific example is provided below. In this example, there are two rules by which the load balancing algorithm makes decisions. “Rule 1” requires that a dynamic load balancing operation be started if the utilization of an upstream channel in the load balancing group equals or surpasses 80%. “Rule 2” requires that for any cable modem having an active service flow with a minimum reserved traffic rate QoS parameter of greater than 600,000, the cable modem should be moved to “List 2” which represents a list of cable modems that do not have so-called “easier to satisfy” QoS parameters.
In this example, cable modem 1 (CM1) is configured with a service class having a minimum reserved traffic rate of 800,000; cable modem 2 (CM2) is configured with a service class having a minimum reserved traffic rate of 700,000; and cable modem 3 (CM3) is configured with a service class having a minimum reserved traffic rate of 500,000. In this example, all cable modems (CM1, CM2, CM3) are actively passing traffic on the same upstream channel and the utilization on this upstream channel crosses 80%. This initiates a load balancing operation to be performed by the CMTS according to the requirement of “Rule 1”. A “List 1” is generated in which CM1, CM2 and CM3 are identified. The algorithm selects CM1 and CM2 to be removed from “List 1” and placed in “List 2” according to the requirements of “Rule 2”. Since “List 1” now represents cable modems considered to have “easier to satisfy” QoS parameters, CM3 is selected for UCC and gets moved to a different (less utilized) channel in the load balancing group in an effort to balance load across the channels of the load balancing group. If the utilization of the upstream channel on which CM1 and CM2 remain falls below 80%, the load balancing operation concludes. Otherwise, if utilization on the channel remains at or above 80% after moving CM3 and “List 1” is empty, cable modems from “List 2” are now considered for load re-balancing. Here, the algorithm selects CM2 for being moved to a less utilized channel because the MRR for CM2 is less than (i.e., easier to satisfy) the MRR for CM1. Thus, CM2 is moved.
The devices, units, modules and storage discussed above can physically be provided on a circuit board or within an electronic device and can include various processors, microprocessors, controllers, chips, disk drives, and the like. It will be apparent to one of ordinary skill in the art that the modules, processors, controllers, units, and the like may be implemented as electronic components, software, hardware or a combination of hardware and software. For example, a means to perform the above discussed algorithm can be provided as at least one computer readable storage medium having computer program instructions stored thereon that are arranged to perform the above referenced operations.
While the principles of the invention have been described above in connection with specific devices, systems, and methods, it is to be clearly understood that this description is made only by way of example and not as limitation on the scope of the invention as defined in the appended claims.