A computer system can include a centralized server or service card that provides data to a plurality of other computers or cards. In such a centralized architecture, the server or service card is required to provide data to multiple other computers or cards at data rates that meet predefined criteria. Criteria include contracted rates, physical data channel rates, and quality of service objectives. In some applications, the component of the centralized server responsible for shaping the data to the required rate is incapable of meeting the criteria without an assisting circuit for adjusting the rate of the shaping component. The assisting circuit for adjusting the rate of the server or centralized card is responsible for correlating the behavior of the server card with the requirements of the systems that are receiving the information and using this knowledge to adjust the rate shaping behavior of the server or centralized card.
In one aspect, there are systems and methods that include receiving data at a traffic rate scheduler and determining an amount of interference traffic to send to the traffic rate scheduler. The systems and methods also include inserting interference traffic with the data in the traffic rate scheduler.
Other embodiments can also include one or more of the following. Inserting interference traffic can modify a data output rate of the traffic rate scheduler. Inserting interference traffic with the data for delivery to the queue in the traffic rate scheduler can include inserting the interference data in a queue. The queue can be a priority queue. An amount of interference traffic can be an ongoing rate of interference traffic or a quantity of interference traffic.
The systems and methods can include receiving information about the state of a system receiving the data, an output data rate of the traffic rate scheduler, and a data rate of data entering the traffic rate scheduler. Determining an amount of interference traffic sent to the traffic rate scheduler can include determining an amount of interference traffic sent to the traffic rate scheduler based on the information. The state of a system receiving the data can refer to the amount of data in the queue of another scheduling system or can refer to the amount of data in the queue of a transmission system. The information can include a class of service of the data or a format of the data.
The systems and methods can also include selecting the interference traffic for delivery as if the interference traffic was data. The systems and methods can also include discarding the interference traffic. Discarding the interference traffic can decrease the data output rate of the traffic rate scheduler or decrease an arrival rate of data at a downstream system.
The systems and methods can also include receiving information describing an algorithm employed by the traffic rate scheduler. Determining an amount of interference traffic sent to the traffic rate scheduler can include determining an amount of interference traffic sent to the traffic rate scheduler based on the information. The algorithm employed by the traffic rate scheduler can include cell shaping or asynchronous transfer mode (ATM) shaping.
In another aspect, a system includes a computer program product, tangibly embodied in an information carrier, for executing instructions on a processor, the computer program product being operable to cause a machine to receive data at a traffic rate scheduler, determine an amount of interference traffic to send to the traffic rate scheduler, and insert interference traffic with the data in the traffic rate scheduler.
Other embodiments can also include one or more of the following. The computer program product can include instructions to cause a machine to insert interference traffic to modify a data output rate of the traffic rate scheduler. The computer program product can include instructions to cause a machine to discard the interference traffic.
The computer program product can include instructions to cause a machine to receive information about a state of a system receiving the data, an output data rate of a traffic rate scheduler, a data rate of data entering the traffic rate scheduler, or the data entering the traffic rate scheduler. The instructions to cause the machine to determine an amount of interference traffic sent to the traffic rate scheduler also includes instructions to cause a machine to determine an amount of interference traffic sent to the traffic rate scheduler based on the information.
The use of interference traffic to modify the effective output rate of the traffic rate scheduler on the server or centralized card allows a single traffic rate scheduler to send data at a wide variety of transmission rates. This increases the range of applications and rates that can be supported by a particular traffic rate scheduler.
Insertion and subsequent dropping of interference traffic provides advantages such as effectively modifying the output rate of a traffic rate scheduler without changing the configured output rate of the traffic rate scheduler. The effective output rate of the system can have different behavioral characteristics than the traffic rate scheduler was configured to accommodate alone. System behaviors that the traffic rate scheduler cannot implement alone can be effected by the shaper modification circuit using interference traffic and one or more of the following information sources: traffic scheduler behavior, monitoring of system state, monitoring of traffic scheduled data rate, monitoring of input data, and configured system behavior.
Referring to
Referring to
While in this example, the state of a queue 60 is monitored to determine if an output rate from the traffic rate scheduler is adequate, other factors could be monitored. For example, the system can have a predetermined rate and the system 61 monitors the rate of data arriving to the system 61 and sends this data to the shaper modification circuit 56.
In order to modify the effective data output rate of data sent to the downstream queue 60, the traffic scheduler 50 includes a interference traffic queue 36, data queues 38 and 40, and a interference discard circuit 54. The traffic scheduler 50 combines data from the interference traffic queue 36 and data from the data queues 38 and 40 to form a rate shaped channel 48. The traffic scheduler 50 delivers data from the queues 36, 38, and 40 to the rate shaped channel 48 at a constant rate. The interference traffic queue 36 can have a higher priority than queues 38 and 40 so that interference traffic is selected before data if interference traffic is available in the interference traffic queue 36.
The queues 38 and 40 temporarily store incoming data (indicated by arrow 34) for delivery to the downstream system 61. The interference traffic queue 36 is dedicated to storing interference traffic. Interference traffic is traffic inserted into the rate shaped channel 48 to modify the data output rate of the traffic scheduler 50. Interference traffic includes a header or other indication such that a interference discard circuit 54 knows not to deliver the interference traffic to system 61. Interference traffic generally would not include user data for delivery but rather serves as filler in the shaped channel 48 from the perspective of the traffic rate scheduler 50. All data in the rate shaped channel (i.e., data from both the interference traffic queue 36 and the data queues 38 and 40) is passed at a constant rate from the rate shaped channel 48 to interference discard circuit 54 (as indicated by arrow 52). The interference discard circuit 54 determines the origin of the data, discards data originating from the interference traffic queue 36, and sends the remaining data to the downstream system 61 (as indicated by arrow 58). When interference traffic is inserted into the rate shaped channel 48 it effectively lowers the data transmission rate of the traffic scheduler 50 since the interference traffic is not delivered to the downstream system 61.
When data is available in the interference traffic queue 36, the traffic scheduler 50 selects data from the interference traffic queue 36 instead of selecting data from data queues 38 and 40. For example, the interference traffic queue 36 can be a priority queue. A shaper modification circuit 56 determines when to insert interference data into the interference traffic queue 36. The shaper modification circuit 56 receives system monitoring data 62 and based on this data determines a rate at which to insert the interference traffic into the interference traffic queue 36. For example, the system monitoring data 62 can be generated by system 61 monitoring the state of a queue 60 in system 61. In this example, if the downstream queue is full, the shaper modification circuit increases the rate at which it inserts interference data into the interference traffic queue 36. If the queue 60 in system 61 is low or empty, the shaper modification circuit 56 decreases the rate at which it inserts interference traffic into the interference traffic queue 36.
In this example the traffic rate scheduler 50 includes the interference discard circuit 54, the interference discard circuit 54 could be external to the traffic rate scheduler 50. For example, the interference discard circuit 54 could be included on the system receiving the data (e.g., system 61). Alternately, the interference traffic can be discarded anywhere between the rate shaping circuit and the system 61.
Referring to
While in this example, the traffic rate scheduler selects the interference traffic for delivery before selecting the other data, however, the traffic rate scheduler could have a different priority for the interference traffic. For example, data from a particular source can be selected before the interference traffic. In another example, the traffic rate scheduler includes a single queue and the interference traffic is inserted and delivered based on the arrival time (e.g., a first in first out (FIFO) arrangement).
For example, if a downstream system is capable of receiving data at a rate of 800 Kbits/sec and the traffic rate scheduler 50 delivers data in the rate shaped channel 48 at a rate of 1 Mbit/sec, the shaper modification circuit 56 inserts interference data into the interference traffic queue at a rate of 200 Kbits/sec. Thus, one in every five bytes of data would include interference data. The traffic rate scheduler 50 delivers the interference data along with the real data at the rate of 1 Mbit/sec. However, the interference discard circuit 54 drops 1 in every 5 bytes (i.e. one byte of interference traffic is dropped for every 4 bytes of real data transmitted) to compensate for the rate difference between the two queues. Thus, the effective delivery rate to the destination queue 60 is 800 Kbits/sec.
Referring to
If process 100 determines the rate is too high, the data output rate from the traffic scheduler 50 to the downstream queue 60 should be decreased. To decrease the data output rate, process 100 increases 112 the rate for sending interference traffic to the interference traffic queue 36. Thus, since more interference data is included in the rate shaped channel 48 and the interference discard circuit 54 discards more data, and the effective data rate to the downstream queue 60 decreases. Subsequent to increasing 110 or decreasing 112 the rate of sending interference traffic to the interference traffic queue 36, process 100 returns to the initial state of monitoring 102.
In the example above, system 61 accommodates a transmission rate of 800 Kbits/second. However, this rate can vary over time. For example, the rate can increase to 900 Kbits/second. In this case, the queue would empty (e.g., the rate is too low) and the shaper modification circuit is alerted of the state of the queue. Based on the queue level being too low, the shaper modification circuit decreases the amount and rate of data sent to the interference traffic queue 36. For example, the rate could be decreased to 100 Kbits/sec resulting in an effective transmission rate to queue 60 of 900 Kbits/sec. Based on the state of the queue 60 using this transmission rate, the interference traffic rate could be further adjusted or kept at the 900 Kbits/sec.
While in the examples above the shaper modification circuit receives information about the state of a downstream system 61, the shaper modification circuit can receive other information. The shaper modification circuit can receive information from a variety of monitoring systems, for example, the monitoring can include queue state monitoring, output rate monitoring, or monitoring input data characteristics. Alternately, the shaper modification circuit includes a steady state algorithmic modification to the behavior of the traffic rate scheduler.
Referring to
Referring to
In another example, the downstream system receives data from multiple sources. In this example, the stream of data entering the downstream system or the system itself is monitored. Based on the monitored characteristics, the shaper modification circuit 56 inserts an appropriate amount of interference traffic in the traffic rate scheduler 50 to adjust the output rate from the traffic rate scheduler 50.
In several of these examples, the shaper modification circuit 50 controls the shaped flow when the downstream system is not capable of receiving data at the current shaped rate. Although physical flow control capabilities are usually provided in traffic rate schedulers for a small number of channels, the interference traffic technique adds scalability in terms of number of flow controllable channels, and moves the flow control to a different level of the scheduling hierarchy from the channel scheduler to the rate shaper circuit.
The devices described herein can be implemented in digital electronic circuitry, in computer hardware, firmware, software, or in combinations of them. The devices described herein can be implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable storage device or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a processing device, a computer, or multiple computers. A computer program can be written in any form of programming language, including compiled, assembled, or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
Particular embodiments have been described, however other embodiments are within the scope of the following claims.