]> granicus.if.org Git - zfs/commit
Add vdev_id for JBOD-friendly udev aliases
authorNed A. Bass <bass6@zeno1.(none)>
Sat, 21 Apr 2012 00:32:30 +0000 (17:32 -0700)
committerBrian Behlendorf <behlendorf1@llnl.gov>
Fri, 1 Jun 2012 15:55:14 +0000 (08:55 -0700)
commit821b683436423593a1f3ee597f40a61bd4569bdd
treea327afe3250cad9feae0ca1bdab8a16c9171b33d
parente5b85622771090b7529cffdd38c0402a544609ef
Add vdev_id for JBOD-friendly udev aliases

vdev_id parses the file /etc/zfs/vdev_id.conf to map a physical path
in a storage topology to a channel name.  The channel name is combined
with a disk enclosure slot number to create an alias that reflects the
physical location of the drive.  This is particularly helpful when it
comes to tasks like replacing failed drives.  Slot numbers may also be
re-mapped in case the default numbering is unsatisfactory.  The drive
aliases will be created as symbolic links in /dev/disk/by-vdev.

The only currently supported topologies are sas_direct and sas_switch:

o  sas_direct - a channel is uniquely identified by a PCI slot and a
   HBA port

o  sas_switch - a channel is uniquely identified by a SAS switch port

A multipath mode is supported in which dm-mpath devices are handled by
examining the first running component disk, as reported by 'multipath
-l'.  In multipath mode the configuration file should contain a
channel definition with the same name for each path to a given
enclosure.

vdev_id can replace the existing zpool_id script on systems where the
storage topology conforms to sas_direct or sas_switch.  The script
could be extended to support other topologies as well.  The advantage
of vdev_id is that it is driven by a single static input file that can
be shared across multiple nodes having a common storage toplogy.
zpool_id, on the other hand, requires a unique /etc/zfs/zdev.conf per
node and a separate slot-mapping file.  However, zpool_id provides the
flexibility of using any device names that show up in
/dev/disk/by-path, so it may still be needed on some systems.

vdev_id's functionality subsumes that of the sas_switch_id script, and
it is unlikely that anyone is using it, so sas_switch_id is removed.

Finally, /dev/disk/by-vdev is added to the list of directories that
'zpool import' will scan.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #713
28 files changed:
cmd/Makefile.am
cmd/Makefile.in
cmd/sas_switch_id/Makefile.am [deleted file]
cmd/sas_switch_id/sas_switch_id [deleted file]
cmd/vdev_id/Makefile.am [new file with mode: 0644]
cmd/vdev_id/Makefile.in [moved from cmd/sas_switch_id/Makefile.in with 98% similarity]
cmd/vdev_id/vdev_id [new file with mode: 0755]
cmd/zpool/zpool_vdev.c
configure
configure.ac
etc/zfs/Makefile.am
etc/zfs/Makefile.in
etc/zfs/vdev_id.conf.multipath.example [new file with mode: 0644]
etc/zfs/vdev_id.conf.sas_direct.example [new file with mode: 0644]
etc/zfs/vdev_id.conf.sas_switch.example [new file with mode: 0644]
lib/libzfs/libzfs_util.c
man/Makefile.am
man/Makefile.in
man/man5/Makefile.am [new file with mode: 0644]
man/man5/Makefile.in [new file with mode: 0644]
man/man5/vdev_id.conf.5 [new file with mode: 0644]
man/man8/Makefile.am
man/man8/Makefile.in
man/man8/vdev_id.8 [new file with mode: 0644]
udev/rules.d/60-vdev.rules.in [new file with mode: 0644]
udev/rules.d/Makefile.am
udev/rules.d/Makefile.in
zfs.spec.in