Различия
Здесь показаны различия между двумя версиями данной страницы.
Предыдущая версия справа и слева Предыдущая версия Следующая версия | Предыдущая версия Следующая версия Следующая версия справа и слева | ||
wiki:btrfs [2019/07/30 13:47] [Сжатие/упаковка данных] |
wiki:btrfs [2019/10/23 11:05] [swap файл на btrfs] |
||
---|---|---|---|
Строка 22: | Строка 22: | ||
* Контроль целостности блоков данных и метаданных с помощью контрольных сумм. | * Контроль целостности блоков данных и метаданных с помощью контрольных сумм. | ||
* Зеркалирование метаданных даже в однодисковой конфигурации (отключается на ssd). | * Зеркалирование метаданных даже в однодисковой конфигурации (отключается на ssd). | ||
+ | * Поддержка [[https://ru.wikipedia.org/wiki/Разрежённый_файл|разреженных файлов]]. | ||
* Полностью распределенное блокирование. | * Полностью распределенное блокирование. | ||
* Поддержка ACL. | * Поддержка ACL. | ||
Строка 834: | Строка 835: | ||
Вот собственно и всё. Потом устанавливаем ОС, выбрав для разделов btrfs. Сразу после установки (не перегружаясь) нужно добавить опции монтирования со сжатием - compress=lzo в fstab только что установленной системы (который будет находиться в /target/etc/fstab). | Вот собственно и всё. Потом устанавливаем ОС, выбрав для разделов btrfs. Сразу после установки (не перегружаясь) нужно добавить опции монтирования со сжатием - compress=lzo в fstab только что установленной системы (который будет находиться в /target/etc/fstab). | ||
+ | =====btrfs и GRUB===== | ||
+ | В состав GRUB входят драйвера btrfs. Однако это очень урезанный драйвер и он не поддерживает запись. А отсутствие записи не позволяет GRUB-у записать служебную переменную recordfail. GRUB проверяет значение этой переменной и если она не сброшена, то обязательно показывается меню загрузки. Каждый раз когда GRUB начинает загружать ОС он устанавливает эту переменную в 1, а сбрасывает ее скрипт который запускается после загрузки системы. | ||
+ | |||
+ | Т.к. сохранить значение recordfail GRUB на btrfs не может, то он считает, что каждая загрузка происходит после фейла прошлой загрузки (т.е. recordfail=1). И в таком случае меню загрузки показывается 10 секунд. Изменить этот тайм-аут можно изменив в /etc/default/grub значение переменной GRUB_RECORDFAIL_TIMEOUT. После задания разумного таймаута в /etc/default/grub нужно запустить update-grub с правами root-а чтобы пересоздать скрипты загрузки GRUB-а. | ||
+ | | ||
=====swap файл на btrfs===== | =====swap файл на btrfs===== | ||
- | Начиная с версии 5.0+ на btrfs можно создать swap-файл, но с некоторыми ограничениями: swap-файл должен располагаться целиком на одном устройстве, создаваться обязательно с отключенным COW и сжатием((На самом деле, если вчитаться в детали на btfs-wiki, то отключение COW блокирует возможность архивирования)). Кроме того swap-файл не может попасть в снимок. В перспективе предполагается снять часть ограничений.\\ | + | Начиная с версии ядра 5.0+ на btrfs можно создать swap-файл, но с некоторыми ограничениями: swap-файл должен располагаться целиком на одном устройстве, создаваться обязательно с отключенным COW и сжатием((На самом деле, если вчитаться в детали на btfs-wiki, то отключение COW блокирует возможность архивирования)). Кроме того swap-файл не может попасть в снимок. В перспективе предполагается снять часть ограничений.\\ |
- | Предположим что btrfs у нас на одном устройстве и у нас подходящая версия ядра 5.0+, дальше все довольно просто: | + | Предположим что у нас btrfs на одном устройстве и у нас подходящая версия ядра 5.0+, дальше все довольно просто: |
- | touch /swap # создаем пустой файл /swap - COW можно отключить только на пустом файле | + | touch /swap # создаем пустой файл /swap - COW можно отключить только на пустом файле |
- | chattr +C /swap # отключаем COW, а отключение COW блокирует и возможность компрессии файла | + | chmod go-r /swap # swap должен иметь права 600, а touch проставляет права 644 |
- | truncate -s 4G /swap # создаем пустой файл размером 4Gib | + | chattr +C /swap # отключаем COW |
- | mkswap /swap # создаем внутреннюю разметку в файле для swap-а | + | chattr -c /swap # отключаем компрессию файла |
- | swapon /swap # подключаем swap | + | fallocate swap -l4g # выделяем место под файл 4Gib |
+ | mkswap /swap # создаем внутреннюю разметку в файле для swap-а | ||
+ | swapon /swap # подключаем swap | ||
+ | |||
+ | <note important>Важно выделять место под swap-файл именно командой fallocate. Если создать пустой файл командой truncate, то он фактически останется пустым т.к. в btrfs используется механика [[https://ru.wikipedia.org/wiki/Разрежённый_файл|sparse files]] и mkswap отработает успешно, но swapon сообщит, что в файле есть "дырки", т.е. не размеченные на диск области файла.</note> | ||
Для автоматического монтирования файла в последующем нужно в /etc/fstab добавить следующую строку: | Для автоматического монтирования файла в последующем нужно в /etc/fstab добавить следующую строку: | ||
Строка 849: | Строка 859: | ||
/swap none swap swap 0 0 | /swap none swap swap 0 0 | ||
- | До версии 5.0 использование swap-файла на btrfs привадило [[http://forum.ubuntu.ru/index.php?topic=207432.msg2167728#msg2167728|к разрушению структуры файловой системы]] (отключение COW и компрессии не помогало избежать проблем). Однако можно было создать не очень быстрый и с дополнительными расходами оперативной памяти((что в ситуации с переполнением памяти может привести к не совсем предсказуемым последствиям)) swap-файл через loop-устройство. Давайте рассмотрим пример создания своп-файла этим методом. | + | До версии 5.0 использование swap-файла на btrfs могло привести [[http://forum.ubuntu.ru/index.php?topic=207432.msg2167728#msg2167728|к разрушению структуры файловой системы]] (отключение COW и компрессии не помогало избежать проблем) и поэтому драйвер не дает активировать своп в swap-файле созданном на btrfs. Можно было создать не очень быстрый и с дополнительными расходами оперативной памяти((что в ситуации с переполнением памяти может привести к не совсем предсказуемым последствиям)) swap-файл через loop-устройство. Давайте рассмотрим пример создания своп-файла этим методом. |
Несмотря на то, что отключение COW не помогает, но для избежания фрагментации swap-файла на HDD (на SSD это не так критично) стоит все-таки отключить COW. Компрессию тоже стоит отключить т.к. это еще сильнее затормозит и без того не быстрое решение. | Несмотря на то, что отключение COW не помогает, но для избежания фрагментации swap-файла на HDD (на SSD это не так критично) стоит все-таки отключить COW. Компрессию тоже стоит отключить т.к. это еще сильнее затормозит и без того не быстрое решение. | ||
- | touch /swap # создаем пустой файл /swap - COW можно отключить только на пустом файле | + | touch /swap # создаем пустой файл /swap - COW можно отключить только на пустом файле |
- | chattr +C /swap # отключаем COW, а отключение COW блокирует и возможность компрессии файла | + | chmod go-r /swap # swap должен иметь права 600, а touch проставляет права 644 |
- | truncate -s 4G /swap # создаем пустой файл размером 4Gib | + | chattr +C /swap # отключаем COW |
- | swapfile=$(losetup -f) # находим первое свободное loop-устройство | + | chattr -c /swap # отключаем компрессию файла |
- | losetup $swapfile /swap # настраиваем доступ к файлу /swap через loop-устройство | + | fallocate swap -l4g # выделяем место под файл размером 4Gib |
- | mkswap $swapfile # создаем внутреннюю разметку для swap-а на loop-устройстве | + | swapfile=$(losetup -f) # находим первое свободное loop-устройство |
- | swapon $swapfile # подключаем swap | + | losetup $swapfile /swap # настраиваем доступ к файлу /swap через loop-устройство |
+ | mkswap $swapfile # создаем внутреннюю разметку для swap-а на loop-устройстве | ||
+ | swapon $swapfile # подключаем swap | ||
Для подключения такого swap после перезагрузки добавьте код начиная с swapfile=$(losetup -f) в файл /etc/rc.local (до строки exit 0). | Для подключения такого swap после перезагрузки добавьте код начиная с swapfile=$(losetup -f) в файл /etc/rc.local (до строки exit 0). | ||
+ | |||
+ | <note important>И все же для ядер младше 5.0 предпочтительнее использовать swap на разделе диска.</note> | ||
======Обслуживание btrfs====== | ======Обслуживание btrfs====== | ||
Как и любая другая ФС, btrfs может работать много лет, не требуя какого-то особого обслуживания, однако мы озвучим те действия, которые полезно периодически проводить для поддержания "здоровья" btrfs. | Как и любая другая ФС, btrfs может работать много лет, не требуя какого-то особого обслуживания, однако мы озвучим те действия, которые полезно периодически проводить для поддержания "здоровья" btrfs. |