Overview of the Scheduler
When a process is created, the system assigns a lightweight process (LWP) to the process. If the process is multithreaded, more LWPs might be assigned to the process. An LWP is the object that is scheduled by the UNIX system scheduler, which determines when a process can run. The scheduler maintains process priorities that are based on configuration parameters, process behavior, and user requests. The scheduler uses these priorities to determine which process runs next. The six priority classes are real-time, system, interactive (IA), fixed-priority (FX), fair-share (FSS), and time-sharing (TS).
The default scheduling is a time-sharing policy. This policy dynamically adjusts process priorities to balance the response time of an interactive process. The policy also dynamically adjusts priorities to balance the throughput of a process that uses a lot of CPU time. The time-sharing class has the lowest priority.
The Oracle Solaris operating system (OS) scheduler also provides a real-time scheduling policy. Real-time scheduling enables users to assign fixed priorities to specific processes. The highest-priority real-time user process always gets the CPU as soon as the process is runnable.
The Oracle Solaris OS scheduler also provides a policy for fixed-priority scheduling. Fixed-priority scheduling enables users to assign fixed priorities to specific processes. Fixed-priority scheduling uses the same priority range as the time-sharing scheduling class by default.
A program can be written so that its real-time processes have a guaranteed response time from the system. For more information, see Real-time Programming and Administration.
The control of process scheduling provided by real-time scheduling is rarely needed. However, when the requirements for a program include strict timing constraints, real-time processes might be the only way to satisfy those constraints.
Caution:
Careless use of real-time processes can have a dramatic negative effect on the performance of time-sharing processes.Because changes in scheduler administration can affect scheduler behavior, programmers might also need to know something about scheduler administration. The following interfaces affect scheduler administration:
- 
                     
                     dispadmin– Displays or changes scheduler configuration in a running system. For more information, see thedispadmin(8) man page.
- 
                     
                     ts_dptblandrt_dptbl– Tables that contain the time-sharing and real-time parameters that are used to configure the scheduler. For more information, see thets_dptbl(5) andrt_dptbl(5) man pages.
A process inherits its scheduling parameters, including scheduling class and priority within that class, when the process is created. A process changes class only by a user request. The system adjusts the priority of a process based on user requests and the policy associated with the scheduler class of the process.
In a default configuration, the initialization process belongs to the time-sharing class. Therefore, all user login shells begin as time-sharing processes.
The scheduler converts class-specific priorities into global priorities. The global priority of a process determines when can a process run. The scheduler always runs the runnable process with the highest global priority. A process assigned to the CPU runs until the process sleeps, uses its time slice, or is preempted by a higher-priority process. Processes with the same priority run in sequence, around a circle.
All real-time processes have higher priorities than any kernel process, and all kernel processes have higher priorities than any time-sharing process.
Note:
In a single processor system, no kernel process and no time-sharing process runs while a runnable real-time process exists.Administrators specify default time slices in the configuration tables. Users can assign per-process time slices to real-time processes.
You can display the global priority of a process with -cl options of the
ps command. You can display configuration information about class-specific
   priorities by using the priocntl command and the dispadmin
   command. For more information, see 
                     ps(1), 
                     priocntl(1), and 
                     dispadmin(8) man pages.
               
The following sections describe the scheduling policies of the six scheduling classes.