Sun Microsystems, Inc.
spacerspacer
spacer www.sun.com docs.sun.com |
spacer
black dot
 
 
  Previous   Contents   Next 
   
 
Chapter 5

Introduction to Solaris 9 Resource Manager

Resource management functionality enables you to control how applications use available system resources. You can do the following:

  • Allocate computing resources, such as processor time

  • Monitor how these allocations are being used and adjust them as necessary

  • Generate extended accounting information for analysis, billing, and capacity planning

Overview

Modern computing environments have to provide a flexible response to the varying workloads that are generated by different applications on a system. If resource management features are not used, the Solaris operating environment responds to workload demands by adapting to new application requests dynamically. This default response generally means that all activity on the system is given equal access to resources. Solaris resource management features enable you to treat workloads individually. You can do the following:

  • Restrict access to a specific resource

  • Offer resources to workloads on a preferential basis

  • Isolate workloads from one another

The ability to minimize cross-workload performance compromises, combined with the facilities that monitor resource usage and utilization, are collectively referred to as resource management. Resource management is implemented through a collection of algorithms that handle the series of capability requests that an application presents in the course of its execution.

Resource management facilities permit you to modify the default behavior of the operating system as it applies to different workloads. Behavior primarily refers to the set of decisions that are made by operating system algorithms when the system is presented with one or more resource requests by an application. You can use resource management facilities to do the following:

  • Deny resources or prefer one application over another for a larger set of allocations than otherwise permitted

  • Treat certain allocations collectively instead of through isolated mechanisms

The implementation of a system configuration that uses the resource management facilities can serve several purposes. You can do the following:

  • Prevent an application from consuming resources indiscriminately

  • Change an application's priority based on external events

  • Balance resource guarantees to a set of applications against the goal of maximizing system utilization

When planning a resource-managed configuration, key requirements include the following:

  • Identifying the competing workloads on the system

  • Distinguishing those workloads that are not in conflict from those with performance requirements that compromise the primary workloads

After cooperating and conflicting workloads have been identified, you can create a resource configuration that presents the least compromise to the service goals of the business, within the limitations of the system's capabilities.

Effective resource management is enabled in the Solaris environment by offering control mechanisms, notification mechanisms, and monitoring mechanisms. Control mechanisms are described subsequently. Notification mechanisms and monitoring mechanisms are described in Chapter 8, Resource Controls. Many of these capabilities are provided through enhancements to existing mechanisms such as the proc(4) file system, processor sets, and scheduling classes. Other capabilities are specific to resource management. These capabilities are described in subsequent chapters.

Resource Classifications

A resource is any aspect of the computing system that can be manipulated with the intent to change application behavior. Thus, a resource is a capability that an application implicitly or explicitly requests which, if denied or constrained, causes the execution of a robustly written application to proceed more slowly.

Classification of resources (as opposed to identification of resources) can be made along a number of axes. The axes could be implicitly requested versus explicitly requested, time-based (such as CPU time) versus time-independent (such as CPU shares assigned), and so forth.

Generally, scheduler-based resource management is applied to resources that the application can implicitly request. For example, to continue execution, an application implicitly requests additional CPU time, while to write data to a network socket, an application implicitly requests bandwidth. Constraints can be placed on the aggregate total use of an implicitly requested resource.

Additional interfaces can be presented so that bandwidth or CPU service levels can be explicitly negotiated. Resources that are explicitly requested, such as a request for an additional thread, can be managed by constraint.

Resource Management Control Mechanisms

The three types of control mechanisms available in the Solaris operating environment are constraints, scheduling, and partitioning.

Constraints

Constraints allow the administrator or application developer to ensure that known bounds are set on the consumption of specific resources for a workload. With known bounds, modeling resource consumption scenarios becomes a simpler process. Bounds can also be used to control ill-behaved applications that would otherwise compromise system performance or availability through unregulated resource requests.

Constraints do present complications for the application. The relationship between the application and the system can be modified to the point that the application is no longer able to function. One approach that can mitigate this risk is to gradually narrow the constraints on applications with unknown resource behavior. The resource controls feature that is discussed in Chapter 8, Resource Controls provides a constraint mechanism. Newer applications can be written to be aware of their resource constraints, but application writers might not choose to add this awareness.

Scheduling

Scheduling refers to making a sequence of allocation decisions at specific intervals. The decision that is made is based on a predictable algorithm. An application that does not need its current allocation leaves the resource available for another application's use. Scheduling-based resource management enables full utilization of an undercommitted configuration, while providing controlled allocations in a critically committed or overcommitted scenario. The underlying algorithm defines how the term "controlled" is interpreted. In some situations, the scheduling algorithm might guarantee that all applications have some access to the resource. The fair share scheduler (FSS) that is described in Chapter 9, Fair Share Scheduler manages application access to CPU resources in a controlled way.

Partitioning

Partitioning is used to bind a workload to a subset of the system's available resources. This binding guarantees that a known amount of resources are always available to the workload. The resource pools functionality that is described in Chapter 10, Resource Pools enables you to limit workloads to specific subsets of the machine. Configurations that use partitioning can avoid system-wide overcommitment. However, in avoiding this overcommitment, the possibility for achieving high utilizations are less likely because a reserved group of resources (such as processors) is not available for use by another workload when the workload bound to them is idle.

Resource Management Configuration

Portions of the resource management configuration can be placed in a network name service. This feature allows the administrator to apply resource management constraints across a collection of machines, rather than on an exclusively per-machine basis. Related work can share a common identifier, and the aggregate usage of that work can be tabulated from accounting data.

Resource management configuration and workload-oriented identifiers are described more fully in Chapter 6, Projects and Tasks. The extended accounting facility that links these identifiers with application resource usage is described in Chapter 7, Extended Accounting.

When to Use Resource Management

Use resource management to ensure that your applications obtain the response times they require.

Resource management can also increase resource utilization. By categorizing and prioritizing usage, you can effectively use reserve capacity during off-peak periods, often eliminating the need for additional processing power. You can also ensure that resources are not wasted because of load variability.

Server Consolidation

Resource management is ideal for environments that consolidate a number of applications on a single server.

The cost and complexity of managing numerous machines encourages the consolidation of several applications on larger, more scalable servers. Instead of running each workload on a separate system, with full access to that system's resources, you can use resource management software to segregate workloads within the system. Resource management enables you to lower overall total cost of ownership by running and controlling several dissimilar applications on a single Solaris system.

If you are providing Internet and application services, you can use resource management to do the following:

  • Host multiple web servers on a single machine. You can control the resource consumption that is associated with each web site. Also, you can protect each site from the potential excesses of other sites.

  • Prevent a faulty common gateway interface (CGI) script from exhausting CPU resources.

  • Stop an incorrectly behaving application from leaking all available virtual memory.

  • Ensure that one customer's applications are not affected by another customer's applications that run at the same site.

  • Provide differentiated levels or classes of service on the same machine.

  • Obtain accounting information for billing purposes.

 
 
 
  Previous   Contents   Next