it-swarm-ru.tech

Зарезервированное место для root в файловой системе - почему?

Я понимаю, что по умолчанию вновь созданные файловые системы будут создаваться с 5% пространства, выделенного для root. Я также знаю, что вы можете изменить определенное пространство с помощью:

tune2fs -m 1 /dev/sdXY

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

Причина, по которой я наткнулся на этот вопрос, заключается в том, что мы недавно создали хранилище файлов объемом 1 ТБ и не могли понять, почему из-за df -h мы упустили 5% нашей емкости.

108
suitedupgeek

Экономия места для важных корневых процессов (и возможных действий по спасению) является одной из причин.

Но есть и другое. Ext3 довольно хорошо избегает фрагментации файловой системы, но как только вы наберете около 95% заполнения, такое поведение сойдет с обрыва, и вдруг производительность файловой системы станет беспорядочной. Таким образом, оставив зарезервированные 5%, вы получите буфер против этого.

Ext4 должен быть лучше в этом, как объяснил разработчик файловой системы Linux/гуру Теодор Цо :

Если вы установите зарезервированное количество блоков равным нулю, это не сильно повлияет на производительность, за исключением случаев, когда вы выполняете в течение длительных периодов времени (с большим количеством файлов, создаваемых и удаляемых), пока файловая система почти заполнена (то есть, скажем, выше 95%), в этот момент вы будете подвержены проблемам фрагментации. Многоблочный распределитель Ext4 гораздо более устойчив к фрагментации, поскольку он пытается гораздо сложнее найти смежные блоки, поэтому даже если вы не включите другие функции ext4, вы увидите лучшие результаты, просто смонтировав файловую систему ext3 с использованием ext4 перед файловой системой. становится полностью полным.

Если вы просто используете файловую систему для долгосрочного архивирования, где файлы меняются не очень часто (например, огромный магазин mp3 или видео), это, очевидно, не будет иметь значения.

106
mattdm

Если вы разрешите другим входить в вашу систему, например, через ssh, резервирование этих 5% блоков гарантирует, что внешние пользователи не смогут заполнить диск. Даже если вы не разрешаете другим входить в вашу систему, зарезервированные блоки не позволяют программам, не запущенным от имени root, заполнить ваш диск.

45
LawrenceC

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

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

5% было по умолчанию в течение long времени, когда диски были намного меньше (десятки мегабайт, а не сотни гигабайт), так что 5% было не так уж много. К счастью, его можно легко уменьшить до меньшего процента, как вы говорите, или установить на определенное количество блоков, если вы используете tune2fs 's -r опция вместо -m. В обоих случаях вы можете задать параметр 0, чтобы полностью отключить резервирование - я бы не стал этого делать для /, /tmp, /var и ​​так далее, но вы можете захотеть использовать файловую систему, которая действует только как пользовательское хранилище (например, глобальный общий файловый ресурс) или систему, которая просто хранит файлы фиксированного размера (например, виртуальные машины фиксированного размера), которые будут расти только при создании новый.

22
David Spillett

Значение по умолчанию 5% предназначено для системных разделов. Например, если ваше дисковое пространство заполняется, система записывает в журнал (/var/log) и почтовый ящик root (/var/mail/root) все еще может получать важную информацию. Для /home или общий раздел хранения данных, нет необходимости оставлять место для root. Для особых нужд вы можете сменить пользователя, который получает аварийное пространство (tune2fs -u 1234).

Есть еще одна причина, по которой файловая система ext [234] не заполняется, - фрагментация .

22
Gilles 'SO- stop being evil'