Различия
Здесь показаны различия между двумя версиями данной страницы.
Предыдущая версия справа и слева Предыдущая версия Следующая версия | Предыдущая версия Последняя версия Следующая версия справа и слева | ||
wiki:ext_to_btrfs [2015/12/21 20:45] [Глоссарий] |
wiki:ext_to_btrfs [2016/11/09 12:01] [Инструкция преобразование ext4 в btrfs] |
||
---|---|---|---|
Строка 1: | Строка 1: | ||
====== Ext-btrfs ====== | ====== Ext-btrfs ====== | ||
- | ======Глоссарий====== | ||
- | chunk - кусок файловой системы, btrfs размечает не диск, а chunk'и внутри раздела. | ||
- | leaf - леана, ветка метаданных, inode, в её пишутся метаданные описывающие содержание chunk'ов и мелкие файлы. | ||
- | лист - кусок чанка или сам чанк, туда пишутся данные. | ||
=====Из ext* в btrfs===== | =====Из ext* в btrfs===== | ||
- | <note> | + | [[wiki:btrfs|Btrfs]] содержит очень мало метаданных, которые имеют фиксированное положение, что делает относительно лёгкой разработку утилит преобразования в неё из других файловых систем. Алгоритм Copy on write позволяют btrfs сохранять неизмененную копию исходной файловой системы, а администратору позволяют отменить преобразование, даже после выполнения изменений в итоговой файловой системе btrfs (откат происходит без учета изменений в btrfs, т.е. к тому моменту когда было запущено преобразование). |
- | Эта статья помечена как незаконченная. | + | |
- | </note> | + | |
- | Btrfs содержит очень мало метаданных, которые имеют фиксированное положение, что делает относительно лёгкой разработку утилит преобразования в неё из других файловых систем. Алгоритмы Copy on write позволяют Btrfs сохранять неизмененную копию исходной файловой системы, а администратору позволяют отменить преобразование, даже после выполнения изменений в итоговой файловой системе Btrfs. | + | |
- | Программа преобразования использует libe2fs для чтения метаданных Ext3, и использует свободные блоки в ней для помещения в них новую файловую систему Btrfs. Основной алгоритм преобразования работает так: | + | Программа преобразования btrfs-convert использует libe2fs для чтения метаданных ext2-3-4 (далее для простоты ext*), и использует свободные блоки файловой системы для помещения в них метаданных новой файловой системы btrfs. Алгоритм преобразования работает так: |
- | дублирует первый 1 Мбайт устройства; | + | - дублируется первый 1 Мбайт устройства на свободное место; |
- | дублирует каталоги и inodes, создавая их копии в Btrfs; | + | - создает копии каталогов и inodes в структуре метаданных btrfs (также в свободных областях старой файловой системы); |
- | делает ссылки на блоки данных файла Ext3 в файлах Btrfs. | + | - в новых inode создаются ссылки на блоки данных файлов ext*. |
- | Таким образом создаются копии всех метаданных Ext3, но файлы Btrfs являются просто указателями на те же самые блоки, которые заняты файлами Ext3. Это разделяет большую часть блоков между этими двумя файловыми системами. Поскольку Btrfs использует Copy on write для всех модификаций файла, оригинальная версия блоков данных файла Ext3 сохраняется. | + | Таким образом создается новая структура метаданных btrfs, которая дублирует метаданные ext*, но данные файлов не дублируются на них ссылаются обе структуры метаданных. Это разделяет большую часть блоков между этими двумя файловыми системами. Поскольку btrfs использует Copy on write для всех модификаций файлов, оригинальная версии блоков данных файлов ext* сохраняются без изменений. |
- | Первый 1 МБ устройства копируется в альтернативную область для того, чтобы в него могли быть записаны метаданные Btrfs. Отмена преобразования заключается просто в восстановлении этих блоков. | + | Первый 1 МБ устройства копируется в альтернативную область для того, чтобы в него могли быть записаны метаданные btrfs. Отмена преобразования заключается просто в восстановлении этих блоков. |
Результат преобразования выглядит примерно так: | Результат преобразования выглядит примерно так: | ||
Строка 24: | Строка 17: | ||
{{:wiki:converter-description.png |}} | {{:wiki:converter-description.png |}} | ||
- | Конверсионная программа создает в Btrfs снапшот со ссылками на все блоки, используемые Ext3, позволяя администратору определять время, в течение которого будет сохраняться оригинальная файловая система Ext3. Если администратор захочет освободить место, занимаемое реликтами Ext3, снапошот можно удалить, после чего преобразование станет необратимым. | + | Программа конвертирования создает в btrfs снапшот со ссылками на все блоки, используемые ext*, позволяя администратору определять время, в течение которого будет сохраняться оригинальная файловая система ext*. Если администратор захочет освободить место, занимаемое реликтами ext*, снапошот можно удалить, после чего преобразование станет необратимым. |
- | Пока снапшот не удален, для хранения новых модификаций Btrfs могут использоваться только те блоки, которые были помечены в Ext3 как свободные. Это означает, что преобразование может быть отменено когда угодно в любое время, с восстановлением исходной файловой системы Ext3. Конвертер создает отдельный файл, содержащий все ссылки на исходную файловую систему Ext3, и смещения в этом файле соответствуют смещениям на блочном устройстве. Это позволяет администратору монтировать этот файл как loopback-устройство в режиме read only и видеть исходную файловую систему Ext3 и преобразованную файловую систему Btrfs одновременно. | + | Пока снапшот ext* не удален, для хранения новых и сохранения модифицированных файлов/каталогов btrfs использует только те блоки, которые были помечены в ext* как свободные. Это означает, что преобразование может быть отменено когда угодно в любое время, с восстановлением исходной файловой системы ext*. Конвертер создает отдельный файл, содержащий все ссылки на исходную файловую систему ext*, и смещения в этом файле соответствуют смещениям на блочном устройстве. Это позволяет монтировать этот файл как loopback-устройство в режиме read only и видеть исходную файловую систему ext* одновременно с работой в файловой системой btrfs. |
- | (Если раздел не системный, если системный то грузимся с LiveCD и это будет описано ниже). ххх заменить на необходимый раздел | + | |
- | Пример использования: | + | |
- | # Сначала запустить fsck\\ | ||
- | fsck.ext3 -f /dev/xxx\\ | ||
- | # Преобразование из Ext3 в Btrfs\\ | + | =====Пример конвертирования ext3===== |
- | btrfs-convert /dev/xxx\\ | + | <note important>В примере предполагается, что вы работаете с несмонтированным разделом, если нужно преобразовать корневую файловую систему, то загрузитесь с LiveCd/USB для выполнения этих действий.</note> |
+ | <note important>/dev/sdX в командах нужно заменить на реальное имя устройства с которым вы выполняете операции): | ||
+ | </note> | ||
+ | # Сначала проверьте целостность файловой системы ext3\\ | ||
+ | fsck.ext3 -f /dev/sdX\\ | ||
+ | |||
+ | # Преобразование ext3 в btrfs\\ | ||
+ | btrfs-convert /dev/sdX\\ | ||
- | # Монтирование новообразованной файловой системы Btrfs\\ | + | # Монтирование новообразованной файловой системы btrfs\\ |
- | mount -t btrfs /dev/xxx /btrfs\\ | + | mount -t btrfs /dev/sdX /btrfs\\ |
# Монтирование снапшота ext3\\ | # Монтирование снапшота ext3\\ | ||
- | mount -t btrfs -o subvol=ext2_saved /dev/xxx /ext2_saved\\ | + | mount -t btrfs -o subvol=ext2_saved /dev/sdX /ext2_saved\\ |
# Монтирование файла образа как loopback-устройства\\ | # Монтирование файла образа как loopback-устройства\\ | ||
Строка 46: | Строка 42: | ||
{{ :wiki:converter-post.png|}} В приведённом выше примере файлы в /ext3 и в /btrfs будут идентичны. Любые модификации, выполненные в /btrfs, не будут видны в /ext3. Обратное преобразование делается так: | {{ :wiki:converter-post.png|}} В приведённом выше примере файлы в /ext3 и в /btrfs будут идентичны. Любые модификации, выполненные в /btrfs, не будут видны в /ext3. Обратное преобразование делается так: | ||
- | # Полное отмонтирование файловой системы Btrfs\\ | + | # Отмонтируем все элементы файловой системы смонтированные ранее\\ |
unmount /ext3\\ | unmount /ext3\\ | ||
unmount /ext2_saved\\ | unmount /ext2_saved\\ | ||
Строка 52: | Строка 48: | ||
# Обратное преобразование\\ | # Обратное преобразование\\ | ||
- | btrfs-convert -r /dev/xxx\\ | + | btrfs-convert -r /dev/sdX\\ |
# Монтирование исходной файловой системы\\ | # Монтирование исходной файловой системы\\ | ||
- | mount -t ext3 /dev/xxx /ext3\\ | + | mount -t ext3 /dev/sdX /ext3\\ |
- | Если вы хотите освободить место, занятое исходной файловой системой Ext3 и сделать преобразование постоянным, просто удалите файл /ext2_saved/image. | + | |
+ | Если вы хотите освободить место, занятое снимком исходной файловой системой ext3 (т.е. вы решили, что уже не нужно обратное преобразование), просто удалите файл /ext2_saved/image. | ||
После удаления файла образа диск будет выглядеть примерно так -> | После удаления файла образа диск будет выглядеть примерно так -> | ||
=====Инструкция преобразование ext4 в btrfs===== | =====Инструкция преобразование ext4 в btrfs===== | ||
- | Делаем аналогично, я буду вести вас за руку, делаю на примере моего опыта преобразования раздела /home и прикручивания его на месте. | + | Делаем на примере преобразования вынесенного в отдельный раздел /home. Для этого мы перезагружаемся с LiveCD/USB и монтируем нашу корневую систему (она нам поребуется для редактирования fstab). |
- | Общий план действий, мы установили ubuntu 12.10, корень изначально отформатирован в btrfs, вот fstab: | + | Запись о /home в установленной системы fstab выглядит примерно так так: |
- | # <file system> <mount point> <type> <options> <dump> <pass> | + | |
- | # / was on /dev/sda3 during installation | + | |
- | UUID=d094dfa1-3114-41d0-86da-5e3d91a75a35 / btrfs defaults,subvol=@ 0 1 #корень / | + | |
- | # | + | |
- | # /boot was on /dev/sda2 during installation | + | |
- | UUID=d9e3ccbf-9281-4322-ab39-f3b590b41c1a /boot ext4 defaults 0 2 #раздел /boot обязательно отдельно и не btrfs | + | |
- | # | + | |
- | # /boot/efi was on /dev/sda1 during installation | + | |
- | UUID=EECD-EEE1 /boot/efi vfat defaults 0 1 | + | |
- | #Efi потому что - [[wiki:установка_дистрибутива_на_компьютер_с_efi|Установка дистрибутива на компьютер с efi]] | + | |
- | # | + | |
# /home was on /dev/sda5 during installation | # /home was on /dev/sda5 during installation | ||
UUID=34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home ext4 defaults 0 2 | UUID=34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home ext4 defaults 0 2 | ||
- | # | ||
- | # swap was on /dev/sda4 during installation | ||
- | UUID=eec9a7be-672b-4720-acef-70f5bd6df0c4 none swap sw 0 0 | ||
- | Вот отличненько, первое это приводим в порядок корневой раздел, переделываем его вот в это(инфа о параметрах [[wiki:fstab?&#btrfs|тут]]): | ||
- | # / was on /dev/sda3 during installation | ||
- | UUID=d094dfa1-3114-41d0-86da-5e3d91a75a35 / btrfs defaults,subvol=@,compress,autodefrag 0 0 | ||
- | Перезагружаем, смотрим что вышло. Запустилась? отлично, значит всё хорошо. Загружаемся с любого LiveCD образа. | ||
- | //Инструкция составлена для преобразования раздела /home при схеме разметки как выше, в вашем случае может понадобиться изменить имена разделов// | ||
- | Сначала запустить fsck #Проверим диск на наличие ошибок | + | Для начала проверим файловую систему /home на наличие ошибок: |
- | fsck.ext4 -f /dev/sda5 #ext4 т.к. раздел home выше отформатирован в её. | + | |
+ | fsck.ext4 -f /dev/sda5 # ext4 т.к. раздел home выше отформатирован в её. | ||
| | ||
- | #Преобразование из Ext* в Btrfs | + | Преобразование из ext4 в btrfs |
- | btrfs-convert /dev/sda5 #Он долго и упорно будет сканировать метадаты, у меня процесс конвертации длился больше получаса (300GB/500GB). | + | btrfs-convert /dev/sda5 # Он долго и упорно будет сканировать метаданные и копировать их, процесс конвертации может длиться очень долго. |
- | #Не трогаем не выдергиваем ждём завершения. | + | # Не трогаем не выдергиваем ждём завершения. |
| | ||
- | #Новоиспеченную btrfs можно смонтировать через наутилус и проверить наличие папок ext2_saved и папку пользователя(вашу) | + | Новоиспеченную btrfs можно смонтировать и проверить наличие папок ext2_saved и папку пользователя (вашу). |
- | #Узнаем новый адресс раздела с home | + | |
+ | Теперь нужно внести правки в fstab, но сначала нужно узнать новый идентификатор раздела с home: | ||
sudo blkid | sudo blkid | ||
- | #ищем строку с нашим разделом, вот и она: | + | # ищем строку с нашим разделом, вот и она: |
/dev/sda5: UUID="baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3" UUID_SUB="eaebe91a-5797-44d9-bc74-312316e7dbe6" TYPE="btrfs" | /dev/sda5: UUID="baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3" UUID_SUB="eaebe91a-5797-44d9-bc74-312316e7dbe6" TYPE="btrfs" | ||
- | Теперь надо исправить неправильный адрес home в fstab. Открываем наутилус, примонтируем раздел с корнем. | + | Теперь надо исправить тип файловой системы и UUID home раздела в fstab. Для этого откройте fstab в любом редакторе с правами root пользователя. |
- | sudo gedit | + | Находим строку с нашим разделом home: |
- | открываем корень, затем run -> media -> ищем среди подключенных дисков корневой раздел, открываем там будет папка "@", переходим etc -> fstab \\ | + | |
- | Отлично, находим строку с нашим разделом home: | + | |
| | ||
#/home was on /dev/sda5 during installation | #/home was on /dev/sda5 during installation | ||
UUID=34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home ext4 defaults 0 2 | UUID=34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home ext4 defaults 0 2 | ||
- | Теперь правим его, по аналогии с корнем, заменяем старый UUID "34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3", на новый "baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3", прописываем параметры, получаем(не забудьте исправить ext4 на btrfs): | + | |
+ | Теперь заменяем старый UUID "34a5d56c-f6b3-46bb-b5f6-8b6cc15e4da3", на новый "baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3", меняем тип файловой системы с ext4 на btrfs, должна получиться примерно такая строка : | ||
#/home was on /dev/sda5 during installation | #/home was on /dev/sda5 during installation | ||
- | UUID=baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home btrfs defaults,compress,autodefrag 0 0 | + | UUID=baa5d56c-f6b3-46bb-b5f6-8b6cc15e4da3 /home btrfs defaults 0 2 |
- | Перезагружаемая, если всё сделано правильно, оно загрузиться. В крайнем случае [который не должен наступить] по вышестоящей инструкции можно вернуть ext* на место. | + | |
+ | Перегружаемся в основную систему, если всё сделано правильно, то вы не заметите никаких изменений. В крайнем случае [который не должен наступить] можно вернуть ext4 на место (выполнив обратное преобразование и вернув стрый UUID и тип файловой системы в строке монтирования /home в fstab). | ||
+ | |||
+ | =====Подчистка за конвертером===== | ||
+ | |||
+ | Если переход на btrfs состоялся окончательно и вы уже не планируете возвращать старую фс - то не забудьте подчистить за конвертером: | ||
+ | - Удалите подраздел со снимком ext*: btrfs subvolume delete ext2_saved | ||
+ | - Удалите системный каталог ext* **lost+found** (он вам больше не нужен) | ||
+ | - Проведите дефрагментацию: btrfs filesystem defragment / | ||
+ | - Выполните балансировку: btrfs balance start / | ||
===== Ссылки ===== | ===== Ссылки ===== | ||