freebsd-skq/sbin/geom/class
mjacob 05b92097cb First cut at GEOM based multipath. This is an active/passive{/passive...}
arrangement that has no intrinsic internal knowledge of whether devices
it is given are truly multipath devices. As such, this is a simplistic
approach, but still a useful one.

The basic approach is to (at present- this will change soon) use camcontrol
to find likely identical devices and and label the trailing sector of the
first one. This label contains both a full UUID and a name. The name is
what is presented in /dev/multipath, but the UUID is used as a true
distinguishor at g_taste time, thus making sure we don't have chaos
on a shared SAN where everyone names their data multipath as "Fred".

The first of N identical devices (and N *may* be 1!) becomes the active
path until a BIO request is failed with EIO or ENXIO. When this occurs,
the active disk is ripped away and the next in a list is picked to
(retry and) continue with.

During g_taste events new disks that meet the match criteria for existing
multipath geoms get added to the tail end of the list.

Thus, this active/passive setup actually does work for devices which
go away and come back, as do (now) mpt(4) and isp(4) SAN based disks.

There is still a lot to do to improve this- like about 5 of the 12
recommendations I've received about it,  but it's been functional enough
for a while that it deserves a broader test base.

Reviewed by: pjd
Sponsored by: IronPort Systems
MFC: 2 months
2007-02-27 04:01:58 +00:00
..
cache G_TYPE_NONE was replaced with G_TYPE_BOOL. 2006-11-01 22:28:11 +00:00
concat MFp4: G_TYPE_BOOL sounds much better than G_TYPE_NONE. 2006-09-30 14:40:50 +00:00
eli Correct typo. 2007-02-22 19:25:37 +00:00
journal Forgot to hook up gjournal manual page to the build. 2007-02-10 17:59:46 +00:00
label MFp4: G_TYPE_BOOL sounds much better than G_TYPE_NONE. 2006-09-30 14:40:50 +00:00
mirror Remove duplicate "clear" subcommand. 2006-12-21 18:30:23 +00:00
multipath First cut at GEOM based multipath. This is an active/passive{/passive...} 2007-02-27 04:01:58 +00:00
nop MFp4: G_TYPE_BOOL sounds much better than G_TYPE_NONE. 2006-09-30 14:40:50 +00:00
raid3 Bump .Dd for -f|-F. 2006-11-02 10:44:02 +00:00
shsec MFp4: G_TYPE_BOOL sounds much better than G_TYPE_NONE. 2006-09-30 14:40:50 +00:00
stripe MFp4: G_TYPE_BOOL sounds much better than G_TYPE_NONE. 2006-09-30 14:40:50 +00:00
Makefile First cut at GEOM based multipath. This is an active/passive{/passive...} 2007-02-27 04:01:58 +00:00
Makefile.inc Allow classes to specify local source files. 2005-04-07 15:57:38 +00:00