2009-01-01 14:32:09 +00:00
|
|
|
.\" Copyright 2007-2009 Roy Marples
|
2007-12-17 10:14:54 +00:00
|
|
|
.\" All rights reserved
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
2009-04-22 10:49:07 +00:00
|
|
|
.Dd April 22, 2009
|
2007-12-17 10:14:54 +00:00
|
|
|
.Dt START-STOP-DAEMON 8 SMM
|
|
|
|
.Os OpenRC
|
|
|
|
.Sh NAME
|
|
|
|
.Nm start-stop-daemon
|
|
|
|
.Nd ensures that daemons start and stop
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm
|
|
|
|
.Fl S , -start
|
|
|
|
.Ar daemon
|
|
|
|
.Op Fl -
|
|
|
|
.Op Ar arguments
|
|
|
|
.Nm
|
|
|
|
.Fl K , -stop
|
|
|
|
.Ar daemon
|
|
|
|
.Nm
|
|
|
|
.Fl s , -signal
|
|
|
|
.Ar signal
|
|
|
|
.Ar daemon
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nm
|
|
|
|
provides a consistent method of starting, stopping and signalling daemons.
|
2008-07-27 11:30:49 +00:00
|
|
|
If neither
|
|
|
|
.Fl K , -stop
|
|
|
|
nor
|
|
|
|
.Fl s , -signal
|
|
|
|
are provided, then we assume we are starting the daemon.
|
2007-12-17 10:14:54 +00:00
|
|
|
If a daemon cannot background by itself, nor create a pidfile,
|
|
|
|
.Nm
|
|
|
|
can do it for the daemon in a secure fashion.
|
|
|
|
.Pp
|
2007-04-05 11:18:42 +00:00
|
|
|
If
|
2007-12-17 10:14:54 +00:00
|
|
|
.Nm
|
|
|
|
is used in an OpenRC service, then OpenRC can in turn check to see if the
|
|
|
|
daemon is still running. If not, then the service is marked as crashed.
|
|
|
|
.Pp
|
|
|
|
Here are the options to specify the daemon and how it should start or stop:
|
|
|
|
.Bl -tag -width indent
|
|
|
|
.It Fl x , -exec Ar daemon
|
2008-02-24 23:09:15 +00:00
|
|
|
The
|
|
|
|
.Ar daemon
|
|
|
|
we start or stop.
|
2008-07-27 11:30:49 +00:00
|
|
|
If this option is not specified, then the first non option argument
|
|
|
|
is used.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl p , -pidfile Ar pidfile
|
2008-02-24 23:09:15 +00:00
|
|
|
When starting, we expect the daemon to create a valid
|
|
|
|
.Ar pidfile
|
|
|
|
within a reasonable amount of time. When stopping we only stop the pid(s)
|
|
|
|
listed in the
|
|
|
|
.Ar pidfile .
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl n , -name Ar name
|
2008-02-24 23:09:15 +00:00
|
|
|
Match the process
|
|
|
|
.Ar name
|
|
|
|
instead of a pidfile or executable.
|
2009-04-22 10:49:07 +00:00
|
|
|
.It Fl i , -interpreted
|
|
|
|
When matching process name, we should ensure that the correct interpreter
|
|
|
|
is also matched.
|
|
|
|
So if the daemon foo starts off like so
|
|
|
|
.D1 #!/usr/bin/perl -w
|
|
|
|
then
|
|
|
|
.Nm
|
|
|
|
matches the process
|
|
|
|
.D1 /usr/bin/perl -w foo
|
|
|
|
If an interpreted daemon changes it's process name then this won't work.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl u , -user Ar user Ns Op : Ns Ar group
|
2008-02-24 23:09:15 +00:00
|
|
|
Start the daemon as the
|
|
|
|
.Ar user
|
|
|
|
and update $HOME accordingly or stop daemons
|
|
|
|
owned by the user. You can optionally append a
|
|
|
|
.Ar group
|
|
|
|
name here also.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl t , -test
|
|
|
|
Print the action(s) that would be taken, but don't actually do anything.
|
|
|
|
The return value is set as if the command was taken and worked.
|
2008-09-22 09:37:28 +00:00
|
|
|
.It Fl v , -verbose
|
|
|
|
Print the action(s) that are taken just before doing them.
|
2007-12-17 10:14:54 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
These options are only used for starting daemons:
|
|
|
|
.Bl -tag -width indent
|
2008-07-27 11:30:49 +00:00
|
|
|
.It Fl a , -startas Ar name
|
|
|
|
Change the process name of the daemon to
|
|
|
|
.Ar name .
|
|
|
|
This just changes the first argument passed to the daemon.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl b , -background
|
|
|
|
Force the daemon into the background. Some daemons don't create pidfiles, so a
|
|
|
|
good trick is to get the daemon to run in the foreground, and use the this
|
|
|
|
option along with
|
|
|
|
.Fl m , -make-pidfile
|
|
|
|
to create a working pidfile.
|
|
|
|
.It Fl d , -chdir Ar path
|
|
|
|
chdir to this directory before starting the daemon.
|
|
|
|
.It Fl r , -chroot Ar path
|
|
|
|
chroot to this directory before starting the daemon. All other paths, such
|
|
|
|
as the path to the daemon, chdir and pidfile, should be relative to the chroot.
|
2009-01-01 14:32:09 +00:00
|
|
|
.It Fl c , -chuid Ar user
|
|
|
|
Same as the
|
|
|
|
.Fl u , -user
|
|
|
|
option.
|
2008-02-17 11:17:48 +00:00
|
|
|
.It Fl e , -env Ar VAR=VALUE
|
|
|
|
Set the environment variable VAR to VALUE.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl g , -group Ar group
|
|
|
|
Start the daemon as in the group.
|
2008-08-20 10:02:11 +00:00
|
|
|
.It Fl k , -umask Ar mode
|
|
|
|
Set the umask of the daemon.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl m , -make-pidfile
|
|
|
|
Saves the pid of the daemon in the file specified by the
|
|
|
|
.Fl p , -pidfile
|
|
|
|
option. Only useful when used with daemons that run in the foreground and
|
|
|
|
forced into the background with the
|
|
|
|
.Fl -b , -background
|
2007-04-05 11:18:42 +00:00
|
|
|
option.
|
2008-11-03 21:11:29 +00:00
|
|
|
.It Fl N , -nice Ar level
|
2007-12-17 10:14:54 +00:00
|
|
|
Modifies the scheduling priority of the daemon.
|
|
|
|
.It Fl 1 , -stdout Ar logfile
|
|
|
|
Redirect the standard output of the process to logfile when started with
|
|
|
|
.Fl background .
|
|
|
|
Must be an absolute pathname, but relative to the path optionally given with
|
|
|
|
.Fl r , -chroot .
|
|
|
|
The logfile can also be a named pipe.
|
2009-04-19 18:20:49 +00:00
|
|
|
.It Fl w , -wait Ar seconds
|
|
|
|
Wait
|
|
|
|
.Ar seconds
|
|
|
|
after starting and check that daemon is still running.
|
|
|
|
Useful for daemons that check configuration after forking or stopping race
|
|
|
|
conditions where the pidfile is written out after forking.
|
2007-12-17 10:14:54 +00:00
|
|
|
.It Fl 2 , -stderr Ar logfile
|
|
|
|
The same thing as
|
|
|
|
.Fl 1 , -stdout
|
|
|
|
but with the standard error output.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
These options are only used for stopping daemons:
|
|
|
|
.Bl -tag -width indent
|
|
|
|
.It Fl R , -retry Ar timeout | Ar signal Ns / Ns Ar timeout
|
2009-04-22 10:49:07 +00:00
|
|
|
You can either specify a timeout in seconds or a multiple signal/timeout
|
|
|
|
pairs as a stopping schedule.
|
|
|
|
If not specified then a default value of SIGTERM/5 is assumed.
|
2007-12-17 10:14:54 +00:00
|
|
|
.El
|
2008-03-29 09:37:59 +00:00
|
|
|
.Sh ENVIRONMENT
|
|
|
|
.Va SSD_NICELEVEL
|
|
|
|
can also set the scheduling priority of the daemon, but the command line
|
|
|
|
option takes precedence.
|
2008-09-26 23:58:57 +00:00
|
|
|
.Pp
|
|
|
|
.Va SSD_STARTWAIT
|
2009-04-19 18:20:49 +00:00
|
|
|
As the
|
|
|
|
.Fl w , -wait option above.
|
2008-09-26 23:58:57 +00:00
|
|
|
.Pa /etc/rc.conf
|
|
|
|
.Nm
|
|
|
|
waits for to check the daemon is still running.
|
2008-02-24 23:09:15 +00:00
|
|
|
.Sh NOTE
|
|
|
|
.Nm
|
|
|
|
uses
|
|
|
|
.Xr getopt 3
|
|
|
|
to parse its options, which allows it to accept the `--' option which will
|
|
|
|
cause it to stop processing options at that point. Any subsequent arguments
|
|
|
|
are passed as arguments to the daemon to start and used when finding a daemon
|
|
|
|
to stop or signal.
|
2007-12-17 10:14:54 +00:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr chdir 2 ,
|
|
|
|
.Xr chroot 2 ,
|
2008-02-24 23:09:15 +00:00
|
|
|
.Xr getopt 3 ,
|
|
|
|
.Xr nice 2 ,
|
|
|
|
.Xr rc_find_pids 3
|
2008-09-22 09:34:51 +00:00
|
|
|
.Sh BUGS
|
|
|
|
.Nm
|
2008-11-04 11:05:30 +00:00
|
|
|
cannot stop an interpreted daemon that no longer exists without a pidfile.
|
2008-02-24 23:09:15 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
.Nm
|
|
|
|
first appeared in Debian.
|
|
|
|
.Pp
|
|
|
|
This is a complete re-implementation with the process finding code in the
|
|
|
|
OpenRC library (librc, -lrc) so other programs can make use of it.
|
2007-12-17 10:14:54 +00:00
|
|
|
.Sh AUTHORS
|
2008-12-30 19:08:51 +00:00
|
|
|
.An Roy Marples <roy@marples.name>
|