Библиотека сайта rus-linux.net
Администрирование систем Linux. Файловые системы
Оригинал: File systemsАвтор: Paul Cobbaut
Дата публикации: 12 марта 2015 г.
Перевод: A. Панин
Дата перевода: 29 марта 2015 г.
Глава 6. Файловые системы
После того, как вы закончите разделение жесткого диска на разделы, вы сможете создать файловую систему
в каждом из созданных разделов.
В данной главе используются разделы жесткого диска
, созданные в предыдущей главе, причем сама глава содержит информацию, необходимую для подготовки к чтению следующей главы, в которой мы будем монтировать
созданные файловые системы.
6.1. Информация о файловых системах
Файловая система является способом организации файлов в рамках вашего раздела жесткого диска. Помимо сохранения данных в рамках файлов файловые системы обычно позволяют использовать директории
и механизм контроля доступа
, кроме того, они сохраняют метаданные, относящиеся к файлам, такие, как метки времени доступа и модификации, а также данные о владельце.
Ограничения имен файлов (максимальная длина, набор допустимых символов, ) определяются типом выбранной вами файловой системы. Директории обычно реализуются с помощью файлов специального типа и вам предстоит разобраться в вопросах их реализации! Механизм доступа к файлам оперирует идентификаторами пользователей, владеющих файлами (а также идентификаторами групп пользователей, владеющих файлами и учитывает членство пользователей в группах) с учетом одного или большего количества списков контроля доступа.
6.1.1. Страница руководства man fs
Страница руководства, посвященной файловым системам, может быть открыта с помощью команды man fs
.
[root@rhel65 ~]# man fs
6.1.2. Файл /proc/filesystems
Ядро Linux проинформирует вас о загруженных на данный момент драйверах файловых систем с помощью файла /proc/filesystems
.
root@rhel53 ~# cat /proc/filesystems | grep -v nodev ext2 iso9660 ext3
6.1.3. Файл /etc/filesystems
Файл /etc/filesystems
содержит список автоматически определенных файловых систем (на случай использования утилиты mount
без параметра -t
).
Информация о данном файле содержится на странице руководства, которая может быть открыта с помощью команды man mount
.
[root@rhel65 ~]# man mount
6.2. Часто используемые файловые системы
6.2.1. Файловые системы ext2 и ext3
В прошлом наиболее часто используемой файловой системой в Linux была файловая система ext2
("вторая расширенная файловая система"). Недостаток данной файловой системы заключался в значительных затратах времени на ее проверку.
Впоследствии на большинстве машин, работающих под управлением Linux, файловая система ext2
была заменена на файловую систему ext3
. По большей части данные файловые системы идентичны, за исключением функции журналирования
, которая присутствует только в файловой системе ext3.
Функция журналирования подразумевает запись всех изменений в файловой системе в первую очередь в журнал, расположенный на диске. Периодически осуществляемая синхронизация журнала с диском приводит к записи изменений в файловую систему. Функция журналирования позволяет поддерживать файловую систему в корректном состоянии, поэтому вам не придется осуществлять полную проверку файловой системы после некорректного выключения компьютера или проблем с питанием.
6.2.2. Создание файловых систем ext2 и ext3
Вы можете создать данные файловые системы с помощью утилит /sbin/mkfs
и /sbin/mke2fs
. Используйте команду mke2fs -j
для создания файловой системы ext3.
Также вы можете преобразовать файловую систему ext2 в ext3 с помощью команды tune2fs -j
. При этом вы можете смонтировать файловую систему ext3 как ext2, но в этом случае вы потеряете функцию журналирования. Не забывайте о необходимости выполнения команды mkinitrd
в том случае, если устройство с данной файловой системой должно использоваться в процессе загрузки системы.
6.2.3. Файловая система ext4
Новейшим воплощением расширенной файловой системы является файловая система ext4
, код для поддержки которой включен в состав ядра Linux в 2008 году. Файловая система ext4
поддерживает файлы большего размера (до 16 терабайт), а также позволяет создавать файловые системы на разделах больших размеров, чем в случае файловой системы ext3
(кроме того, она предоставляет множество дополнительных возможностей).
Процесс разработки данной файловой системы начался с доработки файловой системы ext3 с целью полной поддержки 64-битных операций. После того, как выяснилось, что в код должны быть внесены значительные изменения, разработчики приняли решение о присвоении созданной в итоге файловой системе имени ext4
.
6.2.4. Файловая система xfs
Файловая система xfs
используется по умолчанию в дистрибутиве Redhat Enterprise Linux 7. Это хорошо масштабируемая высокопроизводительная файловая система.
Файловая система xfs
была создана специально для операционной системы Irix
и в течение нескольких лет также использовалась в операционной системе FreeBSD. Она поддерживается ядром Linux, но редко используется в дистрибутивах, не имеющих отношения к дистрибутивам Redhat/CentOS.
6.2.5. Файловая система vfat
Файловая система vfat
существует в нескольких форматах: fat12
для дискет, fat16
для операционной системы ms-dos
и fat32
для поддержки дисков большего объема. Реализация файловой системы vfat
из состава ядра Linux поддерживает все упомянутые форматы, но при этом в данной реализации отсутствует поддержка ряда возможностей, таких, как механизм контроля доступа и ссылки на файлы. Диски с файловой системой fat
могут читаться средствами любой операционной системы и широко используются в цифровых камерах и накопителях с интерфейсом USB, причем данная файловая система очень удобна для осуществления обмена данными между операционными системами, установленными на компьютере домашнего пользователя.
6.2.6. Файловая система iso 9660
Файловая система iso 9660
является стандартной файловой системой для оптических дисков CD-ROM. Высока вероятность того, что вы также встретите данную файловую систему на вашем жестком диске в форме образов дисков CD-ROM (которые обычно имеют расширение .iso). Стандарт iso 9660
ограничивает длину имен файлов форматом 8.3. Это ограничение было воспринято негативно в мире Unix, в результате чего в стандарт было добавлено расширение Rock Ridge
, позволяющее использовать имена файлов длиной в 255 символов, режимы доступа и идентификаторы владельцев файлов в стиле Unix, а также символьные ссылки. Другим расширением для стандарта iso 9660
являются расширение Joliet
, которое добавляет возможность использования до 64 символов Unicode в именах файлов. Расширение El Torito
также относится к стандарту iso 9660
и позволяет осуществлять загрузку системы с дисков CD-ROM.
6.2.7. Файловая система udf
При создании большинства оптических дисков (включая диски CD и DVD) в настоящее время используется файловая система udf
, название которой расшифровывается как Universal Disk Format (универсальный дисковый формат).
6.2.8. Файловая система swap
Если принимать во внимание все детали, swap не является файловой системой. Но для использования раздела в качестве раздела подкачки
он должен быть отформатирован и смонтирован как пространство для хранения данных подкачки.
6.2.9. Файловая система gfs
Кластеры на основе Linux обычно используют отдельную кластерную файловую систему, такую, как GFS, GFS2, ClusterFS,
6.2.10. Другие файловые системы...
В более старых системах Linux вы можете встретить файловую систему reiserfs
. Также не исключено, что вы столкнетесь с файловой системой zfs
, разработанной в компании Sun, или открытой файловой системой btrfs
. Для описания возможностей последней, скорее всего, потребуется отдельная глава.
6.2.11. Файл /proc/filesystems
Файл /proc/filesystems
содержит список поддерживаемых файловых систем. В момент монтировании файловой системы без явного указания ее типа утилита mount в первую очередь попытается идентифицировать файловую систему как одну из файловых систем, описанных в файле /etc/filesystems
, после чего в случае необходимости попытается идентифицировать эту же файловую систему как одну из файловых систем, описанных в файле /proc/filesystems
за исключением тех, для которых установлена метка nodev
. В том случае, если в последней строке файла /etc/filesystems
расположен только символ звездочки (*), будут использоваться оба упомянутых файла.
paul@RHELv4u4:~$ cat /proc/filesystems nodev sysfs nodev rootfs nodev bdev nodev proc nodev sockfs nodev binfmt_misc nodev usbfs nodev usbdevfs nodev futexfs nodev tmpfs nodev pipefs nodev eventpollfs nodev devpts ext2 nodev ramfs nodev hugetlbfs iso9660 nodev relayfs nodev mqueue nodev selinuxfs ext3 nodev rpc_pipefs nodev vmware-hgfs nodev autofs paul@RHELv4u4:~$
6.3. Создание файловой системы в разделе
На данный момент у нас в распоряжении имеется недавно созданный раздел жесткого диска. Список системных бинарных файлов, предназначенных для создания файловых систем, может быть сформирован с помощью утилиты ls.
[root@RHEL4b ~]# ls -lS /sbin/mk* -rwxr-xr-x 3 root root 34832 апр 24 2006 /sbin/mke2fs -rwxr-xr-x 3 root root 34832 апр 24 2006 /sbin/mkfs.ext2 -rwxr-xr-x 3 root root 34832 апр 24 2006 /sbin/mkfs.ext3 -rwxr-xr-x 3 root root 28484 окт 13 2004 /sbin/mkdosfs -rwxr-xr-x 3 root root 28484 окт 13 2004 /sbin/mkfs.msdos -rwxr-xr-x 3 root root 28484 окт 13 2004 /sbin/mkfs.vfat -rwxr-xr-x 1 root root 20313 апр 10 2006 /sbin/mkinitrd -rwxr-x--- 1 root root 15444 окт 5 2004 /sbin/mkzonedb -rwxr-xr-x 1 root root 15300 май 24 2006 /sbin/mkfs.cramfs -rwxr-xr-x 1 root root 13036 май 24 2006 /sbin/mkswap -rwxr-xr-x 1 root root 6912 май 24 2006 /sbin/mkfs -rwxr-xr-x 1 root root 5905 авг 3 2004 /sbin/mkbootdisk [root@RHEL4b ~]#
Самое время прочитать страницы руководств утилит mkfs
и mke2fs
. С помощью приведенного ниже примера вы можете проследить процесс создания файловой системы ext2
в разделе, представленном файлом устройства /dev/sdb1. В реальной жизни вам также могут понадобиться такие параметры данной утилиты, как -m0 и -j.
root@RHELv4u2:~# mke2fs /dev/sdb1 mke2fs 1.35 (28-Feb-2004) Filesystem label= OS type: Linux Block size=1024 (log=0) Fragment size=1024 (log=0) 28112 inodes, 112420 blocks 5621 blocks (5.00%) reserved for the super user First data block=1 Maximum filesystem blocks=67371008 14 block groups 8192 blocks per group, 8192 fragments per group 2008 inodes per group Superblock backups stored on blocks: 8193, 24577, 40961, 57345, 73729 Writing inode tables: done Writing superblocks and filesystem accounting information: done This filesystem will be automatically checked every 37 mounts or 180 days, whichever comes first. Use tune2fs -c or -i to override
6.4. Настройка файловой системы
Вы можете использовать утилиту tune2fs
для вывода списка параметров файловой системы и установки их значений. В первом примере показана методика вывода информации о зарезервированном для пользователя root пространстве в рамках раздела (текущее значение равно пяти процентам от общего размера раздела).
[root@rhel4 ~]# tune2fs -l /dev/sda1 | grep -i "block count" Block count: 104388 Reserved block count: 5219 [root@rhel4 ~]#
А в примере ниже данное значение увеличивается до 10 процентов от общего размера раздела. Вы можете использовать утилиту tune2fs в процессе эксплуатации файловой системы, даже в том случае, если данная файловая система содержит корневую директорию (как в примере ниже).
[root@rhel4 ~]# tune2fs -m10 /dev/sda1 tune2fs 1.35 (28-Feb-2004) Setting reserved blocks percentage to 10 (10430 blocks) [root@rhel4 ~]# tune2fs -l /dev/sda1 | grep -i "block count" Block count: 104388 Reserved block count: 10430 [root@rhel4 ~]#
6.5. Проверка файловой системы
Команда fsck
позволяет задействовать утилиту-обертку, используемую для вызова утилит, осуществляющих проверку файловых систем.
[root@RHEL4b ~]# ls /sbin/*fsck* /sbin/dosfsck /sbin/fsck /sbin/fsck.ext2 /sbin/fsck.msdos /sbin/e2fsck /sbin/fsck.cramfs /sbin/fsck.ext3 /sbin/fsck.vfat [root@RHEL4b ~]#
Значение из последнего столбца файла /etc/fstab
используется в качестве флага проверки файловой системы в процессе загрузки операционной системы.
[paul@RHEL4b ~]$ grep ext /etc/fstab /dev/VolGroup00/LogVol00 / ext3 defaults 1 1 LABEL=/boot /boot ext3 defaults 1 2 [paul@RHEL4b ~]$
Проверка смонтированной файловой системы в ручном режиме приведет к выводу предупреждения и завершению работы утилиты fsck.
[root@RHEL4b ~]# fsck /boot fsck из util-linux 2.25.2 e2fsck 1.42.11 (09-Jul-2014) /dev/sda1 is mounted. e2fsck: Cannot continue, aborting.
Но после размонтирования файловой системы ext2 утилиты fsck и e2fsck
могут успешно использоваться для ее проверки.
[root@RHEL4b ~]# fsck /boot fsck из util-linux 2.25.2 e2fsck 1.42.11 (09-Jul-2014) /boot: clean, 44/26104 files, 17598/104388 blocks [root@RHEL4b ~]# fsck -p /boot fsck из util-linux 2.25.2 /boot: clean, 44/26104 files, 17598/104388 blocks [root@RHEL4b ~]# e2fsck -p /dev/sda1 /boot: clean, 44/26104 files, 17598/104388 blocks
6.6. Практическое задание: файловые системы
-
1. Выведите список файловых систем, известных вашей операционной системе.
-
2. Создайте файловую систему
ext2
в разделе размером в 200 МБ. -
3. Создайте файловую систему
ext3
в одном из логических разделов размером в 300 МБ. -
4. Создайте файловую систему
ext4
в разделе размером в 400 МБ. -
5. Установите размер резервируемого пространства для пользователя root в разделе с файловой системой ext3 равным 0 процентов от общего размера раздела.
-
6. Проверьте корректность выполненных действий с помощью утилит
fdisk
иdf
. -
7. Выполните проверки всех недавно созданных файловых систем.
6.7. Корректная процедура выполнения практического задания: файловые системы
-
1. Выведите список файловых систем, известных вашей операционной системе.
-
man fs cat /proc/filesystems cat /etc/filesystems (не во всех дистрибутивах Linux)
-
2. Создайте файловую систему
ext2
в разделе размером в 200 МБ. -
mke2fs /dev/sdc1
(замените sdc1 на корректное имя файла устройства, представляющего необходимый раздел жесткого диска) -
3. Создайте файловую систему
ext3
в одном из логических разделов размером в 300 МБ. -
mke2fs -j /dev/sdb5
(замените sdb5 на корректное имя файла устройства, представляющего необходимый раздел жесткого диска) -
4. Создайте файловую систему
ext4
в разделе размером в 400 МБ. -
mkfs.ext4 /dev/sdb1
(замените sdb1 на корректное имя файла устройства, представляющего необходимый раздел жесткого диска) -
5. Установите размер резервируемого пространства для пользователя root в разделе с файловой системой ext3 равным 0 процентов от общего размера раздела.
-
tune2fs -m 0 /dev/sdb5
-
6. Проверьте корректность выполненных действий с помощью утилит
fdisk
иdf
. -
Использование утилиты mkfs (mke2fs) не должно стать причиной принципиальных различий в выводе предложенных для осуществления диагностики утилит.
В то же время, принципиальные различия проявятся в следующей главе, посвященной монтированию файловых систем.
-
7. Выполните проверки всех недавно созданных файловых систем.
-
fsck /dev/sdb1 fsck /dev/sdc1 fsck /dev/sdb5
Предыдущий раздел: | Оглавление | Следующий раздел: |
Глава 5. Разделы жестких дисков | Глава 7. Монтирование файловых систем |