2001-08-30 04:48:02 +00:00
|
|
|
.\" Copyright (c) 1999 Berkeley Software Design, Inc. 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.
|
|
|
|
.\" 3. Berkeley Software Design Inc's name may not be used to endorse or
|
|
|
|
.\" promote products derived from this software without specific prior
|
|
|
|
.\" written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY BERKELEY SOFTWARE DESIGN INC ``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 BERKELEY SOFTWARE DESIGN INC 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.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2012-06-04 09:25:01 +00:00
|
|
|
.Dd June 4, 2012
|
2001-08-30 04:48:02 +00:00
|
|
|
.Dt DAEMON 8
|
2001-08-31 12:52:50 +00:00
|
|
|
.Os
|
2001-08-30 04:48:02 +00:00
|
|
|
.Sh NAME
|
|
|
|
.Nm daemon
|
|
|
|
.Nd run detached from the controlling terminal
|
|
|
|
.Sh SYNOPSIS
|
2001-08-31 12:52:50 +00:00
|
|
|
.Nm
|
2012-06-04 09:25:01 +00:00
|
|
|
.Op Fl cfr
|
2004-06-02 06:48:13 +00:00
|
|
|
.Op Fl p Ar pidfile
|
2007-03-19 12:12:53 +00:00
|
|
|
.Op Fl u Ar user
|
2001-08-31 12:52:50 +00:00
|
|
|
.Ar command arguments ...
|
2001-08-30 04:48:02 +00:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
2001-08-31 12:52:50 +00:00
|
|
|
utility detaches itself from the controlling terminal and
|
2001-08-30 04:48:02 +00:00
|
|
|
executes the program specified by its arguments.
|
2007-03-19 12:12:53 +00:00
|
|
|
Privileges may be lowered to the specified user.
|
2001-08-30 04:48:02 +00:00
|
|
|
.Pp
|
|
|
|
The options are as follows:
|
2001-08-31 12:52:50 +00:00
|
|
|
.Bl -tag -width indent
|
2001-08-30 04:48:02 +00:00
|
|
|
.It Fl c
|
2001-08-31 12:52:50 +00:00
|
|
|
Change the current working directory to the root
|
|
|
|
.Pq Dq Pa / .
|
2001-08-30 04:48:02 +00:00
|
|
|
.It Fl f
|
|
|
|
Redirect standard input, standard output and standard error to
|
|
|
|
.Pa /dev/null .
|
2004-06-02 06:48:13 +00:00
|
|
|
.It Fl p Ar file
|
2004-07-07 19:57:16 +00:00
|
|
|
Write the ID of the created process into the
|
2005-08-24 17:24:39 +00:00
|
|
|
.Ar file
|
2007-03-19 12:12:53 +00:00
|
|
|
using the
|
2005-08-24 17:24:39 +00:00
|
|
|
.Xr pidfile 3
|
|
|
|
functionality.
|
2012-02-19 10:20:37 +00:00
|
|
|
The program is executed in a spawned child process while the
|
|
|
|
.Nm
|
|
|
|
waits until it terminates to keep the
|
|
|
|
.Ar file
|
|
|
|
locked and removes it after the process exits.
|
|
|
|
The
|
|
|
|
.Ar file
|
|
|
|
owner is the user who runs the
|
|
|
|
.Nm
|
|
|
|
regardless of whether the
|
2012-01-25 14:50:12 +00:00
|
|
|
.Fl u
|
2012-02-19 10:20:37 +00:00
|
|
|
option is used or not.
|
2012-02-19 10:36:29 +00:00
|
|
|
.It Fl r
|
|
|
|
Supervise and restart the program if it has been terminated.
|
|
|
|
.It Fl u Ar user
|
|
|
|
Login name of the user to execute the program under.
|
|
|
|
Requires adequate superuser privileges.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
If the
|
|
|
|
.Fl p
|
|
|
|
or
|
|
|
|
.Fl r
|
|
|
|
option is specified the program is executed in a spawned child process.
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
waits until it terminates to keep the pid file locked and removes it
|
|
|
|
after the process exits or restarts the program.
|
|
|
|
In this case if the monitoring
|
2012-02-19 10:23:51 +00:00
|
|
|
.Nm
|
|
|
|
receives software termination signal (SIGTERM) it forwards it to the
|
|
|
|
spawned process.
|
|
|
|
Normally it will cause the child to exit followed by the termination
|
|
|
|
of the supervising process after removing the pidfile.
|
2005-01-17 07:44:44 +00:00
|
|
|
.Sh EXIT STATUS
|
2001-08-30 04:48:02 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility exits 1 if an error is returned by the
|
|
|
|
.Xr daemon 3
|
2004-07-07 19:57:16 +00:00
|
|
|
library routine, 2 if the
|
|
|
|
.Ar pidfile
|
2005-08-24 17:24:39 +00:00
|
|
|
is requested, but cannot be opened, 3 if process is already running (pidfile
|
|
|
|
exists and is locked),
|
2004-06-02 06:48:13 +00:00
|
|
|
otherwise 0.
|
2005-01-17 07:44:44 +00:00
|
|
|
.Sh DIAGNOSTICS
|
2001-08-30 04:48:02 +00:00
|
|
|
If the command cannot be executed, an error message is displayed on
|
|
|
|
standard error unless the
|
|
|
|
.Fl f
|
|
|
|
flag is specified.
|
|
|
|
.Sh SEE ALSO
|
2007-03-09 09:33:19 +00:00
|
|
|
.Xr setregid 2 ,
|
|
|
|
.Xr setreuid 2 ,
|
2001-08-30 04:48:02 +00:00
|
|
|
.Xr daemon 3 ,
|
|
|
|
.Xr exec 3 ,
|
2005-08-24 17:24:39 +00:00
|
|
|
.Xr pidfile 3 ,
|
2001-08-30 04:48:02 +00:00
|
|
|
.Xr termios 4 ,
|
|
|
|
.Xr tty 4
|
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility first appeared in
|
2003-02-05 19:16:18 +00:00
|
|
|
.Fx 4.7 .
|