The OpenNET Project / Index page

[ новости /+++ | форум | wiki | теги | ]

Поиск:  Каталог документации

Мини-HOWTO: Зацикленная корневая файловая система

Andrew Bishop

amb@gedanken.demon.co.uk

Перевод: Станислав Рогин, SWSoft Pte Ltd.

Версия 1.1, 24 сентября 1999

Этот HOWTO объясняет, как использовать зацикленное (loopback) устройство Linux, чтобы создать файловую систему Linux, которая может запускаться из DOS-раздела без изменения системы разделов. Другое применение этой техники также обсуждается в этом документе.


Содержание
1. Введение
1.1. Copyright
1.2. Авторские права
1.3. История изменений документа
2. Общие принципы зацикленных устройств и электронных дисков (Ramdisks)
2.1. Зацикленные устройства
2.2. Электронные диски
2.3. Загрузочный электронный диск
2.4. Корневая файловая система
2.5. Последовательность загрузки Linux
3. Как создать зацикленное корневое устройство
3.1. Требования
3.2. Создаем ядро Linux
3.3. Создаем загрузочный электронный диск
3.4. Создаем корневое устройство
3.5. Создаем Swap-устройство
3.6. Создаем каталог MSDOS
3.7. Создаем загрузочный флоппи-диск
4. Загрузка системы
4.1. Возможные проблемы и их решение
4.2. Ссылки на другие документы
5. Другие возможности зацикленных корневых устройств
5.1. Установка на DOS-жесткий-диск
5.2. Установка с загрузкой при помощи LILO
5.3. Установка на VFAT / NTFS
5.4. Установка Linux без изменения разделов
5.5. Загрузка с незагружаемого (Non-bootable) устройства

1. Введение

1.1. Copyright

The Loopback Root Filesystem HOWTO Copyright (C) 1998,99 Andrew M. Bishop (amb@gedanken.demon.co.uk).

This documentation is free documentation; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

The GNU General Public License is available from http://www.fsf.org/ or, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111 USA


1.2. Авторские права

Авторские права на русский перевод этого текста принадлежат © 2000 SWSoft Pte Ltd. Все права зарезервированы.

Этот документ является частью проекта Linux HOWTO.

Авторские права на документы Linux HOWTO принадлежат их авторам, если явно не указано иное. Документы Linux HOWTO, а также их переводы, могут быть воспроизведены и распространены полностью или частично на любом носителе, физическом или электронном, при условии сохранения этой заметки об авторских правах на всех копиях. Коммерческое распространение разрешается и поощряется; но, так или иначе, автор текста и автор перевода желали бы знать о таких дистрибутивах.

Все переводы и производные работы, выполненные по документам Linux HOWTO должны сопровождаться этой заметкой об авторских правах. Это делается в целях предотвращения случаев наложения дополнительных ограничений на распространение документов HOWTO. Исключения могут составить случаи получения специального разрешения у координатора Linux HOWTO, с которым можно связаться по адресу приведенному ниже.

Мы бы хотели распространить эту информацию по всем возможным каналам. Но при этом сохранить авторские права и быть уведомленными о всех планах распространения HOWTO. Если у вас возникли вопросы, пожалуйста, обратитесь к координатору проекта Linux HOWTO по электронной почте: , или к координатору русского перевода Linux HOWTO компании SWSoft Pte Ltd. по адресу


1.3. История изменений документа

Версия 1.0.0

Первоначальная версия (Июнь 1998)

Версия 1.0.1-1.0.3

Небольшие изменения, подправки версий ядра, опечаток и т.п. (1998 - Июль 1999)

Версия 1.1

Добавлена информация о Copyright (Сентябрь 1999)


2. Общие принципы зацикленных устройств и электронных дисков (Ramdisks)

Сначала я опишу некоторые общие принципы, используемые при настройке зацикленной файловой системы в качестве корневого устройства.


2.1. Зацикленные устройства

Зацикленное (loopback) устройство Linux - это виртуальное устройство, которое можно использовать так же, как и любой другой носитель информации.

Обычные носители информации - это, например, разделы жесткого диска /dev/hda1, /dev/hda2, /dev/sda1 или полностью диски, как, например, флоппи-диск /dev/fd0 и т.п. Все эти устройства могут содержать в себе файлы и структуры каталогов. Они могут быть отформатированы в формате необходимой файловой системы (ext2fs, msdos, ntfs и т.п.) и затем подключены (mount).

Зацикленная файловая система представляет файл на другой файловой системе как полноценное устройство. Она может быть отформатирована и подключена так же, как и любое другое устройство, описанное выше. Чтобы сделать это, устройства под названиями /dev/loop0, /dev/loop1 и т.п. сопоставляются с файлами, и затем может быть подключено новое виртуальное устройство.


2.2. Электронные диски

В Linux также может использоваться другой тип виртуального устройства, подключаемый как файловая система, под названием электронный диск.

В этом случае, устройство ссылается не на какое-то физическое устройство, а на часть оперативной памяти, выделенной для этой цели. Эта память никогда не сбрасывается в swap на диск, но остается в дисковом кэше.

Электронный диск может быть создан в любой момент путем записи в устройство электронного диска /dev/ram0, /dev/ram1 и т.п. Затем его можно отформатировать и подключить так же, как и зацикленное устройство.

Когда электронный диск используется при загрузке (что часто применяется на инсталляционных дисках Linux или дисках аварийного восстановления), тогда образ диска (полное содержимое диска в виде отдельного файла) может содержаться на загрузочном флоппи-диске в закомпрессированной форме. Эта ситуация автоматически распознается ядром, когда оно загружается, и этот образ разжимается в электронный диск перед его подключением.


2.3. Загрузочный электронный диск

Загрузочный электронный диск Linux - еще один важный механизм, который нам понадобится при использовании зацикленного устройства в качестве корневой файловой системы.

Когда используется загрузочный электронный диск, образ файловой системы загружается в память и подключается для того, чтобы файлы на нем были доступны. Затем запускается программа на этом диске (файл под именем /linuxrc), и, когда она заканчивает работу, другое устройство подключается в виде корневой файловой системы. Старый электронный диск также остается доступен и подключен к каталогу /initrd, если такой каталог присутствует, или может использоваться через устройство /dev/initrd.

Такая необычная процедура необходима потому, что при обычной загрузке система начинает и продолжает загрузку с корневой файловой системы. С загрузочным электронным диском корневая файловая система может быть изменена до начала основной последовательности загрузки Linux.


2.4. Корневая файловая система

Корневая файловая система - это устройство, которое подключается первым, поэтому бывает представлено в виде каталога / после загрузки.

Существует некоторое количество проблем с корневой файловой системой благодаря тому факту, что она содержит все файлы. Когда загрузочные rc-скрипты загружаются, они содержатся в файлах /etc/rc.d или /etc/rc?.d, в зависимости от версии программы /etc/init.

Когда система загрузилась, нельзя отключить корневую файловую систему или изменить ее из-за того, что все программы используют ее тем или иным образом. Вот почему так полезен загрузочный электронный диск, поскольку его можно использовать, чтобы конечная корневая файловая система могла быть отлична от той, которая была в момент начала загрузки.


2.5. Последовательность загрузки Linux

Чтобы понять, как загрузочный электронный диск работает в процессе загрузки системы, изучим порядок событий при загрузке системы.

  1. Ядро загружается в память. Эту операцию производит LILO или LOADLIN. В этот момент выводится сообщение Loading...

  2. Образ электронного диска загружается в память, это тоже делает LILO или LOADLIN. В этот момент также выводится сообщение Loading...

  3. Производится инициализация ядра, включая обработку опций командной строки и подключение электронного диска в виде корневой файловой системы.

  4. На загрузочном электронном диске запускается программа /linuxrc.

  5. Корневое устройство переключается в соответствии с параметром ядра.

  6. Запускается программа /etc/init, которая уже производит настраиваемую пользователем последовательность загрузки.

Это упрощенное описание того, что происходит на самом деле, но этого достаточно, чтобы описать, как запускается ядро и как используется электронный диск.


3. Как создать зацикленное корневое устройство

Теперь, когда все основные принципы объяснены, можно перейти к созданию зацикленного корневого устройства.


3.1. Требования

Создание зацикленного корневого устройства потребует от вас нескольких вещей.

  • Систему с работающим Linux-ом.

  • Способ скопировать большие файлы на DOS-раздел.

Наиболее важно иметь доступ к работающему Linux-у. Это необходимо по причине того, что зацикленное устройство может быть создано только в Linux-е. Это означает, что нельзя создать работающую машину с зацикленной корневой файловой системой из ничего. От этой Linux-системы потребуется возможность собрать на ней ядро.

После создания зацикленное устройство будет представлять из себя большой файл. Я использовал примерно 80 Мб файлов, но этого достаточно только, чтобы сделать Х-терминал, а возможно, если вы захотите чего-то большего, вам потребуется больше места. Этот файл должен быть скопирован на DOS-раздел, то есть придется использовать или сеть, или кучу флоппи-дисков.

Вам также понадобится следующее программное обеспечение:

  • LOADLIN версии 1.6 или новее

  • mount, поддерживающий зацикленные устройства

  • ядро, поддерживающее все необходимые условия.

Это все должно входить в последние инсталляции дистрибутивов Linux.


3.2. Создаем ядро Linux

Я создал зацикленное устройство с использованием ядра версии 2.0.31, другие версии тоже должны работать, но они должны поддерживать все опции, перечисленные ниже.

Опции ядра, которые вам надо будет включить:

  • Поддержка электронных дисков (RAM disk support) (CONFIG_BLK_DEV_RAM).

  • Поддержка загрузочного электронного диска (Initial RAM disk (initrd) support) (CONFIG_BLK_DEV_INITRD).

  • Поддержка зацикленных устройств (Loop device support) (CONFIG_BLK_DEV_LOOP).

  • Поддержка файловой системы FAT (fat fs support) (CONFIG_FAT_FS).

  • Поддержка файловой системы MSDOS (msdos fs support) (CONFIG_MSDOS_FS).

Первые две опции - это сам электронный диск и загрузочный электронный диск. Следующая - это зацикленная файловая система. Последние две - это поддержка файловой системы msdos, которая необходима для подключения DOS-раздела.

Сборка ядра без модулей - это наиболее простой способ, но если вы все-таки решили использовать модули, это возможно, хотя я этого и не пробовал. Если вы используете модули, вы должны убедиться в том, что опции, используемые выше, встроены в ядро, а не собраны в виде модулей.

В зависимости от версии вашего ядра, вам, возможно, придется установить патч к ядру. Это очень простой патч, который разрешает использование зацикленной файловой системы в виде корневой.

  • Ядра версий до 2.0.0 - у меня нет информации по этому поводу.

  • Ядра версий 2.0.0 - 2.0.34 - вам придется использовать патч для ядер 2.0.х, приведенный ниже.

  • Ядра версий 2.0.35 - 2.0.x - патч не требуется.

  • Ядра версий 2.1.x - вам придется использовать патч для ядер 2.0.х или 2.2.х, приведенный ниже, в зависимости от конкретной версии ядра 2.1.x.

  • Ядра версий 2.2.0 - 2.2.10 - вам придется использовать патч для ядер 2.2.х, приведенный ниже.

  • Ядра версий 2.3.x - вам придется использовать патч для ядер 2.2.х, приведенный ниже.

Для ядер версий 2.0.x в файл /init/main.c надо добавить одну строку, в соответствии с уже измененной версией, приведенной ниже. В строке, которую надо добавить написано "loop", 0x0700.

static void parse_root_dev(char * line)
{
	int base = 0;
	static struct dev_name_struct {
		const char *name;
		const int num;
	} devices[] = {
		{ "nfs",     0x00ff },
		{ "loop",    0x0700 },
		{ "hda",     0x0300 },

...

		{ "sonycd",  0x1800 },
		{ NULL, 0 }
	};

...

}

Для ядер версий 2.2.x в файл /init/main.c надо добавить три строки, в соответствии с уже измененной версией, приведенной ниже. Надо добавить строку, в которой написано "loop", 0x0700, а также предшествующую и следующую за ней:

static struct dev_name_struct {
	const char *name;
	const int num;
} root_dev_names[] __initdata = {
#ifdef CONFIG_ROOT_NFS
	{ "nfs",     0x00ff },
#endif
#ifdef CONFIG_BLK_DEV_LOOP
        { "loop",    0x0700 },
#endif
#ifdef CONFIG_BLK_DEV_IDE
	{ "hda",     0x0300 },

...

	{ "ddv", DDV_MAJOR << 8},
#endif
	{ NULL, 0 }
};

После того, как ядро настроено, его необходимо собрать в файл zImage (команда make zImage). Этот файл будет находиться в каталоге arch/i386/boot/zImage.


3.3. Создаем загрузочный электронный диск

Загрузочный электронный диск проще всего создавать, как зацикленное устройство с самого начала. Вы должны делать это в качестве root-а. Список команд, которые вы должны запустить, приведен ниже. Они предполагают запуск из личного каталога root-а (/root).

mkdir /root/initrd
dd if=/dev/zero of=initrd.img bs=1k count=1024
mke2fs -i 1024 -b 1024 -m 5 -F -v initrd.img
mount initrd.img /root/initrd -t ext2 -o loop
cd initrd
[create the files]
cd ..
umount /root/initrd
gzip -c -9 initrd.img > initrdgz.img

Здесь производится несколько действий, которые можно вкратце описать так:

  1. Создаем точку подключения загрузочного электронного диска (пустой каталог).

  2. Создаем пустой файл необходимого размера. Я здесь использовал 1024 Кб, вам может понадобиться меньше или больше, в зависимости от содержимого (размер задается в последней опции).

  3. Создаем файловую систему ext2 в пустом файле.

  4. Подключаем этот файл к точке подключения, с использованием зацикленного устройства.

  5. Переходим ко вновь подключенному зацикленному устройству.

  6. Создадим там все необходимые файлы (см. ниже).

  7. Выходим из подключенного зацикленного устройства.

  8. Отключаем устройство.

  9. Создаем компрессированную версию для дальнейшего использования.

Содержимое загрузочного электронного диска

На загрузочном диске нужно иметь все файлы, необходимые для запуска любых команд:

  • /linuxrc скрипт, который подключает файловую систему msdos (см. ниже).

  • /lib/* система динамических связей (dynamic linker) и библиотеки, необходимые программам.

  • /etc/* Кэш, используемый системой динамических связей (не очень нужен, но после этого перестают выдаваться жалобные сообщения).

  • /bin/* Интерпретатор оболочки (shell) (ash, потому что он меньше размером, чем bash. Программыmount и losetup для работы с DOS-диском и настройки зацикленных устройств.

  • /dev/* Устройства, которые будут использоваться. Вам потребуется устройство /dev/zero для библиотеки ld-linux.so, /dev/hda* для подключения msdos-диска и /dev/loop* для зацикленных устройств.

  • /mnt Пустой каталог для подключения msdos-диска.

Содержимое загрузочного электронного диска, которое я использовал, приведено ниже. Оно заняло примерно 800 Кб, если принимать в расчет излишки файловой системы.

total 18
drwxr-xr-x   2 root     root         1024 Jun  2 13:57 bin
drwxr-xr-x   2 root     root         1024 Jun  2 13:47 dev
drwxr-xr-x   2 root     root         1024 May 20 07:43 etc
drwxr-xr-x   2 root     root         1024 May 27 07:57 lib
-rwxr-xr-x   1 root     root          964 Jun  3 08:47 linuxrc
drwxr-xr-x   2 root     root        12288 May 27 08:08 lost+found
drwxr-xr-x   2 root     root         1024 Jun  2 14:16 mnt

./bin:
total 168
-rwxr-xr-x   1 root     root        60880 May 27 07:56 ash
-rwxr-xr-x   1 root     root         5484 May 27 07:56 losetup
-rwsr-xr-x   1 root     root        28216 May 27 07:56 mount
lrwxrwxrwx   1 root     root            3 May 27 08:08 sh -> ash

./dev:
total 0
brw-r--r--   1 root     root       3,   0 May 20 07:43 hda
brw-r--r--   1 root     root       3,   1 May 20 07:43 hda1
brw-r--r--   1 root     root       3,   2 Jun  2 13:46 hda2
brw-r--r--   1 root     root       3,   3 Jun  2 13:46 hda3
brw-r--r--   1 root     root       7,   0 May 20 07:43 loop0
brw-r--r--   1 root     root       7,   1 Jun  2 13:47 loop1
crw-r--r--   1 root     root       1,   3 May 20 07:42 null
crw-r--r--   1 root     root       5,   0 May 20 07:43 tty
crw-r--r--   1 root     root       4,   1 May 20 07:43 tty1
crw-r--r--   1 root     root       1,   5 May 20 07:42 zero

./etc:
total 3
-rw-r--r--   1 root     root         2539 May 20 07:43 ld.so.cache

./lib:
total 649
lrwxrwxrwx   1 root     root           18 May 27 08:08 ld-linux.so.1 -> ld-linux.so.1.7.14
-rwxr-xr-x   1 root     root        21367 May 20 07:44 ld-linux.so.1.7.14
lrwxrwxrwx   1 root     root           14 May 27 08:08 libc.so.5 -> libc.so.5.3.12
-rwxr-xr-x   1 root     root       583795 May 20 07:44 libc.so.5.3.12

./lost+found:
total 0

./mnt:
total 0

Единственным сложным пунктом здесь являются устройства в каталоге dev. Используйте команду mknod, чтобы создать эти устройства, или используйте устройства в каталоге /dev, как шаблон для необходимых устройств.

Файл /linuxrc

Файл/linuxrc на загрузочном электронном диске нужен для того, чтобы произвести все приготовления, необходимые для подключения зацикленного устройства как корневого.

Скрипт, приведенный ниже пытается подключить /dev/hda1 как раздел msdos, и если это происходит удачно, то он настраивает файлы /linux/linuxdsk.img как /dev/loop0 и /linux/linuxswp.img как /dev/loop1.

#!/bin/sh

echo INITRD: Trying to mount /dev/hda1 as msdos
# echo INITRD: Попытка подключить /dev/hda1 как msdos

if /bin/mount -n -t msdos /dev/hda1 /mnt; then

   echo INITRD: Mounted OK
   # echo INITRD: Подключение  успешно
   /bin/losetup /dev/loop0 /mnt/linux/linuxdsk.img
   /bin/losetup /dev/loop1 /mnt/linux/linuxswp.img
   exit 0

else

   echo INITRD: Mount failed
   # echo INITRD: Подключение не удалось
   exit 1

fi

Первое устройство /dev/loop0 станет корневым, а второе - /dev/loop1 - станет swap-пространством.

Если вы хотите иметь возможность писать на DOS-раздел, не будучи root-ом, когда все будет завершено, то вы должны использовать команду mount -n -t msdos /dev/hda1 /mnt -o uid=0,gid=0,umask=000,quiet, вместо приведенной выше. В этом режиме доступ к DOS-разделу буду исполняться так, как будто это делает root.


3.4. Создаем корневое устройство

Корневое устройство, которое вы будете использовать - это файл linuxdsk.img. Его вам придется создать самим так же, как вы создавали загрузочный электронный диск, но значительно большего размера. Вы можете установить любой дистрибутив Linux, который вам понравится, на этот диск.

Наиболее простой путь для этого - скопировать существующую инсталляцию Linux в этот файл. Другой путь - установить туда Linux с дистрибутива. Предполагая, что вы это сделали, внесем некоторые незначительные изменения.

Файл /etc/fstab должен ссылаться на корневой раздел и swap-пространство через два зацикленных устройства, настроенных загрузочным электронным диском.

/dev/loop0     /      ext2   defaults 1 1
/dev/loop1     swap   swap   defaults 1 1

Таким образом, вы будете уверены в том, что ядро не ошибется относительно реального местоположения корневой файловой системы. Также swap-пространство будет организовано обычным образом так, как будто используется обычный swap-раздел. Вы должны удалить все строки, ссылающиеся на корневое файловое устройство или swap-раздел.

Если хотите иметь возможность читать DOS-раздел под Linux-ом? вам придется внести еще несколько небольших изменений.

Создайте каталог /initrd, куда будет подключен загрузочный электронный диск после подключения зацикленной корневой файловой системы.

Создайте символьную ссылку /DOS, которая будет указывать на /initrd/mnt, куда, в свою очередь, будет подключен реальный DOS-раздел.

Добавьте строку в rc-файл, которая будет подключать диски. Там должна быть команда mount -f -t msdos /dev/hda1 /initrd/mnt, которая создаст 'поддельное' подключение DOS-раздела, чтобы программы (например, df) знали, что DOS-раздел подключен, и где его найти. Если вы использовали другие опции в файле /linuxrc, то, очевидно, вам придется их использовать и здесь.

Нет необходимости в том, чтобы иметь ядро Linux на этом корневом зацикленном устройстве, так как оно загружено ранее. Если вы используете модули, можете включить их в это устройство обычным образом.


3.5. Создаем Swap-устройство

Swap-устройство, которое вы будете использовать - это файл linuxswap.img. Swap-устройство очень просто создать. Создайте пустой файл так же, как делали это для загрузочного электронного диска, и затем запустите mkswap linuxswap.img для его инициализации.

Размер swap-устройства, которое вы будете использовать, зависит от ваших планов по использованию новой системы, но я бы рекомендовал его от 8 Мб до размера вашей оперативной памяти.


3.6. Создаем каталог MSDOS

Файлы, которые будут нами использоваться, необходимо переписать на DOS-раздел.

В DOS-каталоге C:\LINUX должны находиться следующие файлы:

  • LINUXDSK.IMG Образ диска, который станет корневой файловой системой.

  • LINUXSWP.IMG Swap-пространство.


3.7. Создаем загрузочный флоппи-диск

Загрузочный флоппи-диск, который мы будем использовать, является простым загрузочным диском DOS.

Он создается командой DOS format a: /s.

На этом диске вам надо создать файл AUTOEXEC.BAT (пример приведен ниже) и скопировать туда ядро, компрессированный загрузочный электронный диск и программу LOADLIN.

  • AUTOEXEC.BAT Автоматически запускаемый командный файл DOS.

  • LOADLIN.EXE Программа LOADLIN.

  • ZIMAGE Ядро Linux.

  • INITRDGZ.IMG Компрессированный образ загрузочного электронного диска.

В файле AUTOEXEC.BAT должна быть только одна строка.

\loadlin \zImage initrd=\initrdgz.img root=/dev/loop0 ro

Здесь указано, какой образ ядра использовать, какой образ загрузочного электронного диска использовать, а также корневая файловая система, которая должна быть подключена "только для чтения".


4. Загрузка системы

Для загрузки нового корневого устройства необходимо, чтобы флоппи-диск, описанный выше, был вставлен в компьютер при его загрузке.

Вы увидите следующую последовательность событий.

  1. Загрузка DOS

  2. Запуск AUTOEXEC.BAT

  3. Запуск LOADLIN

  4. Загрузка в память ядра Linux

  5. Загрузка в память загрузочного электронного диска

  6. Запуск ядра Linux

  7. Запуск файла /linuxrc с загрузочного электронного диска

  8. Подключение DOS-раздела и настройка корневого и swap-устройств

  9. Последовательность загрузки продолжается с зацикленного устройства

Когда все это пройдет, вы можете убрать флоппи-диск и использовать Linux.


4.1. Возможные проблемы и их решение

Существует ряд причин, по которым что-то в этом процессе идет не так. Я попытаюсь объяснить, в чем они заключаются, и что необходимо проверить.

Загрузку DOS легко узнать по сообщению MS-DOS Starting ... на экране. Если его нет, то диск либо не является загружаемым, либо сам компьютер не может загрузиться с этого дисковода.

Когда запускается файл AUTOEXEC.BAT, то команды, входящие в него, выводятся на экран. В нашем случае, это одна строка, содержащая запуск LOADLIN.

Когда загружается LOADLIN, то он выводит две очень хорошо заметные строки, сначала он загрузит ядро в память, затем также будет загружать загрузочный электронный диск. Обе этих загрузки сопровождаются сообщением Loading....

Когда ядро декомпрессирует себя, оно может выдать сообщение о crc-ошибках, если ядро повреждено. Затем начнется инициализационная последовательность, которая содержит очень много диагностических сообщения. Загрузка в память загрузочного электронного диска также видна на этой фазе.

Когда запускается файл /linuxrc, тогда нет диагностических сообщения, но их вы можете добавить сами для того, чтобы помочь себе в поисках причин возможных проблем. Если на этой фазе не удается настроить зацикленное устройство, вы увидите сообщение о том, что "Не найдено корневое устройство (No root device)", и ядро прекратит работу.

Затем должна продолжиться нормальная последовательность загрузки уже с новой корневой файловой системой, и она также насыщена сообщениями. Могут появиться проблемы типа "Корневое устройство подключено в режиме чтение/запись", но с этим должна справиться опция 'ro' команды LOADLIN. Другая проблема, которая может возникнуть - это вопрос о реальном местоположении корневой файловой системы, это возникнет, возможно, из-за проблем с файлом /etc/fstab.

Когда последовательность загрузки закончится, может возникнуть проблема, состоящая в том, что некоторые программы не очень хорошо понимают, подключен ли DOS-раздел. Поэтому я советую использовать "поддельную" команды mount, описанную выше. Она значительно упростит жизнь, если вы хотите использовать файлы на DOS-устройстве.


4.2. Ссылки на другие документы

При создании моей первой зацикленной корневой файловой системы я использовал следующие источники информации:

  • Исходные тексты ядра Linux, в особенности init/main.c

  • Документацию к ядру Linux, в особенности Documentation/initrd.txt и Documentation/ramdisk.txt.

  • Документацию LILO.

  • Документацию LOADLIN.


5. Другие возможности зацикленных корневых устройств

Мы подробно описали возможность загрузки корневой файловой системы из DOS-раздела, но существует много других вещей, которые вы можете сделать.


5.1. Установка на DOS-жесткий-диск

Если возможно загрузить Linux из файла на жестком диске с раздела DOS, используя загружаемый флоппи, то, очевидно, возможно загрузить его и с самого жесткого диска.

Для того, чтобы загрузить LOADLIN из AUTOEXEC.BAT. можно использовать загрузочное меню. Этот способ значительно ускоряет загрузку, а в остальном совершенно идентичен вышеописанному.


5.2. Установка с загрузкой при помощи LILO

Использование LOADLIN - это только один способ загрузки ядра Linux. Существует также LILO, которое делает то же самое, но без использования DOS.

В этом случае DOS-флоппи диск можно заменить на диск, отформатированный как ext2fs. Остальные детали очень похожи потому, что ядро и загрузочный электронный диск - это файлы на этом флоппи-диске.

Одна из причин, по которой я использовал LOADLIN - это то, что параметры, передаваемые LILO, немного сложнее. И еще очевидна причина, что обычный пользователь сможет узнать, что записано на диске, находясь в DOS-е.


5.3. Установка на VFAT / NTFS

Я использовал этот метод и с NTFS, и у меня не возникло никаких проблем. Драйвер файловой системы NTFS не входит в стандартную поставку ядра версий 2.0.x, но доступен в виде патча по адресу http://www.informatik.hu-berlin.de/~loewis/ntfs/. В версиях 2.2.x драйвер NTFS включен в стандартную поставку ядра.

Единственное изменение, касающееся VFAT или NTFS, должно быть внесено в загрузочный электронный диск, а конкретнее, в файл /linuxrc: при подключении файловой системы необходимо указать тип файловой системы vfat или ntfs, вместо msdos.

Я не знаю причин, по которым это не должно работать в разделе VFAT.


5.4. Установка Linux без изменения разделов

Процесс установки Linux на компьютер со стандартного дистрибутива предполагает загрузку с флоппи-диска и изменение структуры разделов диска. Вместо этого можно создать загружаемый флоппи-диск, который создаст пустое зацикленное устройство и swap-файл. После этого установка может быть продолжена обычным образом, просто система будет установлена в зацикленное устройство вместо раздела.

Этот метод может быть альтернативой установке в раздел UMSDOS - он значительно более эффективен в использовании дискового пространства, так как минимальный размер кластера в файловой системе ext2 - 1 Кб, а в DOS он достигает 32 Кб. Его можно использовать и на дисках VFAT и NTFS, которые сами по себе являются проблемой :-).


5.5. Загрузка с незагружаемого (Non-bootable) устройства

Вышеописанный метод можно также использовать для загрузки Linux-а с устройства, которое обычно не является загружаемым.

  • CD-Rom

  • Zip-диски

  • Диски на параллельном порте

Очевидно, что и многие другие устройства могут быть использованы также. Корневые файловые системы NFS включены в ядро в виде опции, но этот способ может быть использован в качестве альтернативы.




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру