System Management
The management of a Solaris system is quite similar to that of a Linux system.
Often the commands used are the same, or, in the case of printing, the
subsystem is the same. This can aid in the move from Linux to Solaris as the
experience gained on Linux is directly applicable on Solaris.
This chapter will attempt to go through some of the aspects of system
management and highlight some of the similarities and di erences between
Linux and Solaris.
Topics Covered
• Booting, Shutdown and Run Levels
• System Services
• User/Group Management
• File System Management
• Disk and Volume Management
• Network Management
• Remote Management
Booting, Shutdown and Run Levels
Up to Solaris 9 the boot procedures between Linux and Solaris were very
similar. Both systems provided the concept of run levels that were used to dene
what services were started and stopped at each level. The init command was
used to switch between these run levels.
Table 6.1 lists the traditional run levels seen on a Linux system.
Table 6.1: Linux run levels
0 halt
1 single user
2-5 multi user
6 reboot
Solaris machines up to Solaris 9 used a set of run levels as shown in Table 6.2.
Table 6.2: Solaris run levels before Solaris 10
S, s or 1 single user state
0 halt
2 multi-user no network services
3 multi-user with network services
4 unused
5 power o
6 reboot
With Solaris 10, and the inclusion of SMF, the run levels have been replaced
by milestones. Table 6.3 lists the default set of milestones.
Table 6.3: Solaris 10 milestones
sysconfig
devices
single-user Equivalent to run level 1.
network
name-services
multi-user Equivalent to run level 2 in previous Solaris versions.
multi-user-server Equivalent to run level 3 in previous Solaris versions.
Solaris 10 still provides a limited set of run levels as seen in Table 6.4. As in
previous versions of Solaris, and with Linux, you can use init to switch to any
one of these levels.
Table 6.4: Solaris 10 run levels
0 halt
1, s, or S single user
5 power o
6 reboot
Two other commands are available to manipulate the current system state on
Solaris, the reboot and halt commands. These commands will restart or halt the
system, respectively. It should be noted that when using these commands the
system will not go through the normal shutdown procedures. Services are not
stopped. Processes are simply killed, file systems unmounted and the system
rebooted or halted.
The recommended method to reboot or halt the system is to use init.
System Services
When using a Linux system, unless run from inittab with the respawn attribute,
system services will not be respawned if they're killed or terminate abnormally.
With Solaris 10, and the addition of SMF, it isn't possible to simply kill a
system service as it will be automatically restarted by SMF. You have to use
the svcadm commands to disable or enable the service.
Services that would be handled by xinetd on Linux are managed by SMF in
Solaris 10. When editing the services available through inetd you will edit the /
etc/inet/inetd.conf le. You must then execute inetconv to create the
corresponding service entries in SMF. All control of the inetd services will
now be done through inetadm or svcadm.
On a Linux system the typical places to con gure services are listed in Table
6.5.
Table 6.5: Linux services configuration locations
/etc/inittab To be controlled by init.
/etc/rc*.d Run level speci c scripts that start system services.
/etc/(x)inetd.conf Controlled by inetd.
Table 6.6: Solaris services configuration locations
/etc/inittab To be controlled by init. Not recommended in Solaris 10.
/etc/rc?.d, /etc/init.d Run level specific scripts that start system services.
/etc/inetd.conf Controlled by inetd; in Solaris 10, use SMF and inetadm.
SMF Solaris 10 only.
User/Group Management
Solaris extends the useradd and groupadd commands as seen in Linux to
provide extensions to manage RBAC-related properties. Other options may
differ between Linux and Solaris.
Along with useradd and groupadd Solaris also provides smuser and smgroup to
manage accounts and groups in a name server, such as NIS. These two
commands are part of the Solaris Management Console (SMC). smc is also
available as a graphical environment to manage users and groups.
File System Management
Solaris supports a wide variety of le system types to support most storage
media (CDs, DVDs, Hard Drives, oppy disks, ash based storage) and network
based file system protocols. Solaris also uses le systems to implement various
system interface features, and to export some kernel information as files visible
to the user (ie. /etc/mnttab). Table 6.8 shows the various file system types
supported under Solaris 10. In addition to the native supported file system,
third party software vendors also provide file systems; for example, Veritas
provides the vxfs file system.
Table 6.8: File System Types
autofs Automount File System.
cachefs Caching File System.
ctfs Contract File System.
devfs Devices File System.
fd File Descriptor File System.
hsfs High Sierra File System (CDs).
lofs Loopback Virtual File System.
mntfs Mount Table File System (/etc/mnnttab).
nfs Network File System.
objfs Kernel Object File System.
pcfs DOS formatted le system.
proc /proc File System.
qfs Distributed le system.
sam-fs Archive management and retrieval.
tmpfs Memory based le system (/tmp).
udfs Universal Disk Format File System (DVDs).
ufs Unix File System.
volfs Volume Management File System.
xmemfs Extended Memory File System.
In Solaris, file systems are mounted using the mount(1M) command. Linux
places the mount command in /bin. In Solaris this command is located in
/usr/sbin. The file system type is provided to the Linux mount command using
the -t vfstype option. The equivalent option for the Solaris mount command is -
F FSType.
File System Quotas
There are three main commands to work with file system quotas on Solaris. Of
the three, only quot is unique to Solaris. quot will list the file system usage per
system user.
The other two commands, edquota and quota, while being named the same as
their Linux counterparts, have di ering options and behaviour.
Disk and Volume Management
Disk Management
There are two main commands used to work with disks on Solaris, fdisk and
format. The fdisk command (on x86 systems) is used to create a partition on
the disk. Solaris partitions have type 0x82, which is the same as the Linux
SWAP partition. This may cause issues when dual booting an x86 machine
with Solaris.
Solaris uses a single partition with type 0x82 then uses Sun disk labels within
the partition to split it further into slices. This slicing is done with the format
command.
As of Solaris 10 6/06 the partition type 0x82 is depreciated. A new type, 0xbf,
is now used as the partition type for Solaris (this is the Solaris2 type). Solaris
will continue to recognize the older 0x82 (solaris) ID. Older non-Solaris
partitioning software may not yet recognize the 0xbf partition type.
format is used to slice up Solaris fdisk partitions (on x86 systems) or disks
(SPARC) into Solaris slices. format will present the user with a list of disks to
manage. All disks recognized by the system are listed. Once a disk is selected,
the part command can be used to partition it into slices.
Volume Management
Volume management on Linux is controlled using the vg* and lv* commands.
If you aren't using ZFS, then Solaris uses a set of metadevices for volume
management. These metadevices are maintained using the meta* commands
given in Table 6.9.
Table 6.9: Metadevice commands
metadb Creates and manages metadevice
databases.
metainit Initializes metadevices.
metattach Used to attach a metadevice to a mirror
and to attach space to a soft partition.
metadetach Used to detach a metadevice from a
mirror
metahs Used to manage hotspare pools
metaoffline place submirrors offline
metaonline place submirrors online
metaparam modify parameters of metadevices
metarecover recover soft partition information
metarename renames a metadevice
metaset configure shared disksets
metastat Display status of metadevice
metaclear Delete active metadevices and hot
spare pools
metadevadm updates metadevice information
metasync performs metadevice resync during
reboot
metareplace Enable or replace components of
submirrors or RAID 5 metadevices.
Network Management
There are commands, as seen in Table 6.10, and les, as seen in Table 6.11,
which are involved in the configuration of networking on a Solaris host.
Table 6.10: Networking tools
ifconfig Configure interfaces and devices.
route Configure network routes.
netstat Display network configuration and
connection status.
ndd Get/set configuration parameters in
select kernel drivers.
Table 6.11: Networking configuration files
/etc/hostname.[interface name] Each network interface has a
corresponding file which indicates the
hostname to use for assigning IP
addresses to the interface. Also used to
indicate that a network interface is to
use DHCP.
/etc/nodename Hostname of the system.
/etc/hosts Static table of IP addresses.
/etc/defaultrouter IP address of the default router.
/etc/netmasks Table of default netmasks for various
networks.
/etc/networks Table of networks and their names.
/etc/dhcp.[interface name] DHCP parameters for interface.
/etc/resolv.conf DNS client configuration.
/etc/nsswitch.conf Name service switch file. Used to
select the source for various network
information parameters.
Remote Management
Solaris comes bundled with both telnet and ssh to handle remote system
access. These services can be enabled and disabled with SMF as needed.
In addition to the command line access you can also use the SMC GUI to
manage a remote Solaris host.