- all TTY-related exceptions have now been merged into the regular code paths, allowing non-TTY drivers to expose TTY-like devices; - as part of this, CTTY_MAJOR is now fully managed by VFS instead of being an ugly stepchild of the TTY driver; - device styles have become completely obsolete, support for them has been removed throughout the system; same for device flags, which had already become useless a while ago; - device map open/close and I/O function pointers have lost their use, thus finally making the VFS device code actually readable; - the device-unrelated pm_setsid has been moved to misc.c; - some other small cleanup-related changes. Change-Id: If90b10d1818e98a12139da3e94a15d250c9933da
		
			
				
	
	
		
			241 lines
		
	
	
		
			8.1 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			241 lines
		
	
	
		
			8.1 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
.TH SERVICE 8
 | 
						|
.SH NAME
 | 
						|
service \- Manage an operating system service.
 | 
						|
.SH SYNOPSIS
 | 
						|
.PP
 | 
						|
\fBservice [-b -c -n -p -r] (up|run|edit|update)\fR \fI<binary|self>\fR
 | 
						|
[\fB-args\fR \fI<args>\fR] [\fB-dev\fR \fI<special>\fR]
 | 
						|
[\fB-period\fR \fI<ticks>\fR]
 | 
						|
[\fB-script\fR \fI<path>\fR] [\fB-label\fR \fI<name>\fR]
 | 
						|
[\fB-config\fR \fI<path>\fR] [\fB-state\fR \fI<state>\fR]
 | 
						|
[\fB-maxtime\fR \fI<time>\fR]
 | 
						|
.PP
 | 
						|
\fBservice down\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
\fBservice refresh\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
\fBservice restart\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
\fBservice clone\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
\fBservice shutdown\fR
 | 
						|
.br
 | 
						|
.de FL
 | 
						|
.TP
 | 
						|
\\fB\\$1\\fR
 | 
						|
\\$2
 | 
						|
..
 | 
						|
.de EX
 | 
						|
.TP
 | 
						|
\\fB\\$1\\fR
 | 
						|
\\$2
 | 
						|
..
 | 
						|
.SH DESCRIPTION
 | 
						|
.PP
 | 
						|
The \fBservice\fR utility instructs the reincarnation server (\fBRS\fR)
 | 
						|
to perform an action for a given system service (an OS server
 | 
						|
or device driver). The action may concern an existing system service
 | 
						|
(SHIFT+F6 to list them all), or a new system service to be started
 | 
						|
(actions \fBup\fR and \fBrun\fR).
 | 
						|
.br
 | 
						|
.de FL
 | 
						|
.TP
 | 
						|
\\fB\\$1\\fR
 | 
						|
\\$2
 | 
						|
..
 | 
						|
.de EX
 | 
						|
.TP
 | 
						|
\\fB\\$1\\fR
 | 
						|
\\$2
 | 
						|
..
 | 
						|
.SH ACTIONS
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice up\fR \fI<binary>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Starts a new system service identified by the given \fI<binary>\fR,
 | 
						|
which must be specified using an absolute path. When the service
 | 
						|
unexpectedly exits (for example, as a result of a crash or a panic), \fBRS\fR
 | 
						|
will intercept the event and restart the service automatically.
 | 
						|
If the service fails to restart, \fBRS\fR will automatically bring
 | 
						|
it down allowing for graceful degradation of service. If a critical
 | 
						|
system service fails to restart, \fBRS\fR will immediately resort to
 | 
						|
a system-wide panic. The \fBup\fR action takes the following options:
 | 
						|
.TP
 | 
						|
.BI \-b "          "
 | 
						|
disable the usage of binary exponential restart time in \fBRS\fR.
 | 
						|
.TP
 | 
						|
.BI \-c "          "
 | 
						|
\fBRS\fR normally relies on the binary on the disk to restart a
 | 
						|
system service. The
 | 
						|
.B \-c
 | 
						|
option instructs \fBRS\fR to keep an in-memory copy of the binary and
 | 
						|
use the copy to restart the service upon termination. This is necessary
 | 
						|
when the location on the disk may change or if the service itself is
 | 
						|
required to read the binary from the disk (e.g. the disk driver).
 | 
						|
.TP
 | 
						|
.BI \-n "          "
 | 
						|
by default, \fBRS\fR performs blocking startup of the system service. As
 | 
						|
a result, the \fBup\fR action does not terminate until the system service
 | 
						|
completes initialization.
 | 
						|
The
 | 
						|
.B \-n
 | 
						|
option changes the default behavior by performing non-blocking startup
 | 
						|
and thus terminating the \fBup\fR action immediately without waiting for
 | 
						|
the service to complete initialization.
 | 
						|
.TP
 | 
						|
.BI \-p "          "
 | 
						|
instructs \fBRS\fR to keep a replica of the system service in background
 | 
						|
and use the replica to restart the service upon termination. This is
 | 
						|
necessary when the service itself is required to create a working
 | 
						|
service instance (e.g. \fBPM\fR).
 | 
						|
.TP
 | 
						|
.BI \-r "          "
 | 
						|
when saving an in-memory copy, instructs \fBRS\fR to reuse and share the copy
 | 
						|
of an existing service with the same program name, if available.
 | 
						|
.TP
 | 
						|
.BI \-args " <args>"
 | 
						|
specifies the command line arguments to use to run the program
 | 
						|
given by \fI<binary>\fR. The default is to use no arguments.
 | 
						|
.TP
 | 
						|
.BI \-dev " <special>"
 | 
						|
specifies the device file to associate to the system service (used only for
 | 
						|
device drivers). The default is to associate no device file to the service.
 | 
						|
.TP
 | 
						|
.BI \-period " <ticks>"
 | 
						|
specifies the period to use for the system service.
 | 
						|
When a period is specified, \fBRS\fR sends a ping request to
 | 
						|
the system service after every period. If the response does not arrive
 | 
						|
in time, \fBRS\fR will kill the misbehaving service and restart a new one.
 | 
						|
The period must be specified in ticks, but can be appended with HZ to
 | 
						|
make it seconds. The default is to use no period for the service.
 | 
						|
.TP
 | 
						|
.BI \-script " <path>"
 | 
						|
specifies the recovery script to associate to the system service. When a
 | 
						|
recovery script is used, \fBRS\fR will not attempt to restart the service
 | 
						|
upon termination. \fBRS\fR will instead invoke the script and
 | 
						|
delegate the recovery process to it. The script may perform several
 | 
						|
operations, including instructing \fBRS\fR to restart the service
 | 
						|
(\fBrestart\fR action) or bring it down (\fBdown\fR  action).
 | 
						|
The default is to associate no recovery script to the service.
 | 
						|
.TP
 | 
						|
.BI \-label " <name>"
 | 
						|
specifies the label to use for the system service. The label is used to
 | 
						|
univoquely identify the system service. The default is to use the program
 | 
						|
name as the label.
 | 
						|
.TP
 | 
						|
.BI \-config " <path>"
 | 
						|
specifies the absolute path of the system configuration file with the settings
 | 
						|
of the system service. See
 | 
						|
.IR system.conf (5)
 | 
						|
for the syntax to use in the system configuration file.
 | 
						|
The default is to use the global system configuration file \fB/etc/system.conf\fR.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice run\fR \fI<binary>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Runs a new system service identified by the given \fI<binary>\fR,
 | 
						|
which must be specified using an absolute path. Similar to
 | 
						|
\fBservice up\fR \fI<binary>\fR, but instructs \fBRS\fR not to
 | 
						|
restart the service upon termination. This action is currently a shorthand
 | 
						|
for \fBservice up\fR \fI<binary>\fR \fB-script\fR \fI/etc/rs.single\fR, which
 | 
						|
uses a recovery script that simply brings down the service upon termination.
 | 
						|
This action should be only used for short-lived programs that need system
 | 
						|
service privileges and do not require crash recovery support.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice edit\fR \fI<binary>\fR [\fB-label\fR \fI<name>\fR]
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Edits settings of an existing system service identified by the given
 | 
						|
label \fI<name>\fR. This action can be used to dynamically update the
 | 
						|
properties of any system service, including those contained in the
 | 
						|
boot image (e.g. \fBVM\fR). There are a few exceptions to the properties
 | 
						|
that can be actually overridden dynamically. For example, the device file
 | 
						|
associated to the service will no be updated. This
 | 
						|
action takes the same options supported by the \fBup\fR action.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice update\fR \fI<binary|self>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Live updates an existing system service with a new version identified by the
 | 
						|
given \fI<binary>\fR, which must be specified using an absolute path.
 | 
						|
The existing service will be identified from the label given (if explicitly
 | 
						|
specified), or from the program name. If \fI<self>\fR is specified as
 | 
						|
an argument instead, \fBRS\fR will perform a self update of the
 | 
						|
system service (i.e. an update of the service with its own replica). This
 | 
						|
is intended for testing purposes. In this case, a label \fI<name>\fR
 | 
						|
must be explicitly specified. Live update support is still in an early
 | 
						|
stage of development and is subject to change in future revisions. This
 | 
						|
action takes all the options supported by the \fBup\fR action and the
 | 
						|
following additional options:
 | 
						|
.TP
 | 
						|
.BI \-state " <state>"
 | 
						|
specifies the state of the service required by the update. The default
 | 
						|
is a state in which the service is blocked not processing any work.
 | 
						|
.TP
 | 
						|
.BI \-maxtime " <time>"
 | 
						|
specifies the maximum amount time for the service to prepare
 | 
						|
for the update. The default is 0 (unlimited).
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice down\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Stops an existing system service identified by the given \fI<label>\fR. \fBRS\fR
 | 
						|
will bring down the service without attempting to restart it. Critical system
 | 
						|
services cannot be shut down.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice refresh\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Refreshes an existing system service identified by the given \fI<label>\fR.
 | 
						|
\fBRS\fR will kill the service and attempt to restart it.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice restart\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Restarts an existing terminated system service identified by the
 | 
						|
given \fI<label>\fR. This action can only be used from a recovery script.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice clone\fR \fI<label>\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Clones an existing system service to create a replica \fBRS\fR will use
 | 
						|
to restart the service upon termination.
 | 
						|
.PP
 | 
						|
.SS
 | 
						|
\fBservice shutdown\fR
 | 
						|
.PP
 | 
						|
.PP
 | 
						|
Tells \fBRS\fR the system is about to shutdown and no system service should
 | 
						|
be restarted upon termination.
 | 
						|
.PP
 | 
						|
.SH EXAMPLES
 | 
						|
.TP 20
 | 
						|
.B service up /sbin/is -period 5HZ
 | 
						|
# Start the IS server and check its status every 5 seconds.
 | 
						|
.br
 | 
						|
.TP 20
 | 
						|
.B service up /usr/sbin/dp8390 -args DPETH0=pci
 | 
						|
# Start the DP8390 ethernet driver, passing one argument.
 | 
						|
.br
 | 
						|
.TP 20
 | 
						|
.B service down lance
 | 
						|
# Stop the system service with label lance.
 | 
						|
.br
 | 
						|
.SH "SEE ALSO"
 | 
						|
.PP
 | 
						|
.BR system.conf (5),
 | 
						|
.BR boot (8),
 | 
						|
.BR monitor (8).
 | 
						|
.SH AUTHOR
 | 
						|
Cristiano Giuffrida <giuffrida@cs.vu.nl>
 | 
						|
 |