Data centers provide a centralized location where a distributed network of servers shares certain resources, such as compute, memory, and network resources. The sharing of such resources in data centers typically reduces wasteful and duplicative resource requirements and thus, data centers provide benefits over individual server operations. This has led to an explosive growth in the number of data centers as well as the complexity and density of the data centers. One result of this growth is that management of complex data centers has also become increasingly more difficult and expensive.
For instance, managing both the infrastructure and the applications in a large and complicated centralized networked resource environment, such as modern data centers, raises many challenging operational scalability issues. By way of example, it is desirable to share computing and memory resources among different customers and applications to reduce operating costs. However, customers typically prefer dedicated resources that offer isolation and security for their applications as well as flexibility to host different types of applications. Attempting to assign or allocate resources in a data center in an efficient manner which adequately addresses issues that are impacted by the assignment has thus proven to be very difficult and time consuming.
Typically, the resources are assigned or allocated manually by a data center operator, oftentimes in a random or a first-come-first-served manner. In addition, manual assignment of the resources often fails to address energy efficiency concerns as well as other customer service level objectives (SLOs). Moreover, the dynamic nature and high variability of the workloads in many applications, especially electronic business (e-business) applications, typically requires that the resources allocated to an application be easily adjustable to maintain the SLOs.
Although virtualization of resource allocation provides benefits by driving higher levels of resource utilization, it also contributes to the growth in complexity in managing the data centers. Thus, it would be beneficial to be able to substantially reduce the amount of time and labor required of data center operators in managing the growingly complex data centers, while more fully realizing the benefits of virtualization.
The embodiments of the invention will be described in detail in the following description with reference to the following figures.
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.
Disclosed herein is a resource management system and a method for managing resources automatically among a plurality of nodes. The resource management system includes multiple levels of controllers that operate at different scopes and time scales. The multiple levels of controllers may generally be considered as leveraging resource knobs that range from short-term allocation of system-level resources among individual workloads on a shared server, to live migration of virtual machines between different servers, and to the organization of server clusters with groups of workloads configured to maximize efficiencies in combining long-term demand patterns.
In addition, the controllers at the multiple levels are integrated with each other to facilitate automated capacity and workload management in allocating the resources. Specific interfaces are also defined between the individual controllers such that the controllers are coordinated with each other at runtime. The controllers may thus run simultaneously while potential conflicts between them are substantially eliminated. By way of example, the interfaces include the sharing of policy information, such that policies do not have to be duplicated among the controllers, as well as coordination among the multiple controllers.
Through implementation of the resource management system and method disclosed herein, the mapping of physical resources to virtual resources may be automated to substantially minimize the hardware and energy costs associated with performing applications, which meet one or more service level objectives (SLOs). In addition, by adjusting the resource knobs in a substantially continuous manner as conditions change in the data center, hardware and energy costs may substantially be minimized while meeting the SLOs. As such, the resource management system and method disclosed herein generally afford data center operators with the ability to focus on service policy settings, such as, response time and throughput targets, or the priority levels of individual applications, without having to worry about the details of where an application is hosted or how the application shares resources with other applications.
With reference first to
The resource management system 100 is depicted in multiple levels. A first level includes a common user interface 102. A second level includes controllers 110. A third level includes sensors and actuators 120. And a fourth level includes managed resources 130.
The controllers level 110 is depicted as including a node controller 112, a pod controller 114, and a pod set controller 116. The sensors and actuators level 120 is depicted as including resource allocation actuators 122, application performance sensors 124, resource consumption and capacity sensors 126, and workload (WL) migration actuators 128. The managed resources level 130 is depicted as including a plurality of nodes 132a-132n arranged in a plurality of pods 140a-140n, which form a pod set 150.
Each of the nodes 132a-132n is depicted as including workloads (WL), which comprise abstractions that encapsulate a set of work to be done, such as virtual machines, process groups, etc. Generally speaking, the nodes 132a-132n, which comprise servers, are configured as virtual machines to implement or execute an application, which may be composed of multiple workloads (WL). As such, multiple virtual machines on nodes 132a-132n may be assigned to perform the WLs of a single application. The multiple virtual machines that compose a single application may be hosted on a single node or on multiple nodes 132a-132n.
The nodes 132a-132n are depicted as being grouped into pods 140a-140n. The pods 140a-140n may be defined based upon the virtual machine live migration as a set of nodes 132a-132n, such that a virtual machine is able to live migrate between any two nodes in the set. As such, for the nodes 132a-132n to be included in a particular pod 140a, the nodes 132a-132n require compatible configurations for the live migration, such as similar CPU types, mutual access to the same shared storage device, etc. In addition, the requirements for determining which pod 140a-140n that a particular node 132a belongs may be technology dependent on the particular type of live migration used among the nodes 132a-132n. In addition, or alternatively, the nodes 132a-132n may be assigned to the particular pods 140a-140n based upon other attributes of the nodes 132a-132n, such as, the physical or virtual locations of the nodes 132a-132n, the network switches to which the nodes 132a-132n are connected, etc.
The pod set 150 may be defined as including a plurality of non-overlapping pods 140a-140n. The pods 140a-140n are considered to be non-overlapping because each of the nodes 132a-132n is assigned to only one of the pods 140a-140n. The pods 140a-140n forming or contained in a pod set 150 may comprise all of the pods 140a-140n or a subset of all of the pods 140a-140n contained in one or more data centers. The assignment of the pods 140a-140n to one or more pod sets 150 may be based upon various factors, such as, physical configurations of the nodes 132a-132n contained in the pods 140a-140n, workload types assigned to the nodes 132a-132n contained in the pods 140a-140n, etc. By way of example, the pods 140a-140n of a particular pod set 150 may each include nodes 132a-132n in which workloads are able to be non-live migrated between the nodes 132a-132n contained in different pods 140a-140n. Again, the pods 140a-140n of a pod set 150 need not be located in the same data center, but may be located in multiple data centers, so long as the conditions described above are met.
Also shown in
The application performance sensors 124 are configured to measure application level performance metrics, such as response time, throughput for the workloads of an application, etc. The resource consumption and capacity sensors 126 are configured to measure, for instance, how much CPU and memory each virtual machine is using on average for a given period of time, as well as the CPU capacity and memory capacity that a given node 132a-132n has. In other words, the resource consumption and capacity sensors 126 are configured to determine the real resource allocations on the nodes 132a-132n for a given workload. As shown, the application performance sensors 124 communicate the measured application level performance metrics to the node controller 112. In addition, the resource consumption and capacity sensors 126 communicate the sensed data to all three of the controllers 112-116.
Although a single node controller 112, a single pod controller 114, and a single pod set controller 116 have been depicted in
The node controller 112, the pod controller 114 and the pod set controller 116 also receive service policy information from the common user interface 102, which may be entered into the resource management system 100 by a user 160 through the common user interface 102, as indicated by the arrow 161. As shown, the service policy information may be entered once through the common user interface 102, which may comprise a graphical user interface which may be presented to the user 160 via a suitable display device, and communicated to each of the node controller 112, pod controller 114, and pod set controller 116, as indicated by the solid arrows 103-107. As such, a user 160 is not required to separately enter and communicate the service policy information to each of the node controller 112, pod controller 114, and pod set controller 116. In addition, the service policy information may be communicated to each of the node controller 112, the pod controller 114, and the pod set controller 116 in a synchronized manner. One result of this synchronized policy distribution is that the policies may automatically be unfolded onto the controllers 112, 114, 116 such that they are operated in a synergistic manner.
The service policy information may be broken up into different types of information, which are communicated to the node controller 112, the pod controller 114, and the pod set controller 116. For instance, the service policy information communicated to the node controller 112, referenced by the arrow 103, may comprise SLOs and workload priority information. As another example, the service policy information communicated to the pod controller 114, referenced by the arrow 105, may comprise workload placement policies as well as workload priority information. Moreover, the service information communicated to the pod set controller 116, referenced by the arrow 107, may comprise policies for the node controller 112, the pod controller 114, and the pod set controller 116.
By way of example with respect to the pod set controller 116, the service policy information may include an instruction indicating that a particular workload is to receive a certain quality of service (QoS) level. In this example, the pod set controller 116 may take the QoS level instruction into account when deciding how to globally optimize a pod 140a-140n. For instance, the pod set controller 116 may allow a workload to have a lower QoS (for example, where the workload does not receive all of the requested resources) and the pod set controller 116 may take that into account when making packing decisions about which workloads should go into each pod 140a-140n and onto which node 132a-132n.
Similarly, the node controller 112, equipped with the same instruction, may enable the node controller 112 to take a workload and divide the demands of the workload across two classes of service, for instance, an “own” class, which is a very high priority class of service and a “borrow” class, which is a lower priority class of service. In this example, a certain portion of the demand up to some limit would be owned and the rest will be borrowed and they may be satisfied if resources are available. In addition, the pod set controller 116 may determine the portion of the demand that must be owned and how much of the demand must be borrowed based upon historical data. An example of the use of different classes of service is described in greater detail in copending and commonly assigned U.S. patent application Ser. No. 11/492,376 (Attorney Docket No. 200601298-1), the disclosure of which is hereby incorporated by reference in its entirety.
As another example, the priority levels of different workloads may be used to guide resource allocation in both the node controller 112 and the pod controller 114 when there are resource constraint situations. In this example, the service policy information pertaining to the different priority levels may originate from the same user instructions and may be communicated to both the node controller 112 and the pod controller 114. As such, the service policy information need not be entered into the node controller 112 and the pod controller 114 individually.
As a further example, there may arise situations where multiple customers are serviced in a cloud computing data center, where the multiple customers may have policies where one of the customers requires that their virtual machines are not on the same node as another customer's virtual machines. In these situations, a single service policy instruction pertaining to this constraint may be entered through the common user interface 102 and communicated to both the pod set controller 116 and the pod controller 114 to prevent such allocation of workloads.
A node controller 112 may be associated with each node 132a-132n in a pod 140a-140n and manages the dynamic allocation of the node's resources to each individual workload running in a virtual machine. Each of the node controllers 112 is configured to translate the service policy information for a given application along with the values from the feedback information received from the application performance sensors 124 into an allocation that is required for each workload of the application, such that the requirements in the service policy may be met. In other words, for instance, each of the node controllers 112 operates to dynamically adjust each workload's resource allocations to satisfy SLOs for the applications. In addition, the node controllers 112 may operate under a relatively short time scale, for instance, over periods of seconds, to continuously adjust the resource allocations of the workloads to satisfy the SLOs for the applications. Various manners in which the node controllers 112 may operate are described in greater detail in U.S. patent application Ser. No. 11/492,353 (Attorney Docket No. 200506591-1), and in U.S. patent application Ser. No. 11/492,307 (Attorney Docket No. 200507437-1), the disclosures of which are hereby incorporated by reference in their entireties.
In addition, each of the node controllers 112 tunes the resource allocation actuators 122 to effectuate allocation of the node resources based upon the determined allocations. More particularly, the resource allocation actuators 122 control how much resources, such as CPU, memory, disk I/O, network bandwidth, etc., each workload gets on whichever node the workload happens to be on at a given time.
Each of the node controllers 112 is also configured to pass the information pertaining to resource demands of the workloads to the pod controller 114 as indicated by the solid arrow 113, to facilitate integration between the node controllers 112 and the pod controller 114. In various instances, the node controllers 112 may communicate different information to the pod controller 114 than the information communicated to the resource allocation actuators 122. For instance, the node controllers 112 may inform the pod controller 114 of the resources that the workloads really should have in order to meet the application's performance requirements. However, there may be constraints on a particular node 132a-132n that the node controller 112 is managing, where the node controller 112 is unable to allocate all of those resource requirements. In these instances, the node controller 112 arbitrates between the workloads, for example, using priorities, various mechanisms, such as, various policies, to give the workloads less resources than what they really should be allocated to meet the performance requirements. In addition, the node controller 112 informs the pod controller 114 of the resources that the workloads really require so that the pod controller 114 may attempt to move workloads among nodes 132a-132n in a particular pod 140a to substantially ensure that the workloads will have their requisite resource allocations to meet the SLOs, for instance, in a period of a few minutes.
By way of example, a node controller 112 informs the pod controller 114 of the CPU requirements of various virtual machines and may also provide information pertaining to the available node capacity. In addition, the pod controller 114 receives resource consumption and capacity information of the nodes 132a-132n from the resource consumption and capacity sensors 126. If the pod controller 114 detects that the sum of the required allocations for all the VMs on a node add up to more than the node capacity, then the pod controller 114 determines that the workload (WL) migration actuators 128 need to be called upon to actuate migration of one or more of the workloads among one or more nodes 132a-132n in a pod 140a-140n.
According to another example, the pod controller 114 may tune the workload migration actuators 128 to migrate the workloads among the nodes 132a-132n to increase efficiency of the resource utilization in the nodes 132a-132n. For instance, the pod controller 114 may determine that placing workloads in one node 132a and setting another node 132b into an idle state may yield a more efficient use of the resources in the node 132a and may thus instruct the workload migration actuators 128 to place the workloads in the determined manner. According to an example, the idle node 132b can then be turned off to save energy.
The pod controller 114 is configured to perform intrapod migration among the nodes 132a-132n in a particular pod 140a and is configured to operate on a longer time scale as compared with the node controller 112, for instance, over periods of minutes. In addition, the pod controller 114 makes use of live migration, so that a user experiences very little, typically less than a second, of downtime during the migration process from one node to another. The actual migration, however, may take a relatively longer period of time, such as a few minutes. An example of a manner in which the pod controller 114 may operate is described in greater detail in copending and commonly assigned U.S. patent application Ser. No. 11/588,691 (Attorney Docket No. 200504718-1), the disclosure of which is hereby incorporated by reference in its entirety.
Additional types of suitable pod controllers 114 are described in C. Hyser, B. Mckee, R. Gardner, and B. J. Watson, “Autonomic virtual machine placement in the data center.” HP Labs Technical Report HPL-2007-189, February 2007 and S. Seltzsam, D. Gmach, S. Krompass and A. Kemper, “AutoGlobe: An automatic administration concept for service-oriented database applications.” Proc. Of the 22nd Intl. Conf. on Data Engineering (ICDE '06), Industrial Track, 2006. The disclosures of those articles are hereby incorporated by reference in their entireties.
According to an example, the pod controller 114 is configured to pass pod performance data to the pod set controller 116 as indicated by the solid arrow 115, to facilitate integration between the node controllers 112, the pod controller 114 and the pod set controller 116. The pod performance data may include information pertaining to the arrangement of the workloads among the nodes 132a-132n. For instance, the pod performance data may include information pertaining to whether the resource requirements of the workloads as set forth in an SLO, for instance, have or have not been met. If the resource requirements have not been met, the pod controller 114 informs the pod set controller 116 that the resource requirements of the workloads have not been satisfied.
Generally speaking, the pod set controller 116 is configured to perform capacity planning for all of the pods 140a-140n contained in the pod set 150 and may be configured to run every few hours or more. The pod set controller 116 is thus aware of new workloads entering into the resource management system 100, old workloads that have been completed, historical data pertaining to how workloads have changed over time, etc. The pod set controller 116 may, for example, use the historical data to predict how workloads will change on certain days or certain hours. For instance, the pod set controller 116 is configured to determine whether a pod 140a-140n has become too overloaded and whether workloads should be redistributed between pods 140a-140n. Examples of manners in which the pod set controller 116 may operate are described in greater detail in copending and commonly assigned U.S. patent application Ser. No. 11/742,530 (Attorney Docket No. 200700357-1), U.S. patent application Ser. No. 11/492,376 (Attorney Docket No. 200601298-1), U.S. patent application Ser. No. 11/489,967 (Attorney Docket No. 200506225-1), filed on Jul. 20, 2006; U.S. patent application Ser. No. 11/492,347 (Attorney Docket No. 200504358-1), filed on Apr. 27, 2006; and U.S. patent application Ser. No. 11/493,349 (Attorney Docket No. 200504202-1), the disclosures of which are hereby incorporated by reference in their entireties.
The pod set controller 116 may communicate information pertaining to the predicted workloads back to the pod controller 114, as indicated by the solid arrow 115. The pod controller 114 may employ the information received from the pod set controller 116 and the service policy information when making workload migration determinations. As such, the pod controller 114 may make workload migration determinations among the nodes 132a-132n in a particular pod 140a using information that would have otherwise been unavailable to the pod controller 114.
By way of particular example, the pod set controller 116 may anticipate that some workloads are going to ramp up their resource demands at a certain time (for instance, an end-of-month report generation application) using historical analysis of the workloads as a predictor of the workload demands. In this example, the pod set controller 116 may inform the pod controller 114 of the impending increase in resource demand. In response, the pod controller 114 may place some of the current workload on its own machine, for instance, so that the pod controller 114 is better able to allocate the new workloads while substantially meeting the SLOs of the new workloads.
The pod set controller 116 may initiate a more global reorganization of the workloads than the pod controller 114 by moving one or more of the workloads between pods 140a-140n within a pod set 150 to better satisfy the resource requirements of the workloads, as indicated by the arrow 117. The pod set controller 116 may instruct a user 160 or a robotic device to physically rearrange the connections of a node 132a to form part of another pod 140b, to add a new node 132n to one of the pods 140a or to remove an existing node 132n from one of the pods 140a. In addition, or alternatively, the pod set controller 116 may instruct a node movement actuator (not shown) to change the association of the node 132a from one pod 140a to another pod 140b.
The pod controller 114 is distinguished from the pod set controller 116 because the pod set controller 116 is more focused on planning and also has a historical perspective of resource utilization for various workloads. In addition, although both the pod controller 114 and the pod set controller 116 have consolidation functions, they perform those functions in different degrees. For instance, the pod controller 114 performs these functions within a certain pod 140a, whereas the pod set controller 116 performs these functions among a plurality of pods 140a-140n. As a further distinction, because the pod controller 114 runs more often than the pod set controller 116, the pod controller 114 attempts to find the most efficient path, for instance, the solution that requires the smallest number of migrations, and thus the pod controller 114 attempts to minimize the overhead of migrating the virtual machines around. On the other hand, because the pod set controller 116 runs less often, for instance, every few hours or even less often, the pod set controller 116 attempts to perform more global optimizations and is less concerned with the cost of migration overhead.
The components of the resource management system 100 comprise software, firmware, hardware, or a combination thereof. Thus, for instance, one or more of the controllers 112, 114, 116 may comprise software modules stored on one or more computer readable media. Alternatively, one or more of the controllers 112, 114, 116 may comprise hardware modules, such as circuits, or other devices configured to perform the functions of the controllers 112, 114, 116 as described above. Likewise, the resource allocation actuators 122, the workload migration actuators 128, the application performance sensors 124, and the resource consumption and capacity sensors 126 may also comprise software or hardware modules.
The relationships between the nodes 132a-132n, the pods 140a-140n, and the pod set 150 may be stored as data, for instance, in a computer readable storage media. As such, the relationships may be stored as virtual relationships along with virtual representations of the nodes 132a-132n.
An example of a method of managing resources automatically among a plurality of nodes 132a-132n will now be described with respect to the following flow diagram of the method 200 depicted in
The descriptions of the methods 200 and 300 are made with reference to the resource management system 100 illustrated in
The method 300 is similar to the method 200, but provides steps in addition to the steps contained in the method 200.
Turning first to
With reference now to
At step 302, the node controller 112, the pod controller 114, and the pod set controller 116 receive common service policies. As discussed above, each of the controllers 112, 114, 116 may receive a common set of service policies through the common user interface 102. In other words, service policy information that is inputted through the common user interface 102 may be communicated to each of the controllers 112, 114, 116. As such, the service policy information need not be inputted individually into each of the controllers 112-116 by a user.
At step 304, the controllers 112, 114, 116 receive resource consumptions and capacities of the nodes 132a-132n detected by the resource consumption and capacity sensors 126.
At step 306, the node controller 112 receives application performance metric data of the nodes 132a-132n from the application performance sensors 124. In addition, at step 308, the node controller 112 determines an allocation of node resources, for instance, for a particular workload, based upon the application performance metric data and service policy information from the common service policies received through the common user interface 102.
At step 310, the node controller 112 communicates instructions related to the allocation of the node resources determined at step 308 to the resource allocation actuators 122, which are configured to effectuate the allocation of the node resources in each of the nodes 132a-132n as determined by the node controller 112. In addition, at step 312, the node controller 112 communicates resource demands of the workloads to the pod controller 114, which, as described above, may differ from the actual resources allocated to the workloads.
Continuing on to
At step 316, the pod controller 114 communicates instructions related to the assignment of the workloads among the nodes 132a-132n contained in a pod 140a to the workload migration actuators 128, which are configured to effectuate the determined allocation of the workloads among the nodes 132a-132n. At step 318, the pod controller 114 communicates pod performance data pertaining to the assignment of the workloads to the pod set controller 116.
At step 320, the pod set controller 116 performs capacity planning for the pods 140a-140n contained in the pod set 150 based upon the pod performance data received from the pod controller 114, the common service policies received at step 302, and the detected resource allocations and capacities of the nodes received at step 304. At step 322, the pod set controller 116 manages movement of nodes 132a-132n, which may include initiation of the removal of one or more of the nodes 132a-132n, among or from the pods 140a-140n contained in the pod set 150. In addition or alternatively, at step 322, the pod set controller 116 manages the addition of one or more nodes 132a-132n into one or more of the pods 140a-140n based upon the capacity planning performed at step 320.
At step 324, the pod set controller 116 communicates information pertaining to the capacity planning of the nodes to the pod controller 114. In addition, at step 314, in determining the assignment of the workloads among the nodes in a pod 140a, the pod controller 114 is further configured to base the determination of the workload assignment upon the capacity planning information received from the pod set controller 116
As may be seen from the methods 200 and 300, the node controller 112, the pod controller 114 and the pod set controller 116 are operated in an integrated manner to enable the controllers 112, 114, 116 to allocate resources and migrate workloads, such that the workloads may be completed while meeting service policies in an automated manner. The integration of the controllers 112, 114, 116 is enabled, for instance, through interfaces and communication of information across the interfaces between the controllers 112, 114, 116.
The operations set forth in the methods 200 and 300 may be contained as utilities, programs, or subprograms, in any desired computer accessible medium. In addition, the methods 200 and 300 may be embodied by computer programs, which may exist in a variety of forms both active and inactive. For example, they may exist as software program(s) comprised of program instructions in source code, object code, executable code or other formats. Any of the above may be embodied on a computer readable medium.
Exemplary computer readable storage devices include conventional computer system RAM, ROM, EPROM, EEPROM, and magnetic or optical disks or tapes. Concrete examples of the foregoing include distribution of the programs on a CD ROM or via Internet download. It is therefore to be understood that any electronic device capable of executing the above-described functions may perform those functions enumerated above.
The computing apparatus 400 includes a processor 402 that may implement or execute some or all of the steps described in the methods 200 and 300. Commands and data from the processor 402 are communicated over a communication bus 404. The computing apparatus 400 also includes a main memory 406, such as a random access memory (RAM), where the program code for the processor 402, may be executed during runtime, and a secondary memory 408. The secondary memory 408 includes, for example, one or more hard disk drives 410 and/or a removable storage drive 412, representing a floppy diskette drive, a magnetic tape drive, a compact disk drive, etc., where a copy of the program code for the methods 200 and 300 may be stored.
The removable storage drive 412 reads from and/or writes to a removable storage unit 414 in a well-known manner. User input and output devices may include a keyboard 416, a mouse 418, and a display 420. A display adaptor 422 may interface with the communication bus 404 and the display 420 and may receive display data from the processor 402 and convert the display data into display commands for the display 420. In addition, the processor(s) 402 may communicate over a network, for instance, the Internet, LAN, etc., through a network adaptor 424.
It will be apparent to one of ordinary skill in the art that other known electronic components may be added or substituted in the computing apparatus 400. It should also be apparent that one or more of the components depicted in
What has been described and illustrated herein is a preferred embodiment of the invention along with some of its variations. The terms, descriptions and figures used herein are set forth by way of illustration only and are not meant as limitations. Those skilled in the art will recognize that many variations are possible within the scope of the invention, which is intended to be defined by the following claims—and their equivalents—in which all terms are meant in their broadest reasonable sense unless otherwise indicated.
The present application has the same Assignee and shares some common subject matter with U.S. patent application Ser. No. 11/492,353 (Attorney Docket No. 200506591-1), filed on Jul. 25, 2006, now abandoned; U.S. patent application Ser. No. 11/492,307 (Attorney Docket No. 200507437-1), filed on Jul. 25, 2006; U.S. patent application Ser. No. 11/742,530 (Attorney Docket No. 200700357-1), filed on Apr. 30, 2007; U.S. patent application Ser. No. 11/492,376 (Attorney Docket No. 200601298-1), filed on Jul. 25, 2006; U.S. patent application Ser. No. 11/413,349 (Attorney Docket No. 200504202-1), filed on Apr. 28, 2006; U.S. patent application Ser. No. 11/588,691 (Attorney Docket No. 200504718-1), filed on Oct. 27, 2006; U.S. patent application Ser. No. 11/489,967 (Attorney Docket No. 200506225-1), filed on Jul. 20, 2006; U.S. patent application Ser. No. 11/492,347 (Attorney Docket No. 200504358-1), filed on Apr. 27, 2006; and U.S. patent application Ser. No. 11/493,349 (Attorney Docket No. 200504202-1), filed on Apr. 28, 2006. The disclosures of the above-identified U.S. Patent Applications are hereby incorporated by reference in their entireties.