2014-01-22 01:30:03 +04:00
|
|
|
.\"
|
|
|
|
.\" CDDL HEADER START
|
|
|
|
.\"
|
|
|
|
.\" The contents of this file are subject to the terms of the
|
|
|
|
.\" Common Development and Distribution License (the "License").
|
|
|
|
.\" You may not use this file except in compliance with the License.
|
|
|
|
.\"
|
|
|
|
.\" You can obtain a copy of the license from the top-level
|
|
|
|
.\" OPENSOLARIS.LICENSE or <http://opensource.org/licenses/CDDL-1.0>.
|
|
|
|
.\" See the License for the specific language governing permissions
|
|
|
|
.\" and limitations under the License.
|
|
|
|
.\"
|
|
|
|
.\" When distributing Covered Code, include this CDDL HEADER in each file
|
|
|
|
.\" and include the License file from the top-level OPENSOLARIS.LICENSE.
|
|
|
|
.\" If applicable, add the following below this CDDL HEADER, with the
|
|
|
|
.\" fields enclosed by brackets "[]" replaced with your own identifying
|
|
|
|
.\" information: Portions Copyright [yyyy] [name of copyright owner]
|
|
|
|
.\"
|
|
|
|
.\" CDDL HEADER END
|
|
|
|
.\"
|
|
|
|
.\" Developed at Lawrence Livermore National Laboratory (LLNL-CODE-403049).
|
|
|
|
.\" Copyright (C) 2013-2014 Lawrence Livermore National Security, LLC.
|
|
|
|
.\"
|
|
|
|
.TH ZED 8 "Octember 1, 2013" "ZFS on Linux" "System Administration Commands"
|
|
|
|
|
|
|
|
.SH NAME
|
2014-09-19 22:10:28 +04:00
|
|
|
ZED \- ZFS Event Daemon
|
2014-01-22 01:30:03 +04:00
|
|
|
|
|
|
|
.SH SYNOPSIS
|
|
|
|
.HP
|
|
|
|
.B zed
|
|
|
|
.\" [\fB\-c\fR \fIconfigfile\fR]
|
2014-09-19 22:10:28 +04:00
|
|
|
[\fB\-d\fR \fIzedletdir\fR]
|
2014-01-22 01:30:03 +04:00
|
|
|
[\fB\-f\fR]
|
|
|
|
[\fB\-F\fR]
|
|
|
|
[\fB\-h\fR]
|
|
|
|
[\fB\-L\fR]
|
|
|
|
[\fB\-M\fR]
|
|
|
|
[\fB\-p\fR \fIpidfile\fR]
|
|
|
|
[\fB\-s\fR \fIstatefile\fR]
|
|
|
|
[\fB\-v\fR]
|
|
|
|
[\fB\-V\fR]
|
|
|
|
[\fB\-Z\fR]
|
|
|
|
|
|
|
|
.SH DESCRIPTION
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
\fBZED\fR (ZFS Event Daemon) monitors events generated by the ZFS kernel
|
|
|
|
module. When a zevent (ZFS Event) is posted, \fBZED\fR will run any ZEDLETs
|
|
|
|
(ZFS Event Daemon Linkage for Executable Tasks) that have been enabled for the
|
|
|
|
corresponding zevent class.
|
2014-01-22 01:30:03 +04:00
|
|
|
|
|
|
|
.SH OPTIONS
|
|
|
|
.TP
|
|
|
|
.BI \-h
|
|
|
|
Display a summary of the command-line options.
|
|
|
|
.TP
|
|
|
|
.BI \-L
|
|
|
|
Display license information.
|
|
|
|
.TP
|
|
|
|
.BI \-V
|
|
|
|
Display version information.
|
|
|
|
.TP
|
|
|
|
.BI \-v
|
|
|
|
Be verbose.
|
|
|
|
.TP
|
|
|
|
.BI \-f
|
|
|
|
Force the daemon to run if at all possible, disabling security checks and
|
|
|
|
throwing caution to the wind. Not recommended for use in production.
|
|
|
|
.TP
|
|
|
|
.BI \-F
|
|
|
|
Run the daemon in the foreground.
|
|
|
|
.TP
|
|
|
|
.BI \-M
|
|
|
|
Lock all current and future pages in the virtual memory address space.
|
|
|
|
This may help the daemon remain responsive when the system is under heavy
|
|
|
|
memory pressure.
|
|
|
|
.TP
|
|
|
|
.BI \-Z
|
|
|
|
Zero the daemon's state, thereby allowing zevents still within the kernel
|
|
|
|
to be reprocessed.
|
|
|
|
.\" .TP
|
|
|
|
.\" .BI \-c\ configfile
|
|
|
|
.\" Read the configuration from the specified file.
|
|
|
|
.TP
|
2014-09-19 22:10:28 +04:00
|
|
|
.BI \-d\ zedletdir
|
|
|
|
Read the enabled ZEDLETs from the specified directory.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.BI \-p\ pidfile
|
|
|
|
Write the daemon's process ID to the specified file.
|
|
|
|
.TP
|
|
|
|
.BI \-s\ statefile
|
|
|
|
Write the daemon's state to the specified file.
|
|
|
|
|
|
|
|
.SH ZEVENTS
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
A zevent is comprised of a list of nvpairs (name/value pairs). Each zevent
|
2014-01-22 01:30:03 +04:00
|
|
|
contains an EID (Event IDentifier) that uniquely identifies it throughout
|
|
|
|
the lifetime of the loaded ZFS kernel module; this EID is a monotonically
|
|
|
|
increasing integer that resets to 1 each time the kernel module is loaded.
|
|
|
|
Each zevent also contains a class string that identifies the type of event.
|
|
|
|
For brevity, a subclass string is defined that omits the leading components
|
|
|
|
of the class string. Additional nvpairs exist to provide event details.
|
|
|
|
.PP
|
|
|
|
The kernel maintains a list of recent zevents that can be viewed (along with
|
|
|
|
their associated lists of nvpairs) using the "\fBzpool events \-v\fR" command.
|
|
|
|
|
|
|
|
.SH CONFIGURATION
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLETs to be invoked in response to zevents are located in the
|
|
|
|
\fIenabled-zedlets\fR directory. These can be symlinked or copied from the
|
|
|
|
\fIinstalled-zedlets\fR directory; symlinks allow for automatic updates
|
|
|
|
from the installed ZEDLETs, whereas copies preserve local modifications.
|
|
|
|
As a security measure, ZEDLETs must be owned by root. They must have
|
|
|
|
execute permissions for the user, but they must not have write permissions
|
|
|
|
for group or other. Dotfiles are ignored.
|
2014-01-22 01:30:03 +04:00
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLETs are named after the zevent class for which they should be invoked.
|
|
|
|
In particular, a ZEDLET will be invoked for a given zevent if either its
|
2014-01-22 01:30:03 +04:00
|
|
|
class or subclass string is a prefix of its filename (and is followed by
|
|
|
|
a non-alphabetic character). As a special case, the prefix "all" matches
|
2014-09-19 22:10:28 +04:00
|
|
|
all zevents. Multiple ZEDLETs may be invoked for a given zevent.
|
2014-01-22 01:30:03 +04:00
|
|
|
|
2014-09-19 22:10:28 +04:00
|
|
|
.SH ZEDLETS
|
2014-01-22 01:30:03 +04:00
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLETs are executables invoked by the ZED in response to a given zevent.
|
|
|
|
They should be written under the presumption they can be invoked concurrently,
|
|
|
|
and they should use appropriate locking to access any shared resources.
|
|
|
|
Common variables used by ZEDLETs can be stored in the default rc file which
|
|
|
|
is sourced by scripts; these variables should be prefixed with "ZED_".
|
2014-01-22 01:30:03 +04:00
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
The zevent nvpairs are passed to ZEDLETs as environment variables.
|
2014-01-22 01:30:03 +04:00
|
|
|
Each nvpair name is converted to an environment variable in the following
|
|
|
|
manner: 1) it is prefixed with "ZEVENT_", 2) it is converted to uppercase,
|
|
|
|
and 3) each non-alphanumeric character is converted to an underscore.
|
|
|
|
Some additional environment variables have been defined to present certain
|
|
|
|
nvpair values in a more convenient form. An incomplete list of zevent
|
|
|
|
environment variables is as follows:
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_EID
|
|
|
|
The Event IDentifier.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_CLASS
|
|
|
|
The zevent class string.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_SUBCLASS
|
|
|
|
The zevent subclass string.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_TIME
|
|
|
|
The time at which the zevent was posted as
|
|
|
|
"\fIseconds\fR\ \fInanoseconds\fR" since the Epoch.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_TIME_SECS
|
|
|
|
The \fIseconds\fR component of ZEVENT_TIME.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_TIME_NSECS
|
|
|
|
The \fInanoseconds\fR component of ZEVENT_TIME.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZEVENT_TIME_STRING
|
|
|
|
An almost-RFC3339-compliant string for ZEVENT_TIME.
|
|
|
|
.PP
|
|
|
|
Additionally, the following ZED & ZFS variables are defined:
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZED_PID
|
|
|
|
The daemon's process ID.
|
|
|
|
.TP
|
|
|
|
.B
|
2014-09-19 22:10:28 +04:00
|
|
|
ZED_ZEDLET_DIR
|
|
|
|
The daemon's current \fIenabled-zedlets\fR directory.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZFS_ALIAS
|
2014-09-19 22:10:28 +04:00
|
|
|
The ZFS alias (\fIname-version-release\fR) string used to build the daemon.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZFS_VERSION
|
|
|
|
The ZFS version used to build the daemon.
|
|
|
|
.TP
|
|
|
|
.B
|
|
|
|
ZFS_RELEASE
|
|
|
|
The ZFS release used to build the daemon.
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLETs may need to call other ZFS commands. The installation paths of
|
2014-01-22 01:30:03 +04:00
|
|
|
the following executables are defined: \fBZDB\fR, \fBZED\fR, \fBZFS\fR,
|
|
|
|
\fBZINJECT\fR, and \fBZPOOL\fR. These variables can be overridden in the
|
2014-09-19 22:10:28 +04:00
|
|
|
rc file if needed.
|
2014-01-22 01:30:03 +04:00
|
|
|
|
|
|
|
.SH FILES
|
|
|
|
.\" .TP
|
|
|
|
.\" @sysconfdir@/zfs/zed.conf
|
|
|
|
.\" The default configuration file for the daemon.
|
|
|
|
.TP
|
|
|
|
.I @sysconfdir@/zfs/zed.d
|
2014-09-19 22:10:28 +04:00
|
|
|
The default directory for enabled ZEDLETs.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.I @sysconfdir@/zfs/zed.d/zed.rc
|
2014-09-19 22:10:28 +04:00
|
|
|
The default rc file for common variables used by ZEDLETs.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.I @libexecdir@/zfs/zed.d
|
2014-09-19 22:10:28 +04:00
|
|
|
The default directory for installed ZEDLETs.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.I @runstatedir@/zed.pid
|
|
|
|
The default file containing the daemon's process ID.
|
|
|
|
.TP
|
|
|
|
.I @runstatedir@/zed.state
|
|
|
|
The default file containing the daemon's state.
|
|
|
|
|
|
|
|
.SH SIGNALS
|
|
|
|
.TP
|
|
|
|
.B HUP
|
2014-09-19 22:10:28 +04:00
|
|
|
Reconfigure the daemon and rescan the directory for enabled ZEDLETs.
|
2014-01-22 01:30:03 +04:00
|
|
|
.TP
|
|
|
|
.B TERM
|
|
|
|
Terminate the daemon.
|
|
|
|
|
|
|
|
.SH NOTES
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
\fBZED\fR requires root privileges.
|
2014-01-22 01:30:03 +04:00
|
|
|
.\" Do not taunt zed.
|
|
|
|
|
|
|
|
.SH BUGS
|
|
|
|
.PP
|
|
|
|
Events are processed synchronously by a single thread. This can delay the
|
|
|
|
processing of simultaneous zevents.
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
There is no maximum timeout for ZEDLET execution. Consequently, a misbehaving
|
|
|
|
ZEDLET can delay the processing of subsequent zevents.
|
2014-01-22 01:30:03 +04:00
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
The ownership and permissions of the \fIenabled-zedlets\fR directory (along
|
2014-01-22 01:30:03 +04:00
|
|
|
with all parent directories) are not checked. If any of these directories
|
|
|
|
are improperly owned or permissioned, an unprivileged user could insert a
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLET to be executed as root. The requirement that ZEDLETs be owned by
|
2014-01-22 01:30:03 +04:00
|
|
|
root mitigates this to some extent.
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
ZEDLETs are unable to return state/status information to the kernel.
|
2014-01-22 01:30:03 +04:00
|
|
|
.PP
|
|
|
|
Some zevent nvpair types are not handled. These are denoted by zevent
|
|
|
|
environment variables having a "_NOT_IMPLEMENTED_" value.
|
|
|
|
.PP
|
|
|
|
Internationalization support via gettext has not been added.
|
|
|
|
.PP
|
|
|
|
The configuration file is not yet implemented.
|
|
|
|
.PP
|
|
|
|
The diagnosis engine is not yet implemented.
|
|
|
|
|
|
|
|
.SH COPYRIGHT
|
|
|
|
.PP
|
|
|
|
Developed at Lawrence Livermore National Laboratory (LLNL\-CODE\-403049).
|
|
|
|
.br
|
|
|
|
Copyright (C) 2013\-2014 Lawrence Livermore National Security, LLC.
|
|
|
|
|
|
|
|
.SH LICENSE
|
|
|
|
.PP
|
2014-09-19 22:10:28 +04:00
|
|
|
\fBZED\fR (ZFS Event Daemon) is distributed under the terms of the
|
2014-01-22 01:30:03 +04:00
|
|
|
Common Development and Distribution License (CDDL\-1.0).
|
|
|
|
|
|
|
|
.SH SEE ALSO
|
|
|
|
.BR zfs (8),
|
|
|
|
.BR zpool (8)
|