summaryrefslogtreecommitdiff
path: root/share/man/man4/softraid.4
diff options
context:
space:
mode:
Diffstat (limited to 'share/man/man4/softraid.4')
-rw-r--r--share/man/man4/softraid.439
1 files changed, 25 insertions, 14 deletions
diff --git a/share/man/man4/softraid.4 b/share/man/man4/softraid.4
index 3cf17c7d62a..a5fa4fea5e3 100644
--- a/share/man/man4/softraid.4
+++ b/share/man/man4/softraid.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: softraid.4,v 1.11 2007/06/02 15:33:21 jmc Exp $
+.\" $OpenBSD: softraid.4,v 1.12 2008/01/24 19:33:16 marco Exp $
.\"
.\" Copyright (c) 2007 Todd T. Fries <todd@OpenBSD.org>
.\" Copyright (c) 2007 Marco Peereboom <marco@OpenBSD.org>
@@ -15,7 +15,7 @@
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
.\"
-.Dd $Mdocdate: June 2 2007 $
+.Dd $Mdocdate: January 24 2008 $
.Dt SOFTRAID 4
.Os
.Sh NAME
@@ -27,14 +27,19 @@
.Sh DESCRIPTION
The
.Nm
-device emulates an HBA (host bus adapter) that provides RAID and other IO
+device emulates an HBA (Host Bus Adapter) that provides RAID and other IO
related services.
-The idea is to tie chunks together into an IO discipline.
-A discipline can for example provide a volume that mirrors chunks (RAID 1).
+The
+.Nm
+device provides a scaffold to implement more complex IO transformation
+disciplines.
+For example, one can tie chunks together into a mirroring discipline.
+There really is no limit on what type of discipline one can write as long
+as it fits the SCSI model.
.Pp
Currently
.Nm
-only supports a mirroring discipline.
+supports a mirroring (RAID 1) and a striping (RAID 0) discipline.
.Pp
A
.Em discipline
@@ -58,16 +63,16 @@ An example to create a 3 chunk RAID 1 from scratch is as follows:
.Pp
Initialize the partition tables of all disks:
.Bd -literal -offset indent
-echo y | fdisk -i wd1
-echo y | fdisk -i wd2
-echo y | fdisk -i wd3
+fdisk -iy wd1
+fdisk -iy wd2
+fdisk -iy wd3
.Ed
.Pp
Now create RAID partitions on all disks:
.Bd -literal -offset indent
-echo "d a\ena\en\en\en\enRAID\enw\enq\en" | disklabel -E wd1
-echo "d a\ena\en\en\en\enRAID\enw\enq\en" | disklabel -E wd2
-echo "d a\ena\en\en\en\enRAID\enw\enq\en" | disklabel -E wd3
+echo "a\en\en\en\enRAID\enw\enq\en" | disklabel -E wd1
+echo "a\en\en\en\enRAID\enw\enq\en" | disklabel -E wd2
+echo "a\en\en\en\enRAID\enw\enq\en" | disklabel -E wd3
.Ed
.Pp
Assemble the RAID volume:
@@ -90,8 +95,8 @@ dd if=/dev/zero of=/dev/rsd0c bs=1m count=1
Initialize the partition table and create a filesystem on the
new RAID volume:
.Bd -literal -offset indent
-echo y | fdisk -i sd0
-echo "d a\ena\en\en\en\en4.2BSD\enw\enq\en" | disklabel -E sd0
+fdisk -iy sd0
+echo "a\en\en\en\en4.2BSD\enw\enq\en" | disklabel -E sd0
newfs /dev/rsd0a
.Ed
.Pp
@@ -131,6 +136,12 @@ Currently the RAID 1 support does not have the ability to recover a
failed chunk.
.Pp
The RAID 1 discipline does not initialize the mirror upon creation.
+This is by design because all sectors that are read are written first.
+There is no point in wasting a lot of time syncing random data.
+.Pp
+Currently there is no automated mechanism to recover from failed disks.
+.Pp
+There is no boot support at this time for any disciplines.
.Pp
Certain RAID levels can protect against some data loss
due to component failure.