Замена диска в програмном RAID1 в Linux
Оглавление:
-
I. Удаление диска из массива
II. Добавление диска в массив после замены
1. Определение таблицы разделов(GPT или MBR) и перенос её на новый диск
2. Добавление диска в массив
III. Установка загрузчика
У нас есть сервер в котором 2 диска: /dev/sda и /dev/sdb. Эти диски собраны у нас в софтверный RAID1 с помощью mdadm. Один из дисков вышел из строя, в нашем случае это /dev/sdb.
Перед заменой диска желательно убрать диск из массива. Для начала проверим как размечен диск в массиве:
# cat /proc/mdstat
Personalities : [raid1] [raid0] [raid6] [raid5] [raid4]
md2 : active raid1 sda4[0] sdb4[1]
1456504640 blocks super 1.2 [2/2] [UU]
md1 : active raid1 sda3[0] sdb3[1]
7996352 blocks super 1.2 [2/2] [UU]
md0 : active raid1 sda2[0] sdb2[1]
499392 blocks super 1.2 [2/2] [UU]
unused devices: <none>
В данном случае массив собран так. Что md0 состоит из sda2 и sdb2, md1 из sda3 и sdb3, md2 из sda4 и sdb4. На этом сервере md0 это /boot, md1 — своп, md2 — корень. Убираем sdb из всех устройств.
# mdadm /dev/md0 --remove /dev/sdb2
# mdadm /dev/md1 --remove /dev/sdb3
# mdadm /dev/md2 --remove /dev/sdb4
Если разделы из массива не удаляются, это как в нашем случае. Mdadm не считает диск неисправным и использует его, и при удалении мы увидим ошибку, что устройство используется. В этом случае перед удалением помечаем диск как сбойный.
# mdadm /dev/md0 -f /dev/sdb2
# mdadm /dev/md1 -f /dev/sdb3
# mdadm /dev/md2 -f /dev/sdb4
А затем снова выполним команды по удалению разделов из массива. Все, мы удалили сбойный диск из массива. Теперь можем писать в датацентр запрос на замену диска.
II. Добавление диска в массив после замены
1. Определение таблицы разделов(GPT или MBR) и перенос её на новый диск
После замены поврежденного диска нужно добавить новый диск в массив. Для этого надо определить какая у нас таблица разделов: GPT или MBR. Для этого будем использовать gdisk Установим gdisk:
# apt-get install gdisk -y
Выполняем:
# gdisk -l /dev/sda
Где /dev/sda — исправный диск находящийся в raid. В выводе будет примерно это для MBR:
Partition table scan:
MBR: MBR only
BSD: not present
APM: not present
GPT: not present
И примерно это для GPT:
Partition table scan:
MBR: protective
BSD: not present
APM: not present
GPT: present
Перед добавлением диска в массив нам нужно на нем создать разделы в точности такие же как и на sda. В зависимости от разметки диска это делается по разному.
Копирование разметки для GPT:
# sgdisk -R /dev/sdb /dev/sda
Здесь надо быть внимательным. Первым пишется диск на который копируется разметка, а вторым с которого копируют. Если перепутать их местами, то разметка на изначально исправном диске будет уничтожена. Даем диску новый случайный UIDD:
# sgdisk -G /dev/sdb
Копирование разметки для MBR:
# sfdisk -d /dev/sda | sfdisk /dev/sdb
Здесь наоборот первым пишется диск с которого переносим разметку, а вторым на который переносим. Если разделы не видны в системе, то можно перечитать таблицу разделов командой:
# sfdisk -R /dev/sdb
Когда мы создали разделы на /dev/sdb, то можно добавлять диск в массив.
# mdadm /dev/md0 -a /dev/sdb2
# mdadm /dev/md1 -a /dev/sdb3
# mdadm /dev/md2 -a /dev/sdb4
После добавления диска в массив нужно установить на него загрузчик. Если сервер загружен в нормальном режиме, то это делается одной командой:
# grub-install /dev/sdb
Если сервер загружен в recovery или rescue, т.е с live cd, то установка загрузчика выглядит следующим образом. Монтируем корневую файловую систему в /mnt:
# mount /dev/md2 /mnt
Монтируем boot:
# mount /dev/md0 /mnt/boot
Монтируем /dev, /proc и /sys:
# mount --bind /dev /mnt/dev
# mount --bind /proc /mnt/proc
# mount --bind /sys /mnt/sys
Затем делаем chroot в примонтированную систему:
# chroot /mnt
И устанавливаем grub на sdb:
# grub-install /dev/sdb
Теперь можно попробовать загрузится в нормальный режим.
P.S. Если при установке загрузчика возникнет ошибка Could not find device for /boot/boot: not found or not a block device то вам сюда.
Менял сегодня диски в серверах под VPS, делал это впервые. Ваша статья крайне помогла, пока я тренировался на ВМ, делал многое из этого руками в fdisk. Премного благодарен. (Бот, это не спам)
Рад что помог.
Огромное спасибо. Моя ситуация. Инфа очень пригодилась. Привык к GUI и MS. Искал долго, пока не задал правильный вопрос ))).
А не вышло. Есть к примеру простой диск1 на 70гб. И 2 диска на 100гб. Нужно сделать из 2 дисков пои100гб программный raid1 и на него скопировать содержимое диска 70гб. Как только копирую с диска1 на диск 2 или 3 или на raid из них, весь программный raid разваливается. Каков хоть правильный порядок переноса? Делал копированием диска 1 в образ и затем из образа на диски 100гб. Потому структура и сбивалась. Пните в нужном направлении.