The present invention relates to a communications network and a method of operating a communications network.
Recently, the demand for streaming video to a computer via the Internet has grown strongly. This has led to a need to supply increasing amounts of video material over local communication networks (including the copper pairs used by telephone network operators or the coaxial cables used by cable television network operators).
In telephony networks this additional demand is being met partly by the introduction of Digital Subscriber Loop (DSL) technology. As its name suggests, this technology carries digital signals over the local copper loop between a user's home and a local telephone exchange. Data-rates of several megabits per second to the user's home have become commonplace. Advances in this technology now lead to much higher rates, 20 Mbit/s and above and with plans in the industry to offer 50 Mbit/s and above to a substantial proportion of broadband end users in the relatively near future. Using DSL, the digital signal is conveyed between modems placed at either end of the copper loop. The advantages of statistical multiplexing have led to the digital signals being organized into transport packets (whether they be Asynchronous Transfer Mode (ATM) packets or Ethernet packets. Over either of these are carried Internet Protocol (IP) packets conveying all of the broadband services.
Cable networks have also been upgraded to carry broadband services to user's homes. Substantial numbers of users currently receive broadband services over cable and, again, the services are conveyed using IP packets over Ethernet.
Video material requires a data rate which varies between 1.5 Mbps (for a quality comparable to that offered by a video cassette recording) to 20 Mbps (High-Definition Television). In DSL or cable networks, these higher application data rates means that a mechanism is needed to manage contention for the capacity available towards the user's home. This capacity management includes both the maximum available capacity for any one user and the shared capacity towards the DSL Access Multiplexer (DSLAM) or Cable Modem Termination System (CMTS). This capacity (sometimes termed “backhaul” capacity) may be shared by several hundred users, and contention for the capacity will also need to be managed as users demand more choice in the material they view.
The backhaul capacity may be divided into VLANs, where each VLAN is the aggregate bandwidth that a single internet service provider can exploit to deliver services to many end-users. In this case, the active users who are receiving internet services via this service provider will share the capacity of this VLAN aggregate. In an alternative arrangement, several internet service providers may jointly share the backhaul capacity and some means may be provided so that each service provider obtains a fair share.
Under the first arrangement, where the capacity of a VLAN is available to a single service provider, there is freedom for that service provider to make unique choices about cost and QoS. The choice is a balance between insufficient capacity would result in frequent congestion and more dissatisfaction among the end users. Too much capacity results in excess cost for the provision of services.
Under the second arrangement, where several service providers share capacity, there may be more opportunity to exploit unused capacity that belongs to one of the fair shares. This has advantages but also some disadvantages. The advantage is that the cost of aggregate bandwidth may be kept lower for each of the service providers. Instead they may rely on the availability of unused bandwidth when otherwise there would have been dissatisfaction among their end users due to congestion. The disadvantage is that the availability of extra bandwidth is uncertain, being dependent on the patterns of usage of end users of each of the sharing service providers. Another disadvantage is the non-uniqueness of the cost/QoS offering of each of the service providers. However, this disadvantage can be overcome by altering the nature of the fair-share controls of the aggregate bandwidth, so that one service provider is preferred over another in terms of the amount of capacity its users are entitled to get when loading levels are high.
An arrangement where capacity is shared among several service providers and the capacity is unequally divided among them when loading levels are high can lead to even greater uncertainty that extra capacity is there when needed, especially for those service providers that receive a lower amount of capacity that the average.
It is the management of this issue to remove the uncertainty that extra bandwidth is there when needed and to provide just enough bandwidth, on backhaul links or other network links, that is the subject of the present patent.
In a conventional circuit-switched telephone network, the problem of contention for scarce telecommunication resources is dealt with by simply preventing a user from receiving (or sending) any traffic unless the necessary capacity to carry that traffic can be reserved beforehand. The capabilities of multi-services packet networks have also been developed to include call admission control schemes—examples include the Resource Reservation Protocol (RSVP). Although such schemes can prevent congestion when all new communications or calls are admitted or rejected using these principles, QoS management must also manage so-called “elastic” traffic where there is potentially a need for a minimum guaranteed rate but frequently a desire to transmit the flow as fast as possible, subject to network congestion constraints and constraints on maximum sending rates.
An alternative to the use of connection admission control in packet networks is to use reactive flow control. These schemes allow users access to communications resources but attempt to cause senders to decrease their sending rate on the onset of congestion. The scheme used for reliable transmission across the Internet (Transmission Control Protocol) is the most common example. This is unsuitable for video flows however, since real-time video servers cannot reduce their sending rate.
Most flow control schemes, applied to elastic applications, result in some reduction of the rate available at the onset of congestion. Some flow control schemes are more sophisticated, classifying traffic into different classes, with some classes being more likely to suffer packet delay or discard than others. In situations where such classification is not available or where most traffic is within one class, alternative solutions must be provided. One such alternative solution which concentrates the adverse effects of ATM cell discard on one IP packet at a time is described in ‘Early Selective Packet Discard for Alternating Resource Access of TCP over ATM-UBR’ by Kangsik Cheon and Shivendra S. Panwar, in the Proceedings of IEEE Conference on Local Computer Networks LCN 97, Minneapolis, Minn., Nov. 2-5, 1997, incorporated by reference herein.
A discussion toward the Internet based Next Generation Network (NGN) is actively progressed around the standards bodies including the ITU-T (International Telecommunication Union—Telecommunication Standardization Sector) and ETSI (European Telecommunications Standards Institute), IEEE (Institute of Electrical and Electronics Engineers), IETF (Internet Engineering Task Force), and etc. The roles of the standard bodies are different. The IEEE and IETF develop the core technology for specific problems in layer 2 and layer 3, respectively. ITU-T and ETSI develop the network architecture and control procedure.
A QoS control or resource control architecture has been developed in the several standard bodies. To name a few, they are ITU-T, ETSI, Cable Lab, 3GPP, MSF, and the DSL forum. Among those organization, CableLab, and DSL forum, 3GPP, and ETSI define the QoS control architecture in a particular case while ITU-T defines the generic architecture that can cover the outcomes of other standard bodies.
CableLab defines the dynamic QoS (DQoS) control architecture as described in PacketCable Specification “PacketCable Dynamic Quality-of-Service” for the Hybrid Fiber and Coaxial (HFC) network. The control architecture is designed for the uniqueness of the HFC network. In the HFC network, multiple CMs (Cable Modems) share an upstream channel to CMTS (Cable Modem Termination System). The bandwidth is controlled based on layer 2 MAC protocol called DOCSIS (Data Over Cable System Interface Specification) as described in “Data-Over-Cable Service Interface Specifications, Radio Frequency Interface Specification”, by Cable Television Laboratories, Inc., Jul. 30, 2003. The layer 2 level QoS guarantee mechanism is defined from the DOCSIS version 1.1. The goal of the DQoS is supporting the QoS guaranteed service through HFC network.
DQoS defines the procedure of the call setup signaling and the dynamic QoS control on DOC SIS interface. In the architecture, the CMS (Call Management Server) I Gate controller controls the call establishment. The guaranteed bandwidth between CM and CMTS is reserved dynamically during the call setup signaling. The CMS/Gate Controller triggers the layer 2 or layer 3 QoS signaling to reserve the bandwidth in the HFC network by sending commands to CM, CMS, or MTA (Multimedia Terminal Adapter).
DQoS has been refined through version 1.0, 1.5, and 2.0. Version 1.0 defines the basic call setup signaling procedure for both embedded MTA and standalone MTA. The embedded MTA can initiate the dynamic layer 2 QoS signaling while a standalone MTA initiates IP level QoS signaling. Version 1.5 and 2.0 defines the QoS control architecture when SIP (Session Initiation Protocol) based call setup signaling is used. DQoS 2.0 is defined especially for interoperability with IP Multimedia Subsystem (IMS) which is the SIP based call setup architecture developed in 3rd Generation Partnership Project (3GPP). PacketCable Multimedia, as described in PacketCable Specification “Multimedia Specification”, Dec. 21, 2005, has been developed for simple and reliable control for the multimedia service over cable network. It defines the service delivery framework for the policy based control on multimedia service. The simple procedure for time or volume based resource authorization, resource auditing mechanism, and security of the infrastructure are defined in PacketCable Multimedia.
Such developments as this strongly suggest that new QoS mechanisms should take account of, and build on top of, the underlying deployment of QoS controls.
Again, the DSL forum defines the resource control at the DSL (Digital Subscriber Line) access network, as described in Technical Report 59 DSL Forum “DSL Evolution—Architecture Requirements for the Support of QoS-Enabled IP Services”. Unlike Cable network, DSL modem is connected to the subscriber through the dedicated line. Layer 2 level dynamic QoS control between DSL modem and Digital Subscriber Line Access Multiplexer (DSLAM) is not required. The DSL forum focuses more on resource control in the home network especially resource control of multiple terminals behind the home gateway.
The resource control architectures defined in the above mentioned two standard bodies—PacketCable and DSL Forum focus on a specific transport technology (i.e., HFC network and DSL network). The scope of DQoS and DSL forum is mainly within network operator's view. Unlike these, RACF (Resource and Admission Control Functions), as described in ITU-T recommendation Y.2111 “Resource and Admission Control Functions in NGN”, and RAGS (Resource and Admission Control Sub-system), as described in ETSI ES 282 003 V1.1.1 (2006-03), “Resource and Admission Control Sub-system (RAGS); Functional Architecture”, define the resource control architecture in more general aspect.
The QoS control architecture in both RACF and RAGS are closely related with 3GPP (3rd Generation Partnership Project) effort. The 3GPP is originally founded for developing new service architecture over cellular network, especially for GSM (Global System for Mobile communication) network. During this effort, 3GPP developed the IMS (IP Multimedia Subsystem) for controlling the IP multimedia services in the areas of session control, service control, and management of database of the subscribers. Even though IMS is initially developed for the evolution of GSM cellular network, its framework can be applicable for any types of transport technologies. The IMS architecture has been adopted to the other QoS control architectures such as 3GPP2 MMD (Multimedia Domain), ETSI TISPAN (Telecoms & Internet converged Services & Protocols for Advanced Networks), and ITU-T NGN. Thus, both RAGS and RACF are interoperable with IMS.
In general, RACF and RAGS are very similar with each other. The two standards bodies are closely interacted in developing their architecture. There is no significant conflict between the two, but there are still differences, as described in ITU-T NGN-GSI Contribution, “Comparison of TISPAN RAGS and ITU-T RACF”. One of differences is the range of the control region. The control region of RAGS covers the access network and the edge of the core network. The access network is defined as the region where the traffic is aggregated or distributed without dynamic routing. The resource control in the access network is done in layer 2 level. The core network is the region that the IP routing starts. The core network is out of scope in the RAGS. RACF, however, covers both core and access network. RACF covers both fixed and mobile networks while RAGS is defined for the fixed network. For the control mechanism, the RACF defines more control scenarios than RAGS. Therefore, RAGS is considered as a subset of RACF.
ITU-T defines QoS control functions based on its NGN architecture. One of the important concepts in the ITU-T NGN architecture is the independence of the transport and the service, as described in ITU-T recommendation Y.2012 “Functional Requirements and Architecture of the NGN”. The transport is concerning about the delivery of packets of any kind generically, while the services are concerns about the packet payloads, which may be part of the user, control, or management plane. In this design principle, the NGN architecture is divided into two stratums—Service Stratum and Transport Stratum. Under the concept of the independence of a service and transport functions, the network resource and reliability are guaranteed by the network side upon request from the service stratum. Service Stratum is responsible for the application signaling and Transport Stratum is responsible for reliable data packet forwarding and traffic control. The service stratum can be a simple application server or a full-blown system such as IMS (IP Multimedia Sub-system).
Transport control function is located in Transport stratum interfacing with the Service stratum. It determines the admission of the requested service based on the network policy and the resource availability. It also controls the network element to allocate the resource once it is accepted. Resource and Admission Control Functions (RACF) is responsible for the major part of the admission decision and resource control of the transport function. Details of RACF mechanism can be found in “Overview of ITU-T NGN QoS control”, by Jongtae Song, Mi Young Chang, Soon Seok Lee, and Jinoo Joung, IEEE Communication Magazine, Vol. 45, No. 9, September 2007 and ITU-T recommendation Y.2111 “Resource and Admission Control Functions in NGN”, incorporated by reference herein.
This developing infrastructure needs to be taken account of when considering new QoS mechanisms.
Review of current per-flow QoS controls Flow level transport technology is not a new concept. The core technologies for traffic management schemes such as flow level scheduling, policing, and sharing are already available in a commercial product, as described in “Flow based control for Future Internet” by Jongtae Song, presented in Future Internet Forum (FIW) in July 2007, incorporated by reference herein. The current deployment of flow base control, however, is limited only at the edge of the network. Typical examples of flow base control are traffic monitoring and packet inspection, PacketCable access, session border controller, edge router, and interworking between two networks. They are mostly stand-alone solution at the edge of the network.
However, flow level traffic control only at the edge cannot guarantee the flow level QoS. Furthermore, DiffServ guarantees the QoS only if the premium traffic load is very low(˜ under 10%), as described in “Providing guaranteed services without per flow management” by I. Stoika and H. Zhang in CM SIGCOMM, September 1999, pp. 91-94, incorporated by reference herein. On the other hand, having scalable control architecture for flow level traffic control along the data path is a challenging issue, because the number of flows in a network is huge.
There are several schemes proposed for the scalable control of traffic using flow level mechanisms. These are listed below.
(1). Flow Aware Network (FAN) France Telecom proposed a Flow Aware Network (FAN), as described in “A new direction for quality of service: Flow-aware networking” by S. Oueslati and J. Roberts in Proc. Conference on Next Generation Internet Network (NGI), April 2005, incorporated by reference herein. FAN applies three different regimes based on the network status. They are the “transparent regime”, “elastic regime”, and “overload regime”. The transparent regime is applied when the network has no congestion at all. The elastic regime is applied when the network experiences the occasional traffic congestion because of a few high rate data flows. The overload regime is applied when the traffic overloads the link capacity in the network.
No traffic control is required in the transparent regime. The traffic control is effective only in the overload or elastic regime. In the elastic regime, the network enforces the bandwidth limit for every flow. Every flow is assigned the same amount of bandwidth. In the overload regime, new flows are blocked to protect existing flows. To reduce the control complexity, an implicit approach is preferred where no signaling is required for controlling the network. Each node makes locally optimal decision based on local observation.
The main focus of FAN is the simplicity. It requires no signaling. Only implicit admission control is required upon congestion. Although the control mechanism is very simple, it is shown that the network is stabilized remarkably in FAN. However, this architecture is designed mainly for network stabilization aspect. Every flow is treated equally. In order to support various of QoS requirements for individual flow, this architecture should be improved.
(2). Flow Sate Aware (FSA) technologies FSA is developed to provide different QoS for the individual flow. FSA defines the service types based on typical example of Internet services, as described in ITU-T Recommendation Y.2121, “Requirements for the support of stateful flow-aware transport technology in an NGN” and “Changing the internet to support real-DOCS time content supply from a large fraction of broadband residential users” by J. L. Adams, L. G. Roberts, and A. I. Jsselmuiden, BT Technology Journal, Vol. 23, No. 2, pp 217-231, April 2005, incorporated by reference herein. They are Maximum Rate (MR), Guaranteed Rate (GR), Variable Rate (VR), and Available Rate (AR). GR is designed for applications requiring guaranteed bandwidth for the entire duration of the flow. MR is designed for streaming media such as video and voice. AR is designed for data traffic flow where the application can setup the flow rate at the maximum rate that the network can currently support. VR is the combination of AR and MR. VR could be used for obtaining a maximum response time for a transaction (e.g., a stock trade with maximum transaction time). The MR portion guarantees the minimum guaranteed bandwidth and AR portion is for use available network resource. FSA divides the network resource into two portions. One is Fixed Rate (FR) and the other is Network Rate (NR). FR is requested when flow needs a fixed rate available during the service. NR is requested when flow sends buffered data using network available bandwidth. Service type GR and MR request FR, AR requests NR, and VR requests both NR and FR. The detail requirement is defined in ITU-T Recommendation Y.2121, “Requirements for the support of stateful flow-aware transport technology in an NGN”.
FR and NR are requested by the signaling, as described in ITU-T Study Group 11, Draft Recommendation Q.flowstatesig on signaling protocols and procedures relating to Flow State Aware access QoS control in an NGN, Editor J. L. Adams, incorporated by reference herein, and every node along the path configures its resource based on the requested FR and NR. For the call setup signaling, the source node and destination node exchanges the control messages. [
Both approaches, FAN and FAS, give an insight for flow based traffic control. FAN shows that even very simple flow level traffic control can stabilize the network efficiently. FSA shows that the network resource can be divided into FR and NR. It also indicates that the transit nodes should be controlled for end-to-end flow level QoS.
However, the two approaches have outstanding issues. As mentioned earlier, FAN is not designed for supporting various QoS requirement of the service. Its main objective is stabilizing the overall network performance. In this viewpoint, FAN treats every flow equally. This may stabilize the transport network in general, but the network provider cannot generate additional profit, because FAN cannot support the service that has special QoS treatment. Good business model is hardly found in this case.
FSA is designed for supporting various QoS requirement. Its implementation can be done in both the in-band signaling, as described in ITU-T Study Group 11, Draft Recommendation Q.flowstatesig on signaling protocols and procedures relating to Flow State Aware access QoS control in an NGN, and out-of-band signaling. The in-band signaling procedure requires the every node exchanges the request and response. The request need to be examined by the all the transit node. The destination node generates the response message, and source node finds the agreed rate from the response message. In this approach every FSA node should maintain the flow state.
Requiring FSA signaling feature in every user terminal is possible. However, by making the terminal independent of FSA, we can have several benefits. First, the terminal usually has different capability. The network architecture should be flexible enough to support multiple types of terminal in a network. The terminal can support transport QoS signaling but also has application signaling. The application signaling is common for all terminal types. In order to support more terminal types, the QoS signaling of terminal should be designed in application level. Second, the network security is important in managed network. Enabling the signaling function in the terminal may cause the security hole in the network. For resolving this problem, ITU-T Recommendation Y.2121, “Requirements for the support of stateful flow-aware transport technology in an NGN” specifies the mechanism to authorize the in-band signaling in the application signaling phase. FSA signaling initiated in the network side from the network edge can be another option to avoid the security problem.
In both FAN and FSA approaches, focus is mainly in the transport control. In order to take account of the existing deployment of QoS functions, the concept of RACF function needs to be considered.
(3). FSA with out-band signaling. In this proposal, the FSA signaling is combined with RACF. CPE (Customer Premises Equipment) or user terminal should be able to request the flow level resource in any kind of application signaling. In this aspect, the CPE and user terminal should be protocol independent.
Second, this proposal focuses flow-based control in the access network, not the core. In the access network, user data traffic is statically routed to the edge of the core network, and the downstream data traffic is statically forwarded from the edge of the core network to the end user. Core supports both IP based dynamic routing and layer 2 based static forwarding. The traffic volume, number of flows, and dynamicity of traffic are different in the core and access. Traditional access network controls the bandwidth based on subscribed bandwidth per user in L2 level. For flow level traffic control, however, the bandwidth should be controlled by individual flow. Flow awareness capability is required in the access nodes. The static packet forwarding and scheduling in the flow level granularity is required in the access network. The call by call traffic control and policy enforcement from control plane (e.g., RACF) should be done in micro flow level. In the core, the number of flows is high and call by call flow level control in RACF is difficult to achieve. In the core side network, therefore, the traffic should be controlled in aggregate level rather than micro flow level. The reliability and monitoring capability will be more important in the core. The flow based traffic control and the aggregated traffic control should be translated at the edge of the core network.
These design principles are further illustrated in
However, none of the above proposals provides a method of managing contention in a packet network which allows flow-based QoS mechanisms to operate without end-user signaling and support:
In ‘Flow State Aware QoS Management Without User Signaling’, U.S. Provisional Application No. 61/118,964 filed Dec. 1, 2008, and ‘Flow State Aware QoS Aggregate Management Without User Signaling’, U.S. Provisional Application No. 61/185,843 filed Jun. 10, 2009, solutions are described that do not require signaling. Both solutions assume a fixed assignment of capacity is provided to each aggregate VLAN. Solution in U.S. Provisional Application No. 61/118,964 filed Dec. 1, 2008 gives every flow either a guaranteed rate or some assignment of a minimum rate and some assignment of the remaining unused capacity which is adjusted according to the number of flows and the preference priority of a flow. Solution in U.S. Provisional Application No. 61/185,843 filed Jun. 10, 2009 does not assign capacity to a single flow and does not discard any packets of any flows until the fixed capacity of an aggregate is nearing congestion. It causes less packet deletions than U.S. Provisional Application No. 61/118,964 filed Dec. 1, 2008, although, if there is evolution towards some use of signaling for some of the services and for some of the flows, U.S. Provisional Application No. 61/185,843 filed Jun. 10, 2009 is potentially more unfair on those flows that are being policed through signaling while other flows, established without signaling, are free to change their rates arbitrarily. In this case, U.S. Provisional Application No. 61/118,964 filed Dec. 1, 2008 is believed to provide a fairer arrangement. The aforesaid patent applications are incorporated by reference herein.
However, both solutions in U.S. Provisional Application No. 61/118,964 filed Dec. 1, 2008 and U.S. Provisional Application No. 61/185,843 filed Jun. 10, 2009 assume the aggregate VLAN capacities are constant. The choice of the capacity is important to the service provider. There is a need to avoid congestion becoming too frequent. However, there may be uncertainty about the traffic load, especially with the take-up of new applications among the end users. Therefore, it is typical for the service provider to provide excess capacity to ensure congestion is infrequent. But, as application data rates continue to increase, this approach of always having excess capacity becomes more and more costly for the service provider and, potentially, more costly for the user.
Thus, novel methods of operating a communications network are needed.
The inventive methodology is directed to methods and systems that substantially obviate one or more of the above and other problems associated with conventional techniques for operating a communications network.
Various embodiments of the present invention overcome the above-mentioned difficulties, allowing service providers to exploit both:
This achieves the significant reduction of both the duration and frequency of incidents of congestion at minimum cost in terms of capacity deployed.
According to the present invention, there is provided a method of operating a packet subnet that aims to solve the problem of managing contention in a packet network allowing:
According to a first aspect of the embodiments of the present invention, the said method of operating the subnet comprises:
packet header information at any level of encapsulation;
signaling information related to that flow identity;
policy attributes associated with the physical link on which the packet arrived or will depart;
measured rates applying to the flow rate of the said flow, or the measured jitter in flow rate; and
measured rates applying to the total traffic on one or more of the said aggregates which the said new flow is associated with, or the measured jitter in such said rates.
Flow rate or jitter in rate measured on any flow;
Flow rate or jitter in flow rate measured on any aggregate;
Flow count in any aggregates;
Flow discard probability on the flow of the latest arriving packet;
Policy information on any aggregates associated with the flow of the latest arriving packet;
Packet discard measurements on any aggregate;
Packet discard measurements on any flow;
Packet delay measurements on any flow or averaged on any aggregate;
Received signaling related to any flow, or received signaling related to any aggregate.
According to this first aspect of the embodiments of the present invention, allowing the said pre-determined limits or thresholds indicative of a change in bandwidth requirement on one or more aggregates associated with the flow identity of the said latest arriving packet to include:
According to this first aspect of the embodiments of the present invention, optionally a method where the said observable indication that a change in aggregate capacity is required on one or more aggregates includes the sending of an indication towards a verification function that determines if the said indicated change in capacity can be permitted or modified.
According to this first aspect of the embodiments of the present invention, optionally a method where the said verification function reduces the capacity of a donor aggregate by sending an indication towards a policing function that lowers the policing thresholds on rate or rate jitter of said donor aggregate such that, when said lowered policing thresholds are determined to be exceeded by measurement of the latest and recent arriving packets of the total traffic of said donor aggregate, a number of packets are discarded instead of being transmitted so that the remaining transmitted packets do not exceed the lowered policing rates.
According to this first aspect of the embodiments of the present invention, optionally a method where the said verification function, having observed said indication for an increase in capacity on an aggregate, optionally determines for this said aggregate which donor aggregates associated with the said aggregate shall be decreased in capacity and by what amount of capacity. Similarly, where the verification function observed a said indication for a decrease in capacity of the said aggregate, which donor aggregates associated with the said aggregate shall be increased in capacity and by what amount of capacity.
According to this first aspect of the embodiments of the present invention, optionally a method where a donor aggregate has no flows and its capacity is an unused pool of capacity that can be used to increase the capacity of other aggregates and its capacity can be increased by the release of capacity from other aggregates.
According to this first aspect of the embodiments of the present invention, optionally a method where the said unused pool of capacity is shared among several other flow aggregates and the said verification function controls the sharing of its pool of capacity such that:
According to this first aspect of the embodiments of the present invention, optionally a method where the said unused pool of capacity is shared among several other flow aggregates and the said verification function controls the sharing of its pool of capacity such that:
Under normal operating conditions the said aggregate requiring guaranteed assignments of capacity indicates to the verification function that a decrease in capacity should be effected;
Under abnormal operating conditions where current levels of guaranteed capacity cannot be sustained.
According to this first aspect of the embodiments of the present invention, optionally a method where the said determination of an initial or sustained discard probability associated with a flow identity includes the assignment of a larger discard probability when, for any aggregate associated with the said flow identity, being an aggregate that has a portion of its capacity assigned on the basis of the said temporary assignment of capacity, the measured rate of that aggregate is greater than one or more threshold rates based on the said pre-determined share of capacity available to that aggregate.
According to this first aspect of the embodiments of the present invention, optionally a method where, when a packet arrives whose flow is associated with an aggregate where congestion has ceased or where traffic levels on an aggregate have fallen below some threshold indicative of the onset of congestion, or when measurements relating to any rate-based, byte count-based, or packet-count based threshold shows that measured levels are now below level(s) that had previously exceeded one or more such thresholds, then retrieving policy relating to such a change of status of this aggregate and relating to re-grading of the discard probability of the said flow, given that measured levels have fallen or congestion has disappeared.
According to a second aspect of the embodiments of the present invention there is provided a packet network node comprising:
According to this second aspect of the embodiments of the present invention, the packet network includes further means arranged in operation to provide an observable indication of a requirement for a capacity reassignment to any group of flows, which is either:
According to this second aspect of the present invention, the packet network includes further optional means arranged in operation to provide a communication identifier store for storing a set of communication identifiers and associated state information.
According to this second aspect of the embodiments of the present invention, the packet network includes further means arranged in operation to reduce or increase the discard probability associated with a flow and its related communication identifier from said communication identifier store when one or more predetermined conditions are met associated with measurements in any aggregate to which the flow belongs.
According to this second aspect of the embodiments of the present invention, the packet network includes further means arranged in operation to identify one or more flows that should be discarded when the packet rate, byte rate or the jitter of a rate in any group of flows determine that such a deletion is required.
According to this second aspect of the embodiments of the present invention, the packet network includes further means arranged in operation, on the detection that a packet rate, byte rate or the jitter of a rate in any group of flows is equal to or has exceeded a pre-determined threshold, to identify arriving packets associated with one of said communication identifiers stored in said communication identifier store; and forward packets associated with any flow identifier unless the discard probability associated with that flow identifier is set so that all packets are to be temporarily discarded.
According to this second aspect of the embodiments of the present invention, the packet network includes further means arranged in operation to reassign for any flow or group of flows the preference priorities or discard probability based on the result of one or more measurements and pre-determined thresholds related to any flow or group of flows, including means to revise the policed rate(s) of any flow or group of flows, said pre-determined thresholds being based on, but not limited to:
According to this second aspect of the present invention the packet network includes:
According to a third aspect of the embodiments of the present invention, a packet network node including a packet communications source comprising:
Means that indicate any change of capacity associated with any aggregate;
Means that indicate changes to policing rates or measurement thresholds relating to any flow or any aggregate.
Using the said methods and means, a packet subnet operator is able to temporarily concentrate the adverse effects of congestion on selected communications, whilst improving, where possible, the capacity available to the congested aggregate, with the following advantages:
This in turn has the advantage of being less annoying to users receiving communications because flows are not rejected when traffic conditions determine that new flows cannot be supported with a low discard probability and flows with a high discard probability are managed to minimize any disturbance in the received QoS.
Additional aspects related to the invention will be set forth in part in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. Aspects of the invention may be realized and attained by means of the elements and combinations of various elements and aspects particularly pointed out in the following detailed description and the appended claims.
It is to be understood that both the foregoing and the following descriptions are exemplary and explanatory only and are not intended to limit the claimed invention or application thereof in any manner whatsoever.
The accompanying drawings, which are incorporated in and constitute a part of this specification exemplify the embodiments of the present invention and, together with the description, serve to explain and illustrate principles of the inventive technique. Specifically:
In the following detailed description, reference will be made to the accompanying drawing(s), in which identical functional elements are designated with like numerals. The aforementioned accompanying drawings show by way of illustration, and not by way of limitation, specific embodiments and implementations consistent with principles of the present invention. These implementations are described in sufficient detail to enable those skilled in the art to practice the invention and it is to be understood that other implementations may be utilized and that structural changes and/or substitutions of various elements may be made without departing from the scope and spirit of present invention. The following detailed description is, therefore, not to be construed in a limited sense. Additionally, the various embodiments of the invention as described may be implemented in the form of software running on a general purpose computer, in the form of a specialized hardware, or combination of software and hardware.
An internetwork (
The network 2 comprises exchange-housed equipment (17, 18) housed in the local telephone exchange building 20 and a wide-area network 22 which connects a plurality of such DSLAMs 18 (there is normally one or more DSLAMs per exchange building, only one exchange building is shown in the drawing) towards the flow-based QoS manager 6. As will be understood by those skilled in the art, the exchange-housed equipment includes a Digital Subscriber Line Access Multiplexer (DSLAM) 18 shared between many users and, for each pair of copper wires 19, a splitter unit 17 which terminates the pairs of copper wires 19. The splitter unit 17 is effective to send signals within the frequency range used for normal telephony to the Public Switched Telephone Network (not shown) and to send signals in higher frequency bands to the DSLAM 18.
The user's home network may comprise a PC 10, a digital television 15, a splitter unit 14, a router I set-top box 16 which incorporates an Asymmetric Digital Subscriber Line (ADSL) modem 13, a cable 12 interconnecting the modem 13 and the splitter unit 14, and cables connecting the router 16 to the PC 10 and the digital television 15. The splitter unit 14 is effective to send signals within the frequency range used for normal telephony to the user's telephone 11 and to send signals in higher frequency bands to the ADSL modem 13. The ADSL modem 13 represents the network termination point of network 2.
The ISP's network 4 comprises an IP router 24, a content provider's video server 27, and a Local Area Network 30 which interconnects them. The previously mentioned Internet link 9 is connected to the IP router 24.
Broadband services typically utilize Ethernet as the layer 2 protocol. Again, typically in such a case, the DSLAM terminates the ATM if PPoA is used over the copper pair, and the DSLAM encapsulates the PPP payload in Ethernet for forwarding to the function 6. Link 5 is the aggregate capacity between function 6 and the DSLAMs and it is further subdivided into separate VLANs with either dedicated capacity per DSLAM or capacity that can be borrowed but is pre-emptively available when traffic conditions require the full capacity that can be available towards or from any one DSLAM.
Two other connection products 5 are based on the IP layer and routing across an MPLS platform.
In these cases, the PPPoE connections will terminate on a BRAS function within network 22. The two options are:
In
Function 6 shapes the aggregate traffic of a specific VLAN according to the given maximum current rate allowable, and given current burst tolerance allowable. It also shapes the aggregate traffic towards each end user, again according to the current maximum rate allowable and given current burst tolerance allowable. In each case, it applies FSA QoS principles to incidents of congestion or incidents of excessive burstiness with respect to the individual flows that make up any particular aggregate traffic.
The Discard Control and Packet Forwarding function 6.2 is the main QoS logic which receives inputs from 6.1 and the Flow and Aggregate Measurements and Change Verification function 6.3. Using these inputs, function 6.2 operates to determine if the latest arriving packet should be deleted or forwarded.
According to one embodiment, the method which function 6.3 uses to assist function 6.2 to determine a decision on whether to forward a packet or deleting it are:
1. To indicate to function 6.2 different levels of congestion that have been reached on an aggregate, so that function 6.2 can choose the appropriate number of flows for packet discard actions and, for example select the lowest priority flows first.
2. At any level of congestion, or at a threshold level below the first level that would cause a congestion indication to be sent to function 6.2, the function 6.3 determines whether an increase in bandwidth can be obtained on the aggregate. Or, where congestion levels are falling, or has reached a lowest threshold level below any level that would cause function 6.2 to apply any packet deletion to any arriving packet of that aggregate, to determine whether a decrease in bandwidth is appropriate for the aggregate.
When such a congestion condition is notified by function 6.3.1 (see
This initial group of flows is supplemented by further flows selected for discard if function 6.3.1 indicates to function 6.2.2 that congestion has risen to a greater level on an aggregate, as determined by comparison with the said congestion thresholds for that aggregate.
In one embodiment, when any level of congestion is detected by function 6.3.3, function 6.3.1 reduces the capacity available to the entire aggregate of flows that are contained in the congested aggregate and are classified as “best effort” flows. For example, aggregate 41 towards DSLAM2 in
In a preferred embodiment, when function 6.2.2 receives an indication from 6.3.1 that a best effort aggregate is congested, it marks the entire best effort aggregate as subject to temporary discard of all arriving best effort packets until function 6.3.1 further indicates to function 6.2.2 that congestion has ceased on the said congested best effort aggregate.
The function 6.2.1 (see
In every case above, one preferred embodiment is that sufficient flows are de-selected until a pre-determined number of flows still remain as selected, according to the congestion level. Finally, when congestion disappears, as indicated by function 6.3.1 towards 6.2.2, all flows are de-selected.
In a preferred embodiment, when congestion is decreasing on an aggregate, function 6.3.1 will not release any part of the bandwidth that has been assigned to the aggregate until a lowest threshold level has been reached on measured rate or rate jitter for that aggregate, where this lowest level is below any threshold that would cause function 6.2.1 to be deleting packets of some flows or flow aggregates.
The functions of the main logic 6.2.2 are to receive indications from function 6.3.1 and perform flow selection actions for packet discards to be performed as already described. Similarly the deletion actions of 6.2.1, responsive to the flow selection actions of 6.2.2, have already been described above. If packets are not deleted they are transmitted by function 6.2.1 from the buffer 6.2.3 to the output link 5.
The function 6.3.2 measures rates on individual flows and on aggregates. For aggregates, it also compares the measured rate against one or more predetermined thresholds and indicates an alert to function 6.1 when the aggregate rate is equal to or exceeding one of these thresholds. It also measures the flow rate of a flow. In a preferred embodiment it will include an initial measurement of the flow rate for a sufficiently short interval of time that allows the classifier to be quickly updated about this information and potentially change the classification given to that flow. Again, care must be used so that the interval is sufficiently short, yet long enough that short-term variations in the local rate, due to packet clustering, are not confused with the average rate of the flow.
The main logic function 6.3.1 acts to receive indications from other functions 6.1 and 6.2 and to schedule tasks in functions 6.3.2 and 6.3.3 and to receive the outputs of these tasks and format them into output indications towards 6.1 and 6.2.
Function 6.3.1 also includes a sub-function termed the Verification Function 6.3.1.2 (see
Function 6.3.1.1 is informed by 6.3.3 that congestion thresholds have been reached on an aggregate, either because congestion is increasing or decreasing. The function 6.3.1.1 sends an indication to either a co-located function 6.3.1.2 (
Policy decisions on the addition and subtraction of bandwidth may be varied to suit customer needs including, but not limited to, the following:
Giving bandwidth back to the donor re-assignable unused capacity only after all other donor aggregates have received back specified amounts of bandwidth.
Giving back specified amounts of bandwidth in any pre-assigned sequence that includes all donor aggregates and the donor re-assignable unused bandwidth, whether or not a donor aggregate or the donor re-assignable unused bandwidth gave bandwidth to the aggregate.
Defined limits for the amount of capacity that can be added from a donor aggregate may be calculated based on either static unchanging values, or dynamic values based on the current traffic that the donor is carrying or the frequency which the donor is experiencing congestion.
Capacity may be added on a temporary basis above limits set for that aggregate on the basis that such added temporary capacity will be removed when other aggregates require it where such aggregates are below the limits set for capacity that may be added. In such a case the aggregate with added temporary capacity becomes a new donor aggregate with respect to other aggregates that are entitled to have added capacity. It remains in the state of donor until all the temporary added capacity is removed.
Function 6.3.1.2 indicates to 6.3.3 and 6.3.2 any change in the rates or thresholds that should now be used as a result of a change of capacity, relating to that aggregate and the donor aggregates. Function 6.3.1.2 maintains the remaining unused capacity of any donor re-assignable unused capacity.
The computer platform 1001 may include a data bus 1005 or other communication mechanism for communicating information across and among various parts of the computer platform 1001, and a processor 1005 coupled with bus 1001 for processing information and performing other computational and control tasks. Computer platform 1001 also includes a volatile storage 1006, such as a random access memory (RAM) or other dynamic storage device, coupled to bus 1005 for storing various information as well as instructions to be executed by processor 1005. The volatile storage 1006 also may be used for storing temporary variables or other intermediate information during execution of instructions by processor 1005. Computer platform 1001 may further include a read only memory (ROM or EPROM) 1007 or other static storage device coupled to bus 1005 for storing static information and instructions for processor 1005, such as basic input-output system (BIOS), as well as various system configuration parameters. A persistent storage device 1008, such as a magnetic disk, optical disk, or solid-state flash memory device is provided and coupled to bus 1001 for storing information and instructions.
Computer platform 1001 may be coupled via bus 1005 to a display 1009, such as a cathode ray tube (CRT), plasma display, or a liquid crystal display (LCD), for displaying information to a system administrator or user of the computer platform 1001. An input device 1010, including alphanumeric and other keys, is coupled to bus 1001 for communicating information and command selections to processor 1005. Another type of user input device is cursor control device 1011, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 1005 and for controlling cursor movement on display 1009. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
An external storage device 1012 may be coupled to the computer platform 1001 via bus 1005 to provide an extra or removable storage capacity for the computer platform 1001. In an embodiment of the computer system 1000, the external removable storage device 1012 may be used to facilitate exchange of data with other computer systems.
The invention is related to the use of computer system 1000 for implementing the techniques described herein. In an embodiment, the inventive system may reside on a machine such as computer platform 1001. According to one embodiment of the invention, the techniques described herein are performed by computer system 1000 in response to processor 1005 executing one or more sequences of one or more instructions contained in the volatile memory 1006. Such instructions may be read into volatile memory 1006 from another computer-readable medium, such as persistent storage device 1008. Execution of the sequences of instructions contained in the volatile memory 1006 causes processor 1005 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor 1005 for execution. The computer-readable medium is just one example of a machine-readable medium, which may carry instructions for implementing any of the methods and/or techniques described herein. Such a medium may take many forms, including but not limited to, non-volatile media and volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 1008. Volatile media includes dynamic memory, such as volatile storage 1006.
Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punchcards, papertape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH-EPROM, a flash drive, a memory card, any other memory chip or cartridge, or any other medium from which a computer can read.
Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor 1005 for execution. For example, the instructions may initially be carried on a magnetic disk from a remote computer. Alternatively, a remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system can receive the data on the telephone line and use an infrared transmitter to convert the data to an infra-red signal. An infra-red detector can receive the data carried in the infra-red signal and appropriate circuitry can place the data on the data bus 1005. The bus 1005 carries the data to the volatile storage 1006, from which processor 1005 retrieves and executes the instructions. The instructions received by the volatile memory 1006 may optionally be stored on persistent storage device 1008 either before or after execution by processor 1005. The instructions may also be downloaded into the computer platform 1001 via Internet using a variety of network data communication protocols well known in the art.
The computer platform 1001 also includes a communication interface, such as network interface card 1013 coupled to the data bus 1005. Communication interface 1013 provides a two-way data communication coupling to a network link 1015 that is coupled to a local network 1015. For example, communication interface 1013 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 1013 may be a local area network interface card (LAN NIC) to provide a data communication connection to a compatible LAN. Wireless links, such as well-known 802.11a, 802.11b, 802.11g and Bluetooth may also be used for network implementation. In any such implementation, communication interface 1013 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link 1013 typically provides data communication through one or more networks to other network resources. For example, network link 1015 may provide a connection through local network 1015 to a host computer 1016, or a network storage/server 1017. Additionally or alternatively, the network link 1013 may connect through gateway/firewall 1017 to the wide-area or global network 1018, such as an Internet. Thus, the computer platform 1001 can access network resources located anywhere on the Internet 1018, such as a remote network storage/server 1019. On the other hand, the computer platform 1001 may also be accessed by clients located anywhere on the local area network 1015 and/or the Internet 1018. The network clients 1020 and 1021 may themselves be implemented based on the computer platform similar to the platform 1001.
Local network 1015 and the Internet 1018 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link 1015 and through communication interface 1013, which carry the digital data to and from computer platform 1001, are exemplary forms of carrier waves transporting the information.
Computer platform 1001 can send messages and receive data, including program code, through the variety of network(s) including Internet 1018 and LAN 1015, network link 1015 and communication interface 1013. In the Internet example, when the system 1001 acts as a network server, it might transmit a requested code or data for an application program running on client(s) 1020 and/or 1021 through Internet 1018, gateway/firewall 1017, local area network 1015 and communication interface 1013. Similarly, it may receive code from other network resources.
The received code may be executed by processor 1005 as it is received, and/or stored in persistent or volatile storage devices 1008 and 1006, respectively, or other non-volatile storage for later execution.
Finally, it should be understood that processes and techniques described herein are not inherently related to any particular apparatus and may be implemented by any suitable combination of components. Further, various types of general purpose devices may be used in accordance with the teachings described herein. It may also prove advantageous to construct specialized apparatus to perform the method steps described herein. The present invention has been described in relation to particular examples, which are intended in all respects to be illustrative rather than restrictive. Those skilled in the art will appreciate that many different combinations of hardware, software, and firmware will be suitable for practicing the present invention. For example, the described software may be implemented in a wide variety of programming or scripting languages, such as Assembler, C/C++, perl, shell, PHP, Java, etc.
Moreover, other implementations of the invention will be apparent to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. Various aspects and/or components of the described embodiments may be used singly or in any combination in the communications network and methods of operating of a communications network. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.
This application is a continuation of U.S. application Ser. No. 14/171,605 filed on Feb. 3, 2014, which is a continuation of U.S. application Ser. No. 12/828,150, filed on Jun. 30, 2010, now U.S. Pat. No. 8,693,332 issued Apr. 8, 2014, which claims priority to provisional application No. 61/221,830, filed on Jun. 20, 2009, the contents of all of which are incorporated herein in their entireties by reference.
Number | Date | Country | |
---|---|---|---|
61221830 | Jun 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14171605 | Feb 2014 | US |
Child | 15688712 | US | |
Parent | 12828150 | Jun 2010 | US |
Child | 14171605 | US |