net user administrator /active:yes▼robocopyでコピー (administrator)
robocopy "H:\users\griffon" "D:\users\griffon" /MIR /UNILOG:D:\RoboCopy.log /R:0 /W:0 /TEE /XJD /XJF /FFT /COPY:DATSO /SECFIX※コピー先にはコピー元と同じディレクトリを指定しないとコピー元の中身をぶちまけられるので注意。
net user administrator /active:no★現在の課題
一旦ドライブ文字を削除→再起動→ドライブ文字を付与→再起動で復活することはない。
現在 2TB 未満のディスクを使って gmirror を構築しているが、ディスク障害によるディスク交換で将来的に 2TB を超える HDD にアップグレードを考えているため、ミラーの方肺を 2TB 以上の HDD に置き換え、その後両方とも 2TB を超える HDD に揃える。といった状況の下で説明とする。
% gpart show ada2 ada2s1 ada3 => 63 10485697 ada2 MBR (5.0G) 63 10485657 1 freebsd [active] (5.0G) 10485720 40 - free - (20K) => 0 10485657 ada2s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 4 freebsd-ufs (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % gpart show -lp ada2 ada2s1 ada3 => 63 10485697 ada2 MBR (5.0G) 63 10485657 ada2s1 (null) [active] (5.0G) 10485720 40 - free - (20K) => 0 10485657 ada2s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 ada2s1d (null) (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 ada3p1 (null) (8.0G) % sudo gmirror label -v mirror0 ada2s1d Metadata value stored on ada2s1d. Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2s1d (ACTIVE) % gmirror insert -v mirror0 ada3p1 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2s1d (ACTIVE) ada3p1 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 3646045765 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368647680 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada2s1d Mediasize: 5368648192 (5.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 40448 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 2017605693 2. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3326642448 % sudo mount /dev/mirror/mirror0 /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0 5061568 28072 4628572 1% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 07:40 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 07:40 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 07:40 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 07:40 mikofuku_dd-dy_manual.pdf* % sudo umount /mnt更にこの後に MBR パーティションを持った小さなドライブから GPT パーティションを持った大きなドライブに入れ替える場合は、MBR の小さなドライブを remove してから GPT の大きなドライブを insert して growfs で広げる。
% sudo gmirror label -v mirror0 ada2
Metadata value stored on ada2. Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE) % gmirror insert -v mirror0 ada3p1 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE) ada3p1 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 1111266501 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada2 Mediasize: 5368709120 (5.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3283235968 2. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 2283151022 % gmirror destroy mirror0 % % ll /dev/ada3* crw-r----- 1 root operator - 0x60 10月 9 06:16 /dev/ada3 crw-r----- 1 root operator - 0x67 10月 9 06:38 /dev/ada3p1 crw-r----- 1 root operator - 0x76 10月 9 07:43 /dev/ada3p1s1 crw-r----- 1 root operator - 0x88 10月 9 07:43 /dev/ada3p1s1d
% gpart destroy -F ada3 ada3 destroyed % ll /dev/ada3* crw-r----- 1 root operator - 0x60 10月 9 06:16 /dev/ada3
% gpart show ada2 ada2s1 ada3 => 63 10485697 ada2 MBR (5.0G) 63 10485657 1 freebsd [active] (5.0G) 10485720 40 - free - (20K) => 0 10485657 ada2s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 4 freebsd-ufs (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % gpart show -lp ada2 ada2s1 ada3 => 63 10485697 ada2 MBR (5.0G) 63 10485657 ada2s1 (null) [active] (5.0G) 10485720 40 - free - (20K) => 0 10485657 ada2s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 ada2s1d (null) (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 ada3p1 (null) (8.0G) % sudo mount -v /dev/ada2s1d /mnt /dev/ada2s1d on /mnt (ufs, local, writes: sync 2 async 0, reads: sync 3 async 0, fsid a1f99c5d0a3d3046) % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada2s1d 5061568 28072 4628572 1% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 06:04 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 06:03 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 06:04 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 06:04 mikofuku_dd-dy_manual.pdf* % sudo umount -v /mnt /dev/ada2s1d: unmount from /mnt % sudo dd if=/dev/ada2s1d of=/dev/ada3p1 bs=2M 2559+1 records in 2559+1 records out 5368648192 bytes transferred in 2.444914 secs (2195842973 bytes/sec) % gpart show ada2 ada2s1 ada3 => 63 10485697 ada2 MBR (5.0G) 63 10485657 1 freebsd [active] (5.0G) 10485720 40 - free - (20K) => 0 10485657 ada2s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 4 freebsd-ufs (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % sudo mount -v /dev/ada3p1 /mnt /dev/ada3p1 on /mnt (ufs, local, writes: sync 2 async 0, reads: sync 3 async 0, fsid a1f99c5d0a3d3046) % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada3p1 5061568 28072 4628572 1% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 06:04 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 06:03 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 06:04 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 06:04 mikofuku_dd-dy_manual.pdf* % sudo umount -v /mnt /dev/ada3p1: unmount from /mnt5GB の MBR パーティションを 8GB の GPT パーティションにコピーしたら 5GB になっちゃったので広げましょう。
% gpart show ada3 => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % sudo growfs -N /dev/ada3p1 super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640 % sudo growfs /dev/ada3p1 It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/ada3p1 from 5.0GB to 8.0GB? [yes/no] yes super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640 % sudo mount -v /dev/ada3p1 /mnt /dev/ada3p1 on /mnt (ufs, local, writes: sync 2 async 0, reads: sync 3 async 0, fsid a1f99c5d0a3d3046) % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada3p1 8106676 28072 7430072 0% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 06:04 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 06:03 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 06:04 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 06:04 mikofuku_dd-dy_manual.pdf* % sudo umount -v /mnt /dev/ada3p1: unmount from /mnt
% gpart show -lp ada2 ada3 => 40 10485680 ada2 GPT (5.0G) 40 10485680 ada2p1 (null) (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 16777136 ada3p1 (null) (8.0G) % sudo gmirror label -v mirror0 ada2p1 Metadata value stored on ada2p1. Done. % gmirror insert -v mirror0 ada3p1 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2p1 (ACTIVE) ada3p1 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 315191848 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368667648 (5.0G) ←★小さい方に合わせられる Sectorsize: 512 Mode: r1w1e1 Consumers: 1. Name: ada2p1 Mediasize: 5368668160 (5.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 2366964925 2. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 1280267142 % sudo mount /dev/mirror/mirror0 /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0 5061588 28072 4628592 1% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 04:32 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 04:31 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 04:32 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 04:32 mikofuku_dd-dy_manual.pdf*今度は小さいドライブ (ada2) を外して大きなドライブ (ada4) に交換する。
% gmirror remove -v mirror0 ada2p1 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada3p1 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 1 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 1795428709 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368667648 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 1783526678 % gpart show ada4 => 40 16777136 ada4 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % gpart show -lp ada4 => 40 16777136 ada4 GPT (8.0G) 40 16777136 ada4p1 (null) (8.0G) % gmirror insert -v mirror0 ada4p1 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada3p1 (ACTIVE) ada4p1 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 1795428709 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368667648 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 1783526678 2. Name: ada4p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 2699217139 % sudo mount /dev/mirror/mirror0 /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0 5061588 28072 4628592 1% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 06:39 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 06:39 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 06:39 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 06:39 mikofuku_dd-dy_manual.pdf* % sudo umount /mnt % gmirror resize mirror0 % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 1795428709 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 8589893120 (8.0G)増えました。:)
Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada3p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 1783526678 2. Name: ada4p1 Mediasize: 8589893632 (8.0G) Sectorsize: 512 Stripesize: 0 Stripeoffset: 20480 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 2699217139 % growfs -N /dev/mirror/mirror0 super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640 % sudo growfs /dev/mirror/mirror0 It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/mirror/mirror0 from 5.0GB to 8.0GB? [yes/no] yes super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640 % sudo mount /dev/mirror/mirror0 /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0 8106672 28072 7430068 0% /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 06:39 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 06:39 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 06:39 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 06:39 mikofuku_dd-dy_manual.pdf*
% gpart show -lp ada2 ada3 => 40 10485680 ada2 GPT (5.0G) 40 10485680 ada2p1 (null) (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 10485680 ada3p1 (null) (5.0G) 10485720 6291456 - free - (3.0G) % sudo mount /dev/ada2p1 /mnt % ll /mnt total 28076 drwxrwxrwx 3 root wheel - 512 10月 9 04:32 ./ drwxr-xr-x 23 root wheel - 512 10月 8 23:22 ../ drwxrwxr-x 2 root operator - 512 10月 9 04:31 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 9 04:32 kabe-gami.zip* -rwxr--r-- 1 griffon wheel - 6183181 10月 9 04:32 mikofuku_dd-dy_manual.pdf* % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada2p1 5061588 28072 4628592 1% /mnt % sudo umount /mnt % sudo gmirror label -v mirror0 ada2 Metadata value stored on ada2. Done. % gmirror insert -v mirror0 ada3 Done. % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE) ada3 (ACTIVE) % ll /dev/mirror/mirror0* crw-r----- 1 root operator - 0x6b 10月 9 04:34 /dev/mirror/mirror0 % sudo mount /dev/mirror/mirror0 /mnt mount: /dev/mirror/mirror0: Invalid argument % gmirror list Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NONE GenID: 0 SyncID: 1 ID: 1623628032 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada2 Mediasize: 5368709120 (5.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 26546643 2. Name: ada3 Mediasize: 8589934592 (8.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 66523288なんでマウントできない?と思ったら dmesg にこんなエラーが。
GEOM_MIRROR: Device mirror/mirror0 launched (1/1).とりあえず gmirror destroy してから recover しておきましょう。
GEOM: mirror/mirror0: corrupt or invalid GPT detected.
GEOM: mirror/mirror0: GPT rejected -- may not be recoverable.
GEOM_MIRROR: Device mirror0: provider destroyed.
GEOM_MIRROR: Device mirror0 destroyed.
GEOM: ada2: the secondary GPT table is corrupt or invalid.
GEOM: ada2: using the primary only -- recovery suggested.
GEOM: diskid/DISK-01000000000000000001: the secondary GPT table is corrupt or invalid.
GEOM: diskid/DISK-01000000000000000001: using the primary only -- recovery suggested.
% gmirror destroy -v mirror0 Done. % gpart show ada2 => 40 10485680 ada2 GPT (5.0G) [CORRUPT]つまりこれか。
40 10485680 - free - (5.0G) % gpart recover ada2 ada2 recovered % gpart show ada2 => 40 10485680 ada2 GPT (5.0G) ←★CORRUPTがなくなった 40 10485680 - free - (5.0G)
> gmirror(8) stores one block of metadata at the end of the disk. Because GPT partition schemes also store metadata at the end of the disk, mirroring entire GPT disks with gmirror(8) is not recommended. MBR partitioning is used here because it only stores a partition table at the start of the disk and does not conflict with the mirror metadata.つまりは GPT ディスクにパーティション切ってそれをミラーすればいいというわけで。
(和訳) gmirror(8) は、ディスクの最後に 1ブロックのメタデータを保存します。GPT パーティションスキームはディスクの最後にメタデータも保存するため、 gmirror(8) で GPT ディスク全体をミラーリングすることはお勧めしません。MBR パーティショニングは、ディスクの先頭にのみパーティションテーブルを格納し、ミラーメタデータと競合しないため、ディスク全体を使用することが出来ます。
% gpart show -lp ada2 ada3 => 40 10485680 ada2 GPT (5.0G) 40 10485680 ada2p1 freebsd-ufs (5.0G) => 40 16777136 ada3 GPT (8.0G) 40 8388608 ada3p1 freebsd-ufs (4.0G) 8388648 8388528 - free - (4.0G) % sudo gmirror label -v mirror0 ada2p1 Metadata value stored on ada2p1. Done. % gmirror insert -v mirror0 ada3p1 gmirror: Provider ada3p1 too small.どうしてもパーティションサイズを同じにしてミラーしたいということであれば gpart backup [geom] | gpart restore [geom] してもいいが、ここで疑問なのは「ちょっとでも小さい方に restore したらどうなる?」だが、ちゃんと蹴られます。
% fdisk ada2 (省略) start 63, size 10485657 (5119 Meg), flag 80 (active) (省略) % gpart show ada3 => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) % gpart backup ada3 | gpart restore ada2 gpart: size '16777136': Invalid argumentgpart backup [geom] | gpart restore [geom] は、こう。
% gpart destroy -F ada4 ada4 destroyed % gpart backup ada3 | gpart restore ada4 % gpart show ada3 ada4 => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) => 40 16777136 ada4 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G)gpart backup | gpart destore はパーティション情報が残ってるとエラーになるので必ず gpart destroy でメタデータを削除してからにしましょう。
% gpart backup ada3 | gpart restore ada4 gpart: geom 'ada4': File exists % gpart destroy ada4 gpart: Device busy % gpart destroy -F ada4 ada4 destroyed % gpart backup ada3 | gpart restore ada4 % gpart show ada3 ada4 => 40 16777136 ada3 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G) => 40 16777136 ada4 GPT (8.0G) 40 16777136 1 freebsd-ufs (8.0G)
% fdisk ada2 (省略) start 63, size 10485657 (5119 Meg), flag 80 (active) (省略) % fdisk ada3 (省略) start 63, size 16776522 (8191 Meg), flag 80 (active) (省略)ちゃんとサイズは違ってます。
% sudo mount /dev/ada2s1d /mnt % ll /mnt total 21996 drwxrwxrwx 3 root wheel - 512 10月 6 02:13 ./ drwxr-xr-x 23 root wheel - 512 10月 6 02:34 ../ drwxrwxr-x 2 root operator - 512 10月 6 02:12 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 6 02:13 kabe-gami.zip* % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada2s1d 5061568 21992 4634652 0% /mntアンマウントしておく。
% sudo umount /mntRAID-1 メンバーの作成。
% sudo gmirror label -v -F mirror0 ada2 Metadata value stored on ada2. Done.念のためパーティションが存在するかを確認する。
% ll /dev/mirror/mirror0* crw-r----- 1 root operator - 0x68 10月 6 02:39 /dev/mirror/mirror0 crw-r----- 1 root operator - 0x69 10月 6 02:39 /dev/mirror/mirror0s1 crw-r----- 1 root operator - 0x6b 10月 6 02:39 /dev/mirror/mirror0s1d中身が無事かを確認する。
% sudo mount /dev/mirror/mirror0s1d /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0s1d 5061568 21992 4634652 0% /mnt % ll /mnt total 21996 drwxrwxrwx 3 root wheel - 512 10月 6 02:13 ./ drwxr-xr-x 23 root wheel - 512 10月 6 02:34 ../ drwxrwxr-x 2 root operator - 512 10月 6 02:12 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 6 02:13 kabe-gami.zip*この次に空のディスクをアタッチする。
% sudo gmirror insert -v mirror0 ada3 Done. % gmirror status Name Status Components mirror/mirror0 DEGRADED ada2 (ACTIVE) ada3 (SYNCHRONIZING, 55%) % gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE) ada3 (ACTIVE)中身が無事かを確認する。
% df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0s1d 5061568 21992 4634652 0% /mnt % ll /mnt total 21996 drwxrwxrwx 3 root wheel - 512 10月 6 02:13 ./ drwxr-xr-x 23 root wheel - 512 10月 6 02:34 ../ drwxrwxr-x 2 root operator - 512 10月 6 02:12 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 6 02:13 kabe-gami.zip*gmirror はディスクサイズが異なる物をペアにした場合、一番小さい物に合わせられる。
% gmirror list Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NOFAILSYNC GenID: 0 SyncID: 1 ID: 414357605 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) ←★RAID-1 メンバーのサイズ Sectorsize: 512 Mode: r1w1e3 Consumers: 1. Name: ada2 Mediasize: 5368709120 (5.0G) ←★ディスクのサイズ Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3914746213 2. Name: ada3 Mediasize: 8589934592 (8.0G) ←★ディスクのサイズ Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 320096764ディスクサイズが異なっているが RAID-1 メンバーのサイズは一番小さい物に合わせられていることが確認出来る。
% gmirror list Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NOFAILSYNC GenID: 0 SyncID: 1 ID: 307285312 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada2 Mediasize: 5368709120 (5.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 317673527 2. Name: ada3 Mediasize: 8589934592 (8.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3541304040 % sudo gmirror remove mirror0 ada2 ←★サイズの小さいディスクを remove する。 % gmirror status Name Status Components mirror/mirror0 COMPLETE ada3 (ACTIVE) ※ada2 (サイズの小さいディスク) が外れました。 % gmirror list Geom name: mirror0 State: COMPLETE Components: 1 Balance: load Slice: 4096 Flags: NOFAILSYNC GenID: 0 SyncID: 1 ID: 307285312 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada3 Mediasize: 8589934592 (8.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3541304040大きいサイズのディスクのみ残っていることを確認しておく。
% fdisk /dev/ada4 (省略) start 63, size 16776522 (8191 Meg), flag 80 (active) (省略)こいつを RAID-1 メンバーにぶっこむ。
% sudo gmirror insert -v mirror0 ada4 Done. % gmirror status Name Status Components mirror/mirror0 DEGRADED ada3 (ACTIVE) ada4 (SYNCHRONIZING, 70%) % gmirror status Name Status Components mirror/mirror0 COMPLETE ada3 (ACTIVE) ada4 (ACTIVE) % gmirror list mirror0 Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NOFAILSYNC GenID: 0 SyncID: 1 ID: 1256414995 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 5368708608 (5.0G) ←★RAID-1 メンバーのサイズ Sectorsize: 512 Mode: r0w0e0 Consumers: 1. Name: ada3 Mediasize: 8589934592 (8.0G) ←★ディスクのサイズ Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 968255354 2. Name: ada4 Mediasize: 8589934592 (8.0G) ←★ディスクのサイズ Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3468845043この時点では過去の小さいサイズをひきずったままとなっている。
% sudo gmirror resize -v mirror0 Done. % gmirror list Geom name: mirror0 State: COMPLETE Components: 2 Balance: load Slice: 4096 Flags: NOFAILSYNC GenID: 0 SyncID: 1 ID: 2218697283 Type: AUTOMATIC Providers: 1. Name: mirror/mirror0 Mediasize: 8589934080 (8.0G) ←★RAID-1 メンバーのサイズが変わった Sectorsize: 512 Mode: r1w1e1 Consumers: 1. Name: ada3 Mediasize: 8589934592 (8.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3801782773 2. Name: ada4 Mediasize: 8589934592 (8.0G) Sectorsize: 512 Mode: r1w1e1 State: ACTIVE Priority: 0 Flags: NONE GenID: 0 SyncID: 1 ID: 3565686053広がりました。:)
% sudo mount /dev/mirror/mirror0s1d /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0s1d 5061568 21992 4634652 0% /mnt↑ほらね。
% gpart show -lp /dev/mirror/mirror0 => 63 16777152 mirror/mirror0 MBR (8.0G) 63 10485657 mirror/mirror0s1 freebsd-ufs [active] (5.0G) 10485720 6291495 - free - (3.0G) % gpart show -lp /dev/mirror/mirror0s1 => 0 10485657 mirror/mirror0s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 mirror/mirror0s1d freebsd-ufs (5.0G) % gpart show /dev/mirror/mirror0 => 63 16777152 mirror/mirror0 MBR (8.0G) 63 10485657 1 freebsd [active] (5.0G) 10485720 6291495 - free - (3.0G) % gpart show /dev/mirror/mirror0s1 => 0 10485657 mirror/mirror0s1 BSD (5.0G) 0 16 - free - (8.0K) 16 10485641 4 freebsd-ufs (5.0G)広げていきます。
% sudo gpart resize -i 1 /dev/mirror/mirror0 mirror/mirror0s1 resized % gpart show /dev/mirror/mirror0 => 63 16777152 mirror/mirror0 MBR (8.0G) 63 16777152 1 freebsd [active] (8.0G)次にパーティション。
% sudo gpart resize -i 4 /dev/mirror/mirror0s1 mirror/mirror0s1d resized % gpart show /dev/mirror/mirror0s1 => 0 16777152 mirror/mirror0s1 BSD (8.0G) 0 16 - free - (8.0K) 16 16777136 4 freebsd-ufs (8.0G)growfs で広げた部分を使えるようにしよう。
% sudo growfs -N /dev/mirror/mirror0s1d super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640本番。
% sudo growfs /dev/mirror/mirror0s1d It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/mirror/mirror0s1d from 5.0GB to 8.0GB? [yes/no] yes super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640マウントしてみる。
% sudo mount /dev/mirror/mirror0s1d /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/mirror/mirror0s1d 8106676 21992 7436152 0% /mnt % ll /mnt total 21996 drwxrwxrwx 3 root wheel - 512 10月 6 03:34 ./ drwxr-xr-x 23 root wheel - 512 10月 6 03:55 ../ drwxrwxr-x 2 root operator - 512 10月 6 03:33 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 6 03:34 kabe-gami.zip*拡張終わり!!
% gpart show -lp ada3 => 63 16777153 ada3 MBR (8.0G) 63 10485657 ada3s1 freebsd-ufs [active] (5.0G) 10485720 6291496 - free - (3.0G) ←★余ってる! % gpart show -lp ada3s1 => 0 10485657 ada3s1 BSD (5.0G) ←★余ってる! 0 16 - free - (8.0K) 16 10485641 ada3s1d freebsd-ufs (5.0G) ←★余ってる!gpart show の -lp はスライス・パーティションをインデックス番号ではなくデバイスノード名 (ada3s1d とか) で表示する。
% gpart show -l ada3 => 63 16777153 ada3 MBR (8.0G) 63 10485657 1 freebsd-ufs [active] (5.0G) 10485720 6291496 - free - (3.0G)gpart resize でサイズを大きくするが、対象の選択はインデックス番号を使用する。
% sudo gpart resize -i 1 ada3 ada3s1 resized % gpart show -l ada3 => 63 16777153 ada3 MBR (8.0G) 63 16777153 1 (null) [active] (8.0G)大きくなりました :)
% gpart show -l ada3s1 => 0 16777153 ada3s1 BSD (8.0G) 0 16 - free - (8.0K) 16 10485641 4 freebsd-ufs (5.0G) 10485657 6291496 - free - (3.0G)今度は "freebsd-ufs (5.0G)" の前にある "4" なので、-i 4 で指定する。
% sudo gpart resize -i 4 ada3s1 ada3s1d resized % gpart show -l ada3s1 => 0 16777153 ada3s1 BSD (8.0G) 0 16 - free - (8.0K) 16 16777137 4 freebsd-ufs (8.0G)大きくなりました :)
% sudo mount /dev/ada3s1d /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada3s1d 5061568 21992 4634652 0% /mnt増やした分は growfs で実際に使えるようにしなければならない。
% sudo growfs -N /dev/ada3s1d super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640ここで
growfs: requested size **GB is not larger than the current filesystem size **GBとか出たら増やせないので諦めましょう。
% sudo growfs /dev/ada3s1d It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/ada3s1d from 5.0GB to 8.0GB? [yes/no]「ファイルシステムを拡張する前にバックアップは取れよ!
% sudo growfs /dev/ada3s1d It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/ada3s1d from 5.0GB to 8.0GB? [yes/no] yes super-block backups (for fsck_ffs -b #) at: 11542656, 12825152, 14107648, 15390144, 16672640すると増やした部分のみ newfs される。
% sudo mount /dev/ada3s1d /mnt % df /mnt Filesystem 1K-blocks Used Avail Capacity Mounted on /dev/ada3s1d 8106676 21992 7436152 0% /mnt % ll /mnt total 21996 drwxrwxrwx 3 root wheel - 512 10月 6 02:13 ./ drwxr-xr-x 23 root wheel - 512 10月 6 02:34 ../ drwxrwxr-x 2 root operator - 512 10月 6 02:12 .snap/ -rwxr--r-- 1 griffon wheel - 22475540 10月 6 02:13 kabe-gami.zip*
% gmirror status Name Status Components mirror/mirror0 COMPLETE ada1 (ACTIVE) ada2 (ACTIVE)mirror0 からディスクを外す。
% sudo gmirror remove mirror0 ada1 % sudo gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE) ※ada1 が消えた。 % sudo gmirror dump ada1 Can't read metadata from ada1: Invalid argument. gmirror: Not fully done. ※ada1 に gmirror のメタデータが残っていないことを確認。この状態では ada1 のディスクは ada2 と同期が取れているため、ぶっちゃけバックアップドライブとして保管しておいても良い。
% sudo gmirror insert -v mirror0 ada1 Done. sudo gmirror status Name Status Components mirror/mirror0 DEGRADED ada2 (ACTIVE) ada1 (STALE)追加した ada1 が STALE になっているので、ACTIVE な ada2 からデータを貰うことにする。
% sudo gmirror rebuild -v mirror0 ada1 Done. % gmirror status Name Status Components mirror/mirror0 DEGRADED ada2 (ACTIVE) ada1 (SYNCHRONIZING, 0%)ここで注意する点は、指定するディスクを間違えないこと。
gmirror: Not all disks connected.というエラーが出た場合は、落ち着いて forget を使用しよう。
% sudo gmirror forget -v mirror0 Done. % sudo gmirror status Name Status Components mirror/mirror0 COMPLETE ada2 (ACTIVE)これで新しいディスクを追加できるようになる。
% sudo gmirror label -v mirror0 ada4p1
# sudo gmirror clear ada2とかすればメタデータを消去できるのだが今回はダメ。
# gmirror label -v mirror0 ada1としても「mirror0 は既に使われてるで」とエラーが出て他の名前でしか組めない。
# gmirror dump ada1としてみると、どうも過去に gmirror で組んだ RAID-1 のメタデータが残ったままになっている。
# gmirror load -vでモジュールをロードして
# gmirror label -v mirror0 ada1したら無事に RAID-1 を組む準備が出来た。
# gmirror insert -v mirror0 ada2でディスクを追加したら勝手にリビルドが始まるのでそのまま放置。
# gmirror configure -F -v mirror0で勝手にリビルドするのを止める。
gmirror dump ada1 Metadata on ada1: magic: GEOM::MIRROR version: 4 name: mirror0 mid: 239193923 did: 779873358 all: 2 genid: 0 syncid: 1 priority: 0 slice: 4096 balance: load mediasize: 500107861504 sectorsize: 512 syncoffset: 0 mflags: NOFAILSYNC dflags: NONE hcprovider: provsize: 1000204886016 MD5 hash: 6ebcb89bc3fd056f5feda8878f2707acで確認出来る。
# gmirror configure -n -v mirror0 # gmirror dump ada1 (省略) syncoffset: 0 mflags: NOAUTOSYNC dflags: NONE
gpart → bsdlabel → growfs
% gpart recover ada2 ★おまじない ada2 recovering is not needed % gpart show ada2 => 63 1953525105 ada2 MBR (932G) 63 976768002 1 freebsd [active] (466G) 976768065 976757103 - free - (466G) ★余ってる領域 % sudo gpart resize -i 1 -s 1000GB ada2 gpart: size '2097152000': Invalid argument ★大きかった % sudo gpart resize -i 1 -s 932GB ada2 gpart: size '1954545664': Invalid argument ★大きかった % sudo gpart resize -i 1 -s 930GB ada2 ada2s1 resized ★取れた。 % gpart show ada2 => 63 1953525105 ada2 MBR (932G) 63 1950351360 1 freebsd [active] (930G) 1950351423 3173745 - free - (1.5G) ★ちょっと余った % sudo gpart resize -i 1 -s 931GB ada2 ada2s1 resized % gpart show ada2 => 63 1953525105 ada2 MBR (932G) 63 1952448512 1 freebsd [active] (931G) 1952448575 1076593 - free - (526M) ★惜しい % sudo gpart resize -i 1 -s 932GB ada2 gpart: size '1954545664': Invalid argument ★残りが取れない % sudo gpart resize -i 1 -s 1953525105 ada2 ★ada2のブロック数全部を指定 ada2s1 resized ★取れた! % gpart show ada2 => 63 1953525105 ada2 MBR (932G) 63 1953525105 1 freebsd [active] (932G)教訓。サイズ (-s) はバイトサイズではなくブロックサイズで指定しよう。
% sysctl kern.geom.debugflags kern.geom.debugflags: 0 % sudo sysctl kern.geom.debugflags=16 kern.geom.debugflags: 0 -> 16bsdlabel で広げる。
% sudo bsdlabel -e /dev/ada2s1 # /dev/ada2s1: 8 partitions: # size offset fstype [fsize bsize bps/cpg] c: 1953525105 0 unused 0 0 # "raw" part, don't edit d: 1953525105 0 4.2BSD 0 0 0 ★先頭からきっちり使っているのでサイズは同じ数字にする。今回は gmirror によって先頭 16ブロックを無視して完全にゼロから使いはじめていたので c: と d: の値は同じになった。
% sudo sysctl kern.geom.debugflags=0 kern.geom.debugflags: 16 -> 0最後に growfs。
% sudo growfs /dev/ada2s1d It's strongly recommended to make a backup before growing the file system. OK to grow filesystem on /dev/ada2s1d from 466GB to 932GB? [yes/no] yes super-block backups (for fsck_ffs -b #) at: 977009952, 977386304, 977762656, 978139008, 978515360, 978891712, 979268064, 979644416, 980020768, 980397120, 980773472, (省略)見てみましょう。
% sudo mount /dev/ada2s1d /mnt % df -m Filesystem 1M-blocks Used Avail Capacity Mounted on /dev/ada0s1a 36959 7565 26437 22% / devfs 0 0 0 100% /dev /dev/da1s1d 952 70 806 8% /var/log /dev/mirror/mirror0s1d 461929 346476 78498 82% /pub1 /dev/md0 290 0 266 0% /tmp /dev/ada2s1d 923859 346456 503493 41% /mnt以上。
└ G兄
└ G兄
└ G兄
└ G兄
└ G兄
└ G兄
└ G兄
└ G兄
└ 山銀
└ G兄