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 /mnt
5GB の 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 argument
gpart 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兄