]> git.proxmox.com Git - mirror_zfs.git/commit
Add automatic hot spare functionality
authorBrian Behlendorf <behlendorf1@llnl.gov>
Fri, 24 Jan 2014 23:47:46 +0000 (15:47 -0800)
committerBrian Behlendorf <behlendorf1@llnl.gov>
Wed, 2 Apr 2014 20:10:08 +0000 (13:10 -0700)
commit904ea2763e6576f6971be4a684e6765aaea5221c
tree5ce537bd1bec2b7cbaa3c9fb2dfa3c5c86722f8d
parentd21705eab952e5aa1c0bcf920b76e8428384d80b
Add automatic hot spare functionality

When a vdev starts getting I/O or checksum errors it is now
possible to automatically rebuild to a hot spare device.

To cleanly support this functionality in a shell script some
additional information was added to all zevent ereports which
include a vdev.  This covers both io and checksum zevents but
may be used but other scripts.

In the Illumos FMA solution the same information is required
but it is retrieved through the libzfs library interface.
Specifically the following members were added:

  vdev_spare_paths  - List of vdev paths for all hot spares.
  vdev_spare_guids  - List of vdev guids for all hot spares.
  vdev_read_errors  - Read errors for the problematic vdev
  vdev_write_errors - Write errors for the problematic vdev
  vdev_cksum_errors - Checksum errors for the problematic vdev.

By default the required hot spare scripts are installed but this
functionality is disabled.  To enable hot sparing uncomment the
ZED_SPARE_ON_IO_ERRORS and ZED_SPARE_ON_CHECKSUM_ERRORS in the
/etc/zfs/zed.d/zed.rc configuration file.

These scripts do no add support for the autoexpand property. At
a minimum this requires adding a new udev rule to detect when
a new device is added to the system.  It also requires that the
autoexpand policy be ported from Illumos, see:

  https://github.com/illumos/illumos-gate/blob/master/usr/src/cmd/syseventd/modules/zfs_mod/zfs_mod.c

Support for detecting the correct name of a vdev when it's not
a whole disk was added by Turbo Fredriksson.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Chris Dunlap <cdunlap@llnl.gov>
Signed-off-by: Turbo Fredriksson <turbo@bayour.com>
Issue #2
cmd/zed/Makefile.am
cmd/zed/zed.d/checksum-spare.sh [new symlink]
cmd/zed/zed.d/io-spare.sh [new file with mode: 0755]
cmd/zed/zed.d/zed.rc
include/sys/fm/fs/zfs.h
module/zfs/spa.c
module/zfs/zfs_fm.c