class_admin - Administer daemons and databases for class
scheduling.
/usr/sbin/class_admin [subcommand[, subcommand]...]
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 noninteractively.
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 [Toc] [Back]
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: 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.
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. 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 [Toc] [Back]
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: 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. 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. 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. 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. 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. Remove
recent changes to the currently loaded database and
go back to the version last saved to disk.
Syntax: cancel 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 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 Set up the
basic class scheduling parameters. You will be
asked the three questions discussed in the
"Database Configuration Parameters" section.
Syntax: configure 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 an existing
scheduling class. If the class is not empty, you
will be asked for permission to destroy it anyway.
Syntax: destroy class_name 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 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 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 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] List all partitons and
the status of class scheduling for each.
Syntax: listp 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. 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 Change the name of an scheduling
class.
Syntax: rename old_class_name new_class_name 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. 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 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] 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]
Default pathname for a class database, where * represents
the partition. The class scheduler daemon.
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)
class_admin(8)
[ Back ] |