Index Index for
Section 8
Index Alphabetical
listing for C
Bottom of page Bottom of
page

class_admin(8)

NAME

class_admin - Administer daemons and databases for class scheduling.

SYNOPSIS

/usr/sbin/class_admin [subcommand[, subcommand]...]

DESCRIPTION

Class scheduling allows you to organize users and groups into classes and specify the maximum percentage of CPU usage permitted each class. The class_admin utility is used to set up and maintain class databases and to start and stop the class scheduler. These operations are performed through utility subcommands, which are listed and described in the "Subcommands" section. Read the information in class_scheduling(4) if you are unfamiliar with class scheduling. That reference page includes conceptual information, guidelines, and restrictions that are not repeated here and apply to both the class_admin utility and the class scheduling APIs. All class_admin subcommands execute in the context of a soft partition (processor set). The class_admin utility maintains different class scheduling databases for different partitions, and you must enable class scheduling on each partition for which you maintain a class scheduling database. If user-defined partitions do not exist, the default partition is the only partition on the system and contains all system CPUs. This partition exists even after user-defined partitions have been created; in which case, it contains all CPUs that have not been allocated to a user- defined partition. When you enter the class_admin command without a setp pset_num subcommand, the default partition is your context. You can enter a setp subcommand at the utility prompt to change partition context. The class_admin command can be run interactively or non-interactively. Non-interactive mode allows class_admin to be run from within a script, which makes it easy to enable class scheduling at system startup through use of an init script. (See init(8).) To run class_admin non-interactively, specify one or more subcommands as arguments on the utility command line. Interactive mode is useful after system startup. To run class_admin interactively, you can invoke class_admin without specifying any arguments, and then enter all subcommands at the utility prompt. The exception is that you should include the setp pset_num subcommand at invocation time if you do not plan to enable class scheduling for the system default partition. Database Configuration Parameters If a class scheduling database does not exist for the partition to which context is set, the class_admin utility automatically creates a class database when it starts up. When running the utility interactively, you supply configuration parameters for the database by answering three questions. For non-interactive operation, the utility automatically applies to the database the default answers to these questions. You can reset configuration parameters at a later time by using the utility's configure subcommand. The following questions prompt for database configuration parameters: 1. Shall processes that have not been explicitly assigned to a defined class be assigned to a "default" class? Enter (yes/no) [no]: To be class scheduled, a process must be assigned to a class. If you answer yes to this question, a special class called the "default" class will be created, and any process that does not belong to the classes you define will be assigned to this class. If you answer no to this question, then only those processes that belong to classes defined by you are class scheduled. Processes owned by root (UID 0) are not subject to class scheduling. 2. Enforce class scheduling when the CPU is otherwise idle? (yes/no) [yes]: If you answer no to this question, the scheduler can allow a class to exceed its CPU percentage when the partition has idle CPUs. Otherwise, a class is held to its allotted percentage even if the CPUs in the partition have no other work. 3. How often do you want the system to reset class usage? Enter number of seconds (1): If there are interactive jobs subject to class scheduling, use a small number (no more than several seconds) to ensure a quick response time. If only batch jobs are class scheduled, you can enter larger values because system response time is not an issue. If you included the enable subcommand on the class_admin command line, your settings take effect immediately. Subcommands add Add one or more identifiers for a group, user, process, process group, or session to an existing scheduling class. If the specified identifier is a member of another class, you will be asked whether you want to move the member. Syntax: add class_name type id [id]... The type argument can be one of the following: gid To add one or more group identifiers to the class. In this case, the specified numbers reside in the /etc/group file. These identifiers will persist in the class scheduling database across reboots. uid To add one or more user identifiers to the class. In this case, the specified numbers reside in the /etc/passwd file. These identifiers will persist in the class scheduling database across reboots. pid To add one or more process identifiers to the class. In this case, the specified numbers, as shown in the PID column of the ps command display, persist in the class scheduling database only as long as those processes are running. pgrp To add one or more process group identifiers to the class. In this case, the specified numbers, as shown in the PGID column of the ps command display, persist in the class scheduling database only as long as any processes in those process groups are running. session To add one or more session identifiers to the class. In this case, the specified numbers, as shown in the SESS column of the ps command display, persist in the class scheduling database only as long as any processes in those sessions are running. cancel Remove recent changes to the currently loaded database and go back to the version last saved to disk. Syntax: cancel change Change the CPU percentage allotted to a scheduling class. You cannot specify a CPU percentage that would cause the total of percentages for all classes in the database to exceed 100%. Syntax: change class_name cpu_percentage create Create a new scheduling class. The specified name must be unique and cannot exceed 20 characters. Because a newly created class will be empty, you must use the add subcommand to populate the class with members or add process members indirectly through the runclass command after class scheduling is enabled. You cannot specify a CPU percentage that would cause the total of percentages for all classes in the database to exceed 100%. Syntax: create class_name cpu_percentage configure Set up the basic class scheduling parameters. You will be asked the three questions discussed in the "Database Configuration Parameters" section. Syntax: configure delete Remove one or more member identifiers from an existing scheduling class. Syntax: delete class_name type id [id]... See the entry for the add subcommand for a list of supported type values. destroy Destroy an existing scheduling class. If the class is not empty, you will be asked for permission to destroy it anyway. Syntax: destroy class_name disable Turn off class scheduling for the partition to which context is set. Note that the kernel will terminate the instance of the scheduler daemon for that partition. Syntax: disable enable Turn on class scheduling for the partition to which context is set. This starts a daemon that periodically examines CPU usage by different classes and makes adjustments in CPU access according to the class limits. Syntax: enable exit Return to the command shell. If there are any unsaved changes to the current class scheduling database during your session, you will be asked whether you want to save them. (Same as for quit.) Syntax: exit help Display online help. If you specify a particular subcommand, the utility displays the syntax for only that subcommand. Otherwise, the utility displays a list of all subcommands and their arguments. Syntax: help [subcommand] listp List all partitons and the status of class scheduling for each. Syntax: listp load Load the specified class database from disk into memory. Syntax: load database_path The database_path is the path to the class database. By default, class databases reside in the /etc/class directory and have file names in the format part.partition. If you made changes to the database that is currently loaded into memory and neither cancelled nor saved these changes to disk, the utility tells you that load operation will destroy unsaved changes and asks if you still want to proceed with the load operation. quit Return to the command shell. If there are any unsaved changes to the database that is currently loaded into memory, you will be asked whether you want to save them. (Same as for exit.) Syntax: quit rename Change the name of an scheduling class. Syntax: rename old_class_name new_class_name save Write permanent database changes to a file on disk and continue. Syntax: save [database_path] The database_path argument is the pathname for the class database that you are currently setting up or changing. If you omit this argument, changes are saved to the disk file of the class database currently loaded into memory. If you invoked class_admin to set up a new database, use the show command to see the default name and directory for the associated file. If you decide to change the default name or location, remember that the pathname cannot exceed 80 characters. setp Set partition context. Syntax: setp [pset_id] If you do not specify pset_id, the system default partition (processor set 0) is assumed. See also listp. show Show the CPU percentage and members for a scheduling class. If you do not specify a class name, the utility shows this information for all classes in the currently loaded database. Syntax: show [class_name] stats List the target and actual CPU utilization for a scheduling class. If you do not specify a class name, the utility shows CPU utilization for all classes in the current database. Syntax: stats [class_name]

FILES

/etc/class/part.* Default pathname for a class database, where * represents the partition. /usr/sbin/class_daemon The class scheduler daemon.

SEE ALSO

Commands: ps(1), runclass(1) Files: class_scheduling(4), processor_sets(4) Functions: class_add(3), class_change(3), class_change_name(3), class_close(3), class_configure(3), class_create(3), class_database_file_exists(3), class_database_modified(3), class_database_name(3), class_delete(3), class_destroy(3), class_disable(3), class_get_class_members(3), class_get_classes(3), class_get_config_stats(3), class_load_database(3), class_open(3), class_restore_database(3), class_save_database(3)

Index Index for
Section 8
Index Alphabetical
listing for C
Top of page Top of
page