ТЗ#
Существует множество фич упрощающих жизнь системному администратору. Различные системы удаленного управления позволяют установить ОС на девственно-чистый сервер и сегодня это совсем не проблема. Даже наличие второго винчестера превращает проблему переустановки операционки в банальность. Поэтому в этой статье рассмотрим самый суровый из случаев: пусть на сервере имеется только один полностью разбитый винчестер, а наша задача — удалённо переустановить ОС.
Удивлённо поднимем брови, умиляясь тому, как гибка наша любимая операционка, засучим рукава и приступим к делу.
В основе данного метода лежит идея о том, что мы можем использовать SWAP-раздел для установки временной операционной системы, а когда она встанет на ноги — заняться основной. Главное и единственное, что нам нужно — это своп размером не менее 420 Мб (именно столько занимает lenny со всем необходимым).
В статье используются следующие допущения:
- у вас стоит дебиан, и ставить вы планируете дебиан;
- используется grub установленный в MBR.
Краткий план работ#
- превращаем swap-раздел в ext3;
- устанавливаем на него чистую ОС;
- перезагружаемся в нее;
- делаем нужные изменения на основном разделе;
- копируем чистую ОС из временного в основной раздел;
- загружаемся с основного раздела, включаем swap.
Подготовка раздела#
Отключение раздела подкачки#
Первое, что мы сделаем — убедимся, есть ли у нас этот своп-раздел вообще:
Как видим — есть, и размер (отображается в Мб) вполне удовлетворяет требованиям. Осталось выяснить, как у нас разбит диск:
1soar@host:~$ fdisk -l /dev/sda
2...
3Device Boot Start End Blocks Id System
4/dev/sda1 * 1 462 3710983+ 83 Linux
5/dev/sda2 463 522 481950 5 Extended
6/dev/sda5 463 522 481918+ 82 Linux swap / Solaris
Видно, что на sda1
— текущая ОС, на sda5
— своп. Запутаться сложно, но всякое бывает.
Отключаем своп:
1root@host:~# swapoff -a
Убедиться, что мы его выключили, можно выполнив всё тот же free
:
Подготовка временного раздела#
Обновим нашу таблицу разделов:
1root@host:~# fdisk /dev/sda
2Command (m for help): t
3Partition number (1-5): 5
4Hex code (type L to list codes): 83
5Changed system type of partition 5 to 83 (Linux)
6Command (m for help): w
7The partition table has been altered!
8
9WARNING: Re-reading the partition table failed with error 16: Устройство или ресурс занято.
10The kernel still uses the old table.
11The new table will be used at the next reboot.
12Syncing disks.
Нам заботливо сообщили, что ядро не увидит изменений до перезагрузки, но нам это пока и не нужно. Теперь самое время подготовить файловую систему на нашем старом новом разделе. Например, ext3:
Примонтируем раздел куда-нибудь и на этом его подготовка будет закончена.
1root@host:~# mkdir /mnt/temp
2root@host:~# mount /dev/sda5 /mnt/temp
3root@host:~# df -h
4Файловая система Разм Исп Дост Исп% смонтирована на
5/dev/sda1 3,5G 600M 2,8G 18% /
6...
7/dev/sda5 456M 11M 422M 3% /mnt/temp
Установка «временной» ОС.#
Здесь нужно заметить, что временной она является только по своему местоположению. Чтобы дважды не прогонять все действия по сборке чистой системы в дальнейшем мы просто скопируем её на основной раздел.
Использование debootstrap#
Используем отличное средство для получения минимальной установки — debootstrap
. Здесь и далее мы будем считать что проблем с интернетом на сервере нет (иначе какой же он после этого сервер ?), поэтому выкачиваем всё из репозитория.
Данной утилите достаточно передать четыре параметра: желаемая архитектура, название релиза, директория установки и ссылка на полное зеркало. Архитектуру можно определить по выводу uname -a
, дистрибутив выбираем на свой вкус, директория в данном случае та, куда мы смонтировали наш раздел, а ссылку на зеркало можно взять здесь: http://www.debian.org/mirror/list. Получается, что строка запуска выглядит примерно так:
1root@host:~# debootstrap --arch i386 lenny /mnt/temp http://ftp.ru.debian.org/debian/
После нажатия enter начнется процесс загрузки и установки пакетов, при достаточно среднем интернет-соединении (~10 Мбит) на это уходит порядка 5-10 минут — я даже не успел допить свой чай. В конце вы увидите сообщение о том, что система успешно установлена:
1I: Base system installed successfully.
Конфигурирование новой системы#
Теперь начинается одна из самых ответственных процедур: нам нужно правильно сконфигурировать новую систему. Любому сис-админу, наверное, снились кошмары о том, как он теряет удаленный контроль над машиной, да и в конце концов всё это мы затевали именно для того, чтобы не ехать в дата-центр. Поэтому отложим кружку кофе и сосредоточимся.
Сначала скопируем все важные настройки. Наверное, у каждого найдутся достаточно важные файлы, которые лежат не там где положено. У меня, к примеру, есть некий /etc/rc.routes
со всеми нестандартными маршрутами. Главное не забыть ничего. Приводить тут какой-либо список, мне кажется, совершенно бессмысленно, но у меня это выглядит примерно так:
1root@host:~# cp /etc/{resolv.conf,hosts,rc.local} /mnt/temp/etc
2root@host:~# cp /etc/network/interfaces /mnt/temp/etc/network
3root@host:~# cp /etc/your-stuff /mnt/temp/etc
В fstab
напишем самое необходимое — proc и наш корневой раздел:
1root@host:~# cat > /mnt/temp/etc/fstab << "#EOF"
2proc /proc proc defaults 0 0
3/dev/sda5 / ext3 errors=remount-ro 0 1
4#EOF
Теперь смонтируем dev-окружение, перейдем в чрут нашей временной системы и сразу примонтируем proc
:
1root@host:~# mount --bind /dev /mnt/temp/dev
2root@host:~# chroot /mnt/temp /bin/bash
3root@host:~# mount -t proc proc /proc
Очевидно нам понадобится менеджер пакетов, думаю рассказывать о его настройке отдельно не нужно.
1root@host:~# wget http://debian.soar.name/sources.list -O /etc/apt/sources.list
2root@host:~# aptitude update
Настроим часовой пояс:
1root@host:~# dpkg-reconfigure tzdata
Также нам понадобятся следующие пакеты:
1root@host:~# aptitude install locales
2root@host:~# dpkg-reconfigure locales
3root@host:~# aptitude install console-data
4root@host:~# aptitude install ssh
5root@host:~# aptitude install sudo
Сразу же, чтобы не забыть, создадим пользователя и назначим ему пароль, иначе в ssh нас потом не пустят:
Теперь переустановим загрузчик. Сначала необходимо создать все файлы загрузчика на новом диске:
Подготовка загрузчика#
После чего необходимо инициализировать МБР на загрузку с нашего нового раздела. Для этого всё там же, в чруте, войдем в консоль граба и напишем следующее:
1root@host:~# grub
2grub> root (hd0,
3Possible partitions are:
4Partition num: 0, Filesystem type is ext2fs, partition type 0x83
5Partition num: 4, Filesystem type is ext2fs, partition type 0x83
Своеобразный автокомплит по табу подскажет нам, какие разделы есть в нашем распоряжении. Как видим всё на единицу меньше чем в названии в системе. Инициализируем загрузку с нашего sda5
:
1grub> root (hd0,4)
2Filesystem type is ext2fs, partition type 0x83
3
4grub> setup (hd0)
5...
6Done.
7
8grub> quit
Загрузчик установлен куда нужно. Теперь выберем и установим подходящее ядро:
В ходе установки нас спросят «Create a symbolic link to the current kernel image?», на что мы ответим утвердительно. Так же сообщат, что мы устанавливаем ядро, требующее от загрузчика поддержку initrd, и уточнят, не передумали ли мы. Отвечаем «Нет» и установка заканчивается. Осталось обновить меню загрузчика:
1root@host:~# update-grub
2Found kernel: /boot/vmlinuz-2.6.26-2-686
3Updating /boot/grub/menu.lst ... done
Выходим из чрута, собираем нервы в кулак и отправляем сервер в первую перезагрузку:
Если все было сделано правильно — машина перезагрузится в нашу временную систему. Мы можем зайти в ssh как пользователь, которого мы только что добавили.
Перенос системы на основной раздел.#
Подготовка основного раздела#
Форматируем и монтируем наш старый раздел:
1root@host:~# mke2fs -j /dev/sda1
2Writing inode tables: done
3Creating journal (16384 blocks): done
4Writing superblocks and filesystem accounting information: done
5
6root@host:~# mkdir /mnt/temp
7root@host:~# mount /dev/sda1 /mnt/temp
К слову, на этом этапе можно провести и обслуживание диска: например переразбить основной раздел и проверить файловую систему.
Копирование системы#
Остается скопировать нашу чистую ОС на основной раздел:
1root@host:~# cp -a -x / /mnt/temp/
Обновляем fstab. На этот раз причешем его по всем правилам:
1root@host:~# cat > /mnt/temp/etc/fstab << "#EOF"
2# /etc/fstab: static file system information.
3#
4#
5
6proc /proc proc defaults 0 0
7/dev/sda1 / ext3 defaults,errors=remount-ro 0 0
8#EOF
Подготовка загрузчика#
В очередной раз нужно обновить граб. На этот раз — для загрузки уже с нашего основного раздела:
1root@host:~# mount --bind /dev /mnt/temp/dev
2root@host:~# chroot /mnt/temp/ /bin/bash
3root@host:~# grub-install /dev/sda
4root@host:~# grub
5
6grub> root (hd0,0)
7 Filesystem type is ext2fs, partition type 0x83
8
9grub> setup (hd0)
10 Checking if "/boot/grub/stage1" exists... yes
11 Checking if "/boot/grub/stage2" exists... yes
12 Checking if "/boot/grub/e2fs_stage1_5" exists... yes
13 Running "embed /boot/grub/e2fs_stage1_5 (hd0)"... 17 sectors are embedded.
14succeeded
15 Running "install /boot/grub/stage1 (hd0) (hd0)1+17 p (hd0,0)/boot/grub/stage2 /boot/grub/menu.lst"... succeeded
16Done.
17
18grub> quit
19
20root@host:~# update-grub
21Updating /boot/grub/menu.lst ... done
Тут стоит отметить, что у меня в этом месте, в отличие от первого случая, menu.lst обновляться отказался, и там по-прежнему оставались ссылки на sda5. Почему это происходит — я так и не разобрался, поэтому вручную подредактировал этот файл:
1root@host:~# sed -i -e 's/sda5/sda1/g' /boot/grub/menu.lst
2root@host:~# sed -i -e 's/(hd0,4)/(hd0,0)/g' /boot/grub/menu.lst
Выходим из чрута и делаем вторую перезагрузку:
После перезагрузки можно убедиться, что мы снова на родном основном разделе:
1root@host:~# df -h
2Файловая система Разм Исп Дост Исп% смонтирована на
3/dev/sda1 3,5G 436M 2,9G 13% /
Включение раздела подкачки#
Остается создать и включить своп:
1root@host:~# fdisk /dev/sda
2Command (m for help): t
3Partition number (1-5): 5
4Hex code (type L to list codes): 82
5Changed system type of partition 5 to 82 (Linux swap / Solaris)
6...
7The new table will be used at the next reboot.
8Syncing disks.
9
10root@host:~# cat >> /etc/fstab << "#EOF"
11/dev/sda5 none swap sw 0 0
12#EOF
13
14root@host:~# mkswap /dev/sda5
15root@host:~# swapon -a
Убедимся что всё нормально:
Ну и в конце, если вы редактировали /boot/grub/menu.lst
врукопашную — стоит все-таки запустить скрипт его обновления еще раз:
Подводя итоги.#
Данный способ безусловно не самый простой путь переустановки системы, однако, во многих случаях, он становится единственно возможным. Тем более вся процедура занимает около 25 минут, поэтому если ваш ДЦ не через дорогу, то в любом случае выходит совсем неплохая экономия времени. Получилось на удивление много букв — я пытался расписать подробно и понятно, но на самом деле операция простая и достаточно быстрая.