


Собственно, нередко возникает необходимость запускать нормальную рабочую Ubuntu (а не Live-образ) с флешки: например, если надо таскать систему с собой, или если хочется сделать “безмозглую” рабочую станцию, или в качестве эрзац-SSD для достижения бесшумной работы…да мало ли для чего еще…Вот об этом подробно и повествует материал с Хелп.Юбунту:
Оригинал публикации
Содержание
Довольно часто возникает желание или необходимость поставить Ubuntu на USB флешку и получить возможность пользоваться своей любимой ОС на любом компьютере (лишь бы была возможность загрузиться с USB).
Делается это просто – грузимся с LiveCD Ubuntu (или с LiveUSB) и ставим систему на флешку. При этом нам не важно какая ос установлена на компьютере. Все что нужно это сам компьютер, LiveCD/USB и флешка (на которую будем ставить Ubuntu).
И часто подход к этому вопросу, что называется, «в-лоб» разочаровывает низкой производительностью и тем, что флешка быстро умирает .
Кроме того и сам процесс установки порой приводит к неприятным последствиям.
Но не надо отчаиваться и опускать руки…. Даже из не очень хорошего сырья можно сделать…, если не конфетку, то, по крайней мере, что-то съедобное.
Разберемся в причинах печального исхода и возможных методов улучшения ситуации.
Основные ошибки при установке Ubuntu на USB флешку и как с ними бороться
По умолчанию установщик Ubuntu предлагает журналируемую файловую систему EXT4 для создаваемых разделов данных.
Кроме того, загрузчик (GRUB) по умолчанию ставится на первый диск в системе, как правило, – это встроенный HDD компьютера.
Установщик Ubuntu, довольно настойчиво, просит создать раздел подкачки (если вы его не создаете, то получите сообщение и должны будете подтвердить свое желание установить систему без swap-раздела).
Приняв эти умолчания, мы сразу создаем две проблемы.
-
На флешке создаются разделы с файловой системой, которая при работе будет осуществлять большое количество записей на флешку (чем сократит ее время жизни). Это касается и разделов EXT4 и swap-раздела.
-
Загрузчик установится так, что без флешки ваш компьютер не сможет загрузится.
Разберем подробнее эти две проблемы
Как продлить жизнь флешке
Флеш-память отличается от жестких дисков тем, что количество циклов записи ограничено типично числами 10 и 100 тысяч записей (для разных типов флеш-памяти).
Но и высокая цена флешки тоже не говорит о повышенной жевучести – тут ключевое слово – тип памяти – MLC (Multi-level cell, многоуровневые ячейки памяти) выдерживает порядка 10 тысяч записей; SLC (Single-level cell, одноуровневые ячейки памяти) — более 100 тысяч. Более дорогие флешки действительно живут дольше, но достигается это другими средствами (о них – чуть позже)
Кажется это много, но разберемся как эти циклы записи «съедаются» при работе ОС.
-
Запись на флеш-носитель происходит по-блочно (как правило – десятки килобайт), и запись последовательно двух байт в файл с интервалом между записями в несколько минут вызовет две записи одного и того же блока памяти (т.е. обновятся два раза несколько тысяч ячеек).
-
При работе файловой системы (ФС) некоторые служебные структуры ФС обновляются постоянно:
-
журнал (для журналируемых ФС) – чем чаще он пишется, тем выше вероятность сохранения целостности ФС при сбоях системы или питания. Частота записи в журнал, как правило изменяема, но значения по умолчанию не совсем подходят для работы с флеш-памятью, а увеличение периодов между записью – приводит к увеличению вероятности потери целостности ФС при сбое.
-
i-node (специальная структура в которой сохраняется заголовок файла или каталога) – при каждом обращении (даже чтение) к файлу или каталогу в i-node прописывается дата/время последнего обращения. Казалось бы – всего несколько байт, но вспомним про блочную запись, и том, что запись их идет при каждом обращении к файлу (прочитали байт – изменились, еще байт – опять изменилось).
-
-
Временные файлы и логи – так же часто обновляются.
-
SWAP-раздел – если он используется в работе системы, то запись в него тоже очень интенсивная.
Кроме того, нужно не забывать, что лимит циклов записи действует на каждую ячейку памяти. И если на флешке в один и тот же блок сделать 10 тысяч записей, а в другие сделать по 100 записей, то блок, куда было записано 10 тысяч раз, на записи (10тысяч + сколько-то) «умрет», а контроллер флешки, обнаружив 1 битый блок, может заявить, что умерла вся флешка. А даже если он этого не сделает, то этот блок будет содержать важную для работы системы или ФС информацию, и результат будет практически тем же – внезапная остановка системы и невозможность прочитать данные с флешки.
Как бороться со всем этим?
Для начала поймем и примем как данность:
Осознав это поймем, что и
А поняв и приняв это задумаемся – а нужна ли для такой системы надежность журналируемой ФС (такой дорогой ценой как сокращение времени жизни флешки и системы на ней)?
Однозначно – нет.
Нам потребуется EXT4 с отключенным журналом. Если разбираться с отключением журнал в EXT3/4 не хотите – просто воспользуйтесь EXT2.
Избавиться от записи даты/времени последнего доступа к файлам и директориям в i-node помогают опции монтирования файловых систем noatime и nodiratime. Их, после установки системы, нужно будет прописать в файле /etc/fstab для всех разделов системы, которые расположены на флешке.
Временные файлы и swap.
Современные компьютеры редко страдают недостатком оперативной памяти (перелом в этом отношении случился в компьютерной индустрии после значительного удешевления схем памяти). И уже при 1ГБ оперативной памяти Linux довольно редко обращается к swap, если не запускать ресурсоёмкие задачи (например кодирование высококачественного видео или редактирование огромных изображений). Если памяти 2ГБ или больше, то заставить Linux использовать swap вообще довольно сложно.
Полное отсутствие swap грозит неадекватным поведением системы при исчерпании ресурсов оперативной памяти, но вспомним, что мы с вами осознали – система на USB флешке не может быть надежной по определению. Вывод напрашивается сам собой – swap для системы на флешке – не нужен. А на компьютерах с малым объемом памяти нужно быть осторожным и стараться не запускать много приложений одновременно. Можно так же настроить ramzswap (он же – compcache): своп в оперативную память с упаковкой свопируемых станиц.
Ресурсы оперативной памяти помогут и со временными файлами – достаточно смонтировать временный каталог системы /tmp в диск организованный в памяти. Для этого нам пригодится замечательная файловая система tmpfs (даже название говорит, что она хорошо подходит для /tmp).
В /etc/fstab нужно прописать строчку:
1 |
tmpfs /tmp tmpfs rw,size=32m |
Размер /tmp важно выбрать правильно т.к. в нем будут хранится самые разные вещи. Например видео с Youtube вы не сможете посмотреть до конца если файл с видео не влезет полностью в ваш /tmp.
Точно также стоит поступить и с /run (ранее известный как /var/run) и /var/lock (в этих каталогах хранится служебная информация актуальная только на время текущей сессии, объем – малюсенький, а вот обновления довольно регулярны). На них лимит размера можно не задавать. Можно пойти дальше и разместить в памяти и логи (/var/log), однако без логов на устройстве постоянного хранения данных (в нашем случае – на флешке) будет крайне трудно разобраться со сбоем системы, вызывающем перезагрузку (после перезагрузки – все что было в памяти – потеряется и логи будут «пустые» – только то, что туда запишется с момента загрузки системы). Лимит size для /var/log стоит задавать порядка 6-10Мб (для типичного десктоп варианта).
Общий вид файла /etc/fstab будет примерно таким:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
# /etc/fstab: static file system information. # # Use 'blkid' to print the universally unique identifier for a # device; this may be used with UUID= as a more robust way to name devices # that works even if disks are added and removed. See fstab(5). # # proc /proc proc nodev,noexec,nosuid # / was on /dev/sda2 during installation UUID=57f10d10-de95-4d09-8e18-aaf1c42c3f36 / ext4 errors=remount-ro,noatime,nodiratime 1 # /home was on /dev/sda3 during installation UUID=7ecf4c7b-3474-4850-9da5-6e519e415937 /home ext4 noatime,nodiratime 2 tmpfs /tmp tmpfs rw,size=100m tmpfs /run tmpfs rw tmpfs /var/lock tmpfs rw tmpfs /var/log tmpfs rw,size=10m |
В примере на флешке создан корень и отдельный /home. Если есть еще какие-то разделы с флешки – то им тоже прописываем noatime,nodiratime.
Как правильно ставить GRUB
А тут все просто – загрузчик (GRUB) надо ставить на флешку. Если вы оставите предложенную установщиком установку (на первый жесткий диск в системе) то в MBR жесткого диска пропишется часть кода GRUB, который станет искать остальную часть своего кода на разделе, куда будет записан /boot при установке системы (т.е. на флешке). Вытащив флешку из компьютера вы не дадите коду GRUB-а на жестком диске найти свое продолжение. И компьютер не сможет загрузить ОС. Восстановить работу GRUB – просто. Если же надо восстанавливать загрузчик Windows, то стоит поискать информацию по восстановлению загрузчика на любом профильном форуме. Но лучше быть внимательным при установке, и не создавать себе лишнюю работу.
Подведем итоги
Если мы хотим пользоваться системой на флешке долго, и не получить разочарования от потери данных, то нужно делать так:
-
при установке Ubuntu на флешку:
-
тип ФС для разделов системы выбираем EXT4 с отключенным журналом (или на худой конец – EXT2).
-
swap не создаем (а если на компьютере есть раздел swap – то говорим инсталятору – не использовать его).
-
GRUB устанавливаем обязательно на флешку, где и создаем разделы для установки системы.
-
прописываем в /etc/fstab опции noatime,nodiratime для всех разделов размещенных на флешке.
-
прописываем в /etc/fstab монтирование /tmp, /run, /var/lock (и, возможно, /var/log) в tmpfs (не забываем про ограничение размера).
-
-
При использовании системы нужно регулярно делать резервную копию важных данных на другой носитель (не забываем про невысокую надежность ОС на флешке и возможную внезапную кончину флеш-памяти).
-
А при использовании на компьютере с небольшим объемом оперативной памяти (1Гб и менее) стараемся не запускать по много ресурсоёмких задач одновременно или изучаем и настраиваем ramzswap.
А главное – никогда не забываем про вывод, к которому мы пришли в начале этой статьи. Повторю:ОС, установленная на флешку не может быть такой же надежной и долговечной как установленная на жесткий диск.
Если вы нашли ошибку, пожалуйста, выделите фрагмент текста и нажмите Ctrl+Enter.