INIT.D(4) File Formats and Configurations INIT.D(4)
init.d - initialization and termination scripts for changing init states
is a directory containing initialization and termination
scripts for changing init states. These scripts are linked when
appropriate to files in the rc?.d
directories, where `?
' is a single
character corresponding to the init state. See init(1M)
of the states.
The service management facility (see smf(5)
) is the preferred mechanism
for service initiation and termination. The init.d
are obsolete, and are provided for compatibility purposes only.
Applications launched from these directories by svc.startd(1M)
incomplete services, and will not be restarted on failure.
File names in rc?.d
directories are of the form [SK]nn<init.d filename>
means start this job, K
means kill this job, and nn
relative sequence number for killing or starting the job.
When entering a state (init S,0,2,3,etc.) the rc[S0-6]
those scripts in /etc/rc[S0-6].d
that are prefixed with K
those scripts prefixed with S
. When executing each script in one of the /etc/rc[S0-6] directories, the /sbin/rc[S0-6]
script passes a single
argument. It passes the argument 'stop' for scripts prefixed with K
the argument 'start' for scripts prefixed with S
. There is no harm in
applying the same sequence number to multiple scripts. In this case the
order of execution is deterministic but unspecified.
Guidelines for selecting sequence numbers are provided in README
located in the directory associated with that target state. For example, /etc/rc[S0-6].d/README
. Absence of a README
file indicates that there are
currently no established guidelines.
Do not put /etc/init.d
in your $PATH
. Having this directory in your $PATH
can cause unexpected behavior. The programs in /etc/init.d
state changes and, under normal circumstances, are not intended
to be invoked from a command line.
Example 1: Example of /sbin/rc2.
When changing to init state 2 (multi-user mode, network resources not
is initiated by the svc.startd(1M)
following steps are performed by /sbin/rc2
1. In the directory /etc/rc2.d
are files used to stop processes
that should not be running in state 2. The filenames are
prefixed with K
. Each K
file in the directory is executed (by /sbin/rc2
) in alphanumeric order when the system enters init
state 2. See example below.
2. Also in the rc2.d
directory are files used to start processes
that should be running in state 2. As in Step 1, each S
Assume the file /etc/init.d/netdaemon
is a script that will initiate
networking daemons when given the argument 'start', and will terminate
the daemons if given the argument 'stop'. It is linked to /etc/rc2.d/S68netdaemon
, and to /etc/rc0.d/K67netdaemon
. The file is
executed by /etc/rc2.d/S68netdaemon start
when init state 2 is entered
and by /etc/rc0.d/K67netdaemon stop
when shutting the system down.
SEE ALSO svcs(1)
Solaris now provides an expanded mechanism, which includes automated
restart, for applications historically started via the init script
mechanism. The Service Management Facility (introduced in smf(5)
) is the
preferred delivery mechanism for persistently running applications.
scripts will, however, continue to be executed according
to the rules in this manual page. The details of execution in relation to
managed services are available in svc.startd(1M)
On earlier Solaris releases, a script named with a suffix of '.sh' would
be sourced, allowing scripts to modify the environment of other scripts
executed later. This behavior is no longer supported; for altering the
environment in which services are run, see the setenv
subcommand in svccfg(1M)
May 13, 2017 INIT.D(4)