|
|
www.lissyara.su
—> статьи
—> FreeBSD
—> Мелочи
—> HDD(mbr) -> HDD(gpt)
FreeBSD: Перенос системы на диск размером более 2TB
Автор: mvalery.
0. Введение
Администраторы FreeBSD, в том числе и я, столкнулись с очередным ограничением файловой системы. Традиционными средствами невозможно разбить на разделы диск, размер которого превышает 2TB (два терабайта).
В статье описано, как разбить диск размером более 2TB на разделы, сделать загрузочным, а затем перенести на него информацию с рабочей системы — донора.
Статья относится к версиям FreeBSD 6.4 и старше (если такие будут) и FreeBSD 7.1 и старше.
Процесс переноса прост для понимания. Может быть легко автоматизирован.
Мало того. Использовать таблицу разделов GPT, лежащую в основе данного метода, вместо MBR имеет смысл даже для дисков имеющих размер менее 2TB, т.к. несколько копий GPT размещаются в разных частях диска. В случае гибели одной копии, структура разделов будет прочитана из другой. (Кто плакал над смертью нулевого сектора MBR, тот меня поймет.)
Увы, пока невозможно установить FreeBSD напрямую. Инсталлятор sysinstall не умеет работать с GPT.
Второй серьезный недостаток — после аварийной остановки (напр. при аварии по питанию) проверка файловой системы на крупных разделах выполняется очень долго.
Было бы кардинальным решением проблемы перейти на ZFS, но такой переход требует значительно больше телодвижений (в т.ч. построение своего ядра). Кроме того ZFS требует больше оперативной памяти.
(см. дискуссию на форуме)
В принципе можно начинать пользоваться ZFS, если
1. архитектура amd64
2. в наличии более 2GB оперативки.
3. FreeBSD 7.2+
В чем же суть проблемы? Обратимся за разъяснением к мануалам.
# man bsdlabel
СОВМЕСТИМОСТЬ
В связи с использованием u_int32_t при сохранении номеров секторов, BSD labels
ограничен максимумом из 2^32-1 секторов. Что обычно означает 2TB дискового
пространства. Диски большего размера могут быть разбиты посредством другого
метода, такого как gpt(8).
|
Для наших целей достаточно знать, что обычная MBR может хранить информацию о размещении только 4 первичных разделов, чего явно не достаточно. Именно это ограничение вынуждает использовать во FreeBSD двухуровневую структуру слайсы/разделы.
Таблица разделов нового типа GPT, по умолчания может хранить информацию о размещении 128 разделов. Думаю, что на первое время этого должно хватить [ шутка :) ]. Соответственно, существует утилита, которая так и называется gpt(8) и которая позволяет нам проводить с таблицей GPT все необходимые действия.
Возможности GPT позволяют упростить именование разделов в системе.
Типичный раздел на диске для MBR выглядит так:
  /dev/ad4s1d, где ad4 — имя диска; s1 – первый слайс; d – буква раздела
Типичный раздел на таком же же диске но для GPT:
  /dev/ad4p5, где ad4 — все то же имя диска; p5 – 5-й раздел.
1. Предварительные действия
На моем «подопытном» сервере, жесткий диск 160GB, мой донор, подключен к контроллеру материнки.
На этот диск я традиционным способом поставил FreeBSD 7.2.
Система будет перенесена на RAID совокупным объемом 4TB.
Размеры всех разделов при переносе решил сохранить.
Кроме /home. Этому разделу я выделю все оставшееся пространство.
Собираем информацию.
(1) Для начала смотрим какие имена дала система нашим накопителям.
# less /var/run/dmesg.boot
ad4: 152627MB <WDC WD1600AAJS-00PSA0 05.06H05> at ata2-master SATA300
da0: 3814695MB (7812495360 512 byte sectors: 255H 63S/T 486305C)
| ad4 — донор ; da0 — получатель
Дополнительно убеждаемся, что da0 состоит из секторов по 1/2 KB. Для меня это важно т.к. утилита gpt(8) принимает размеры разделов именно в секторах.
(2) Выясняем каковы размеры разделов в секторах.
Смотрим и запоминаем :) вторую колонку.
# df -b -t ufs | sort
Filesystem 512-blocks Used Avail Capacity Mounted on
/dev/ad4s1a 2025948 293688 1570188 16% /
/dev/ad4s1d 2025948 24 1863852 0% /tmp
/dev/ad4s1e 40616796 3637752 33729704 10% /usr
/dev/ad4s1f 10154076 1371176 7970576 15% /var
/dev/ad4s1g 94497492 505612 86432084 1% /home
|
(3) Выясняем размер swap раздела т.к. предыдущая команда его не показала.
# swapinfo
Device 1K-blocks Used Avail Capacity
/dev/ad4s1b 2097152 808 2096344 0%
| Вычисляем размер в секторах:
2097152 K * 2= 4051896 секторов
2. Подготовка нового диска
Разбиваем новый диск на разделы. Размеры разделов см. выше.
(1) Создаем на диске таблицу разделов GPT.
(ключ -f - затирать MBR даже если она есть. На диске может быть таблица только одного типа. Наш выбор GPT.)
(2) Создаем бутовый раздел. Размещаем там загрузчик.
# gpt boot -b /boot/pmbr -g /boot/gptboot da0
| Файлы pmbr и gptboot копируются в директорию /boot в процессе инсталяции системы - донора.
Если ваш сервер бежит под FreeBSD 6.4+ или 7.1+, загляните в /boot. Файлы pmbr и gptboot уже находятся там.
(3) Поочередно создаем разделы, указывая тип файловой системы (ключ -t) и размер в секторах (ключ -s). Для /home ключ -s не указан. Это означает «все оставшееся пространство».
# gpt add -t ufs -s 2025948 da0
# gpt add -t swap -s 4051896 da0
# gpt add -t ufs -s 2025948 da0
# gpt add -t ufs -s 40616796 da0
# gpt add -t ufs -s 10154076 da0
# gpt add -t ufs da0
|
Примечание:
Надежно стереть таблицу GPT с диска можно специальной командой:
Старый добрый финт (# dd if=/dev/zero of=/dev/da0 bs=512 count=1) здесь не пройдет (помните что я говорил про дополнительные копии системы?).
(4) Смотрим что получилось.
# gpt show da0
start size index contents
0 1 PMBR
1 1 Pri GPT header
2 32 Pri GPT table
34 128 1 GPT part - FreeBSD boot
162 2025948 2 GPT part - FreeBSD UFS/UFS2
2026110 4051896 3 GPT part - FreeBSD swap
6078006 2025948 4 GPT part - FreeBSD UFS/UFS2
8103954 40616796 5 GPT part - FreeBSD UFS/UFS2
48720750 10154076 6 GPT part - FreeBSD UFS/UFS2
58874826 7753620501 7 GPT part - FreeBSD UFS/UFS2
7812495327 32 Sec GPT table
7812495359 1 Sec GPT header
| Для нас важна 3-я колонка - index. Это номера разделов.
(5)На основе этой информации строим таблицу соответствия имен разделов.
/dev/da0p2 /dev/ad4s1a /
/dev/da0p3 /dev/ad4s1b swap
/dev/da0p4 /dev/ad4s1d /tmp
/dev/da0p5 /dev/ad4s1e /usr
/dev/da0p6 /dev/ad4s1f /var
/dev/da0p7 /dev/ad4s1g /home
|
(6) Создаем файловые системы в разделах целевого диска.
/dev/da0p2 предназначен для рутового раздела, поэтому без softupdate.
/dev/da0p3 будет содержать своп. Там нечего создавать.
Оставшиеся разделы — стандартные.
# newfs /dev/da0p2
# newfs -U /dev/da0p4
# newfs -U /dev/da0p5
# newfs -U /dev/da0p6
# newfs -U /dev/da0p7
|
(7) Создаем точки монтирования для новой файловой системы в старой.
# mkdir -p /mnt/{root,usr,var,home}
|
3. Собственно перенос
Перенос был выполнен по мотивам статьи http://www.lissyara.su/?id=1198
Большое спасибо автору.
(1) Перезагружаемся в однопользовательский режим.
Когда появится стартовое меню, выбираем
4. Boot FreeBSD in single user mode
|
А затем
Enter full pathname of shell or Return for /bin/sh:
| Жмем <ENTER>.
(2) Монтируем источник
(3) Монтируем получателя
mount /dev/da0p2 /mnt/root
mount /dev/da0p5 /mnt/usr
mount /dev/da0p6 /mnt/var
mount /dev/da0p7 /mnt/home
|
(4) Переносим
# ( dump -0Lf - / ) | ( cd /mnt/root ; restore -rf - )
# ( dump -0Lf - /usr ) | ( cd /mnt/usr ; restore -rf - )
# ( dump -0Lf - /var ) | ( cd /mnt/var ; restore -rf - )
# ( dump -0Lf - /home ) | ( cd /mnt/home ; restore -rf - )
|
(5) На получателе правим в fstab имена разделов.
У нас должно получиться что-то вроде:
# Device Mountpoint FStype Options Dump Pass#
/dev/da0p3 none swap sw 0 0
/dev/da0p2 / ufs rw 1 1
/dev/da0p7 /home ufs rw 2 2
/dev/da0p4 /tmp ufs rw 2 2
/dev/da0p5 /usr ufs rw 2 2
/dev/da0p6 /var ufs rw 2 2
/dev/acd0 /cdrom cd9660 ro,noauto 0 0
|
4. Финальные действия
(1) Выключаем питание
(2) Отсоединяем донора. Стартуем. В BIOS прописываем загрузку с RAID — массива.
Ссылка на обсуждение: http://forum.lissyara.su/viewtopic.php?t=18235.
размещено: 2009-05-30,
последнее обновление: 2009-06-02,
автор: mvalery
|
|
|
|
2014-07-27, lissyara
gmirror
Удалённое создание софтверного зеркала средствами gmirror, на диске разбитом с использованием gpart. Использование меток дисков для монтирования разделов.
2013-08-20, zentarim
Scan+Print server FreeBSD 9
Настройка сервера печати и сервера сканирования под управлением операционной системы FreebSD 9 для МФУ Canon PIXMA MP540
2011-11-20, BlackCat
Разъём на WiFi-карту
Делаем съёмной несъёмную антену на WiFi-карте путём установки ВЧ-разъёма
2011-09-14, manefesto
Настройка git+gitosis
Настройка системы контроля версия исходного кода в связке git+gitosis+ssh
2011-08-14, zentarim
Wi-FI роутер + DHCP + DNS
Настройка Wi-Fi роутера на Freebsd 8 + DNS сервер + DHCP сервер: чтобы Wi-Fi клиенты были в одной подсети с проводными, проводные и беспроводные клиенты получали адреса автоматически по DHCP, кэширующ
2011-06-15, -ZG-
Охранная система на FreeBSD+LPT
В этой статье описана попытка реализации простой охранной системы на базе FreeBSD с подключением к ней охранных устройтсв на LPT порт и видеорегистрацией.
2011-03-13, terminus
ng_nat
Описание работы ng_nat, практическое использование, достоинства и недостатки в сравнении с ipfw nat
2011-02-20, Капитан
Nagios+Digitemp
Статья описывает создание системы оповещения о превышении температуры в специальных помещениях на основе Nagios с использованием программы Digitemp.
2011-02-17, Le1
Zyxel Configuration
Скрипт для массового изменения конфига свичей Zyxel. Берет из файла iplist список ip-шек, заходит последовательно на каждый и выполняет комманды из файла commands, записывая происходящее в лог файл.
2011-02-16, fox
hast carp zfs ucarp cluster
HAST (Highly Available Storage), CARP, UCARP, ZFS, Cluster настройка и одаптация плюс личные размышления…
2011-02-04, BlackCat
Восстановление ZFS
История о том, как был восстановлен развалившийся RAIDZ ZFS-пул (перешедший в FAULTED) с помощью скотча и подручных средств. Или о том, какие приключения ожидают тех, кто не делает резервных копий.
2011-02-03, Капитан
1-Wire
Статья описывает самостоятельное изготовление контроллера DS9097 для съёма показаний с датчиков температуры DS1820 с помощью программы Digitemp.
2011-01-28, Капитан
Температура в серверной
Статья описывает построение системы наблюдения за температурой в помещении серверной с использованием программы Digitemp и выводом графиков в MRTG
2011-01-21, m4rkell
Syslog server
Как то буквально на днях, у нас завалилось, что то в еве) или не в еве не суть. Суть в том, что когда захотели снять логи с хостов esx обнаружили, что хранят эти негодяи логии только за последнии сутк
2011-01-07, lissyara
Canon/gphotofs
Монтирование цифровых фотоаппаратов Canon (PTP) как файловой системы, автоматизация этого процесса через события devd и внешние скрипты.
2010-12-13, Al
IPSec
Описание принципов работы IPSEC и способов аутентификации.
2010-12-07, manefesto
FreeBSD on flash
Было принято решении переехать на USB Flash и установить минимальный джентельменский набор для работы своего роутера. Делаем =)
2010-12-05, Fomalhaut
root ZFS, GPT
Инструкция по установке FreeBSD с использованием в качестве таблицы разделов GPT и в качестве основной файловой системы - ZFS
2010-09-05, Cancer
Настройка аудиоплеера на ximp3
Цели: Простенький аудиоплеер, для того что бы тетя продавец в магазине утром пришла нажала на кнопку Power и заиграла в зале музыка, так же был доступ по сети, общая шара куда можно заливать музыку, к
2010-08-31, Cancer
Установка и настройка OpenVPN
На днях появилась задача - объединить головной офис и 3 филиала в одну сеть через интернет посредством OpenVPN, чтобы люди могли подключаться через RDP к базам 1С на серверах.
2010-08-25, manefesto
freebsd lvm
Использование linux_lvm для работы с LVM разделами из-под FreeBSD. Проблемы которые возники при монтирование lvm раздела
2010-04-30, gonzo111
proftpd file auth"a
Proftpd - квоты и авторизация из файлов, без использования базы данных и/или системных пользователей
2010-04-22, lissyara
tw_cli
Пошаговая инструкция по восстановлению RAID на контроллере 3ware, из которого выпал один диск. Настройка мониторинга состояния рейда и отчётов о его состоянии на email.
2010-04-14, fox
MySQL Master+Master
MySQL (Master Master) and (Master Slave) Как настроить репликацию…
2010-03-09, terminus
DNS zones
Краткий ликбез про управление DNS зонами. Примеры проведения делегирования прямых и обратных DNS зон.
2010-03-09, aspera
Squid+AD (group access)
Настройка прокси сервера SQUID с автроризацией пользователей в AD. Разделение пользователей на группы
|
Комментарии пользователей [12 шт.]