metattach (1M)
Table of Contents

NAME

metattach, metadetach - attach or detach metadevice to or from a mirror or trans

SYNOPSIS

metattach [ -h ]
metattach [ -s setname ] mirror [ metadevice ]
metattach [ -s setname ] [ -i size ] concat/stripe component...
metattach [ -s setname ] RAID component...
metattach [ -s setname ] trans log
metadetach [ -s setname ] [ -f ] mirror submirror
metadetach [ -s setname ] [ -f ] trans

AVAILABILITY

/usr/opt/SUNWmd/sbin

DESCRIPTION

metattach is used to add submirrors to a mirror, add logging devices to trans devices, or grow metadevices. Growing metadevices can be done without interrupting service. To grow the size of a mirror or trans, the slices must be added to the submirrors or to the master devices.

DiskSuite supports one-to-three-way mirrors. Thus, you can only attach a metadevice to a mirror if there are two or fewer submirrors beneath the mirror. Once a new metadevice is attached to a mirror, metattach will automatically start a resync operation to the new submirror.

Attaching a new logging device to a busy trans metadevice is allowed, although a trans metadevice will start using its new logging device only after the trans is idle (after it is unmounted, for example). The busy trans will be in an Attaching state (metastat) until the logging device is actually attached. Attaching a logging device in the Hard Error or Error state (metastat) is not allowed.

metadetach is used to detach submirrors from mirrors, or detach logging devices from trans metadevices.

When a submirror is detached from a mirror, it is no longer part of the mirror, thus reads and writes to and from that metadevice via the mirror are no longer performed through the mirror. Detaching the only existing submirror is not allowed. Detaching a submirror that has slices reported as needing maintenance (by metastat) is not allowed unless the -f (force) flag is used.

metadetach also detaches the logging device from a trans. Once detached, the logging device is no longer part of the trans, thus the trans is no longer logging and all benefits of logging are lost. Any information on the logging device that pertains to the master device is written to the master device before the logging device is detached.

Detaching the logging device from a busy trans device is not allowed unless the -f (force) flag is used. Even so, the logging device is not actually detached until the trans is idle. The trans is in the Detaching state (metastat) until the logging device is detached.

OPTIONS

Root privileges are required for all of the following options except -h.

-f
Force the detaching of metadevices that have components that need maintenance or are busy.

-h
Displays a usage message.

-i size
Specifies the interlace value for stripes, where size is a specified value followed by either `k' for kilobytes, `m' for megabytes, or `b' for blocks. The units can be either upper case or lower case. If size is not specified, the size defaults to the interlace size of the last stripe of the metadevice. When an interlace size change is made on a stripe, it will be carried forward on all stripes that follow.

-s setname
Specifies the name of the diskset on which the metattach command or the metadetach command will work. Using the -s option will cause the command to perform its administrative function within the specified diskset. Without this option, the command will perform its function on local metadevices.

mirror
Specifies the mirror.

metadevice
Specifies the name of the metadevice to be attached to the mirror as a submirror. This metadevice must have been previously created by the metainit command.

concat/stripe
Specifies the metadevice name of the concatenation, stripe, or concatenation of stripes.

component...
The logical name for the physical slice (partition) on a disk drive, such as /dev/dsk/c0t0d0s2, being added to the concatenation, stripe, concatenation of stripes, or RAID5 metadevice.

RAID
Specifies the metadevice name of the RAID5 metadevice.

trans
Specifies the metadevice name of the trans metadevice (not the master or logging device).

log
Specifies the metadevice name of the logging device to be attached to the trans metadevice.

submirror
The metadevice name of the submirror to be detached from the mirror.

EXAMPLES

This example concatenates a single new slice to an existing metadevice, d8. (Afterwards, you would use the growfs command to expand the file system.)

# metattach d8 /dev/dsk/c0t1d0s2

This example adds four slices to an existing metadevice, d9. (Afterwards, you would use the growfs command to expand the file system.)

# metattach d9 /dev/dsk/c0t1d0s2 /dev/dsk/c0t2d0s2 \ /dev/dsk/c0t3d0s2 /dev/dsk/c0t4d0s2

This example detaches the logging device from a trans metadevice d9. Notice that you do not have to specify the logging device itself, as there can only be one.

# metadetach d9

This example expands a RAID5 metadevice, d45, by attaching another slice.

# metattach d45 /dev/dsk/c3t0d0s2

When you add additional slices to a RAID5 metadevice, the additional space is devoted to data. No new parity blocks are allocated. The data on the added slices is, however, included in the overall parity calculations, so it is protected against single device failure.

This example adds space to a two-way mirror by adding a slice to each submirror. (Afterwards, you would use the growfs command to expand the file system.)

# metattach d9 /dev/dsk/c0t2d0s5
# metattach d10 /dev/dsk/c0t3d0s5

This example detaches a submirror, d2, from a mirror, d4.

# metadetach d4 d2

SEE ALSO

metaclear(1M), metadb(1M), metadetach(1M), metahs(1M), metainit(1M), metaoffline(1M), metaonline(1M), metaparam(1M), metareplace(1M), metaroot(1M), metaset(1M), metastat(1M), metasync(1M), md.tab(4), md.cf(4), mddb.cf(4)

Solstice DiskSuite User's Guide, Solstice DiskSuite Reference

WARNING

When a submirror is detached from its mirror, the data on the metadevice may not be the same as the data that existed on the mirror prior to running metadetach. In particular, if the -f option was needed, the metadevice and mirror probably do not contain the same data.