tmpfs (Русский)
tmpfs - это временная файловая система, которая находится в памяти и/или вашем разделе(ах) подкачки, в зависимости от того, насколько вы её заполнили. Монтирование каталогов как TMPFS - это эффективный способ ускорения доступа к своим файлам. Также это полезно, если вам нужно, чтобы содержимое каталогов автоматически удалялось при перезагрузке.
Использование
Некоторые каталоги, где TMPFS обычно используются: /tmp, /var/lock и /var/run. Не используйте его на /var/tmp, так как этот каталог предназначен для временных файлов, которые сохраняются после перезагрузки.
Arch использует tmpfs в каталоге /run
, с симлинками для совместимости /var/run
и /var/lock
. Он также используется для /tmp
в настройках по умолчанию Systemd и не требует записи в fstab, если не требуется конкрентная настройка.
glibc 2.2 и выше ожидает что /dev/shm
будет смонтирован tmpfs для
POSIX разделяемой памяти. Монтирование /dev/shm
в tmpfs выполняется автоматически systemd, поэтому ручная настройка в fstab больше не требуется.
Как правило, интенсивные задачи и программы ввода/вывода, которые выполняют частые операции чтения/записи могут получить пользу используя каталог TMPFS. Некоторые приложения могут даже получить существенную выгоду, снимая нагрузку некоторых (или всех) своих данных на общую память. Например, перемещение профиля Firefox в оперативную память показывает значительное улучшение производительности.
Примеры
По умолчанию раздел TMPFS имеет максимальный размер устанавленный от половины всей вашей оперативной памяти, но это можно настроить. Обратите внимание, что фактическое потребление памяти/подкачки зависит от того, на сколько вы заполните её, так как разделы TMPFS не потребляют память до тех пор, пока это будет на самом деле необходимо.
Чтобы точно установить максимальный размер, в данном примере, чтобы переопределить значение по умолчанию для монтирования /tmp
, используем опцию монтирования size
:
/etc/fstab
tmpfs /tmp tmpfs nodev,nosuid,size=2G 0 0
Limiting the size, and specifying uid and gid + mode is very secure. For more information on this subject, follow the links listed in the #Смотрите также section.
Вот более сложный пример, показывающий, как добавить монтирование TMPFS для пользователей. Это полезно для веб-сайтов, MySQL TMP файлов, ~/.vim/
, и многое другое. Очень важно, попытаться получить идеальные параметры монтирования для того, что вы пытаетесь достичь. Цель состоит в том, чтобы получить безопасные параметры, насколько это возможно, чтобы предотвратить повышенное использование. Будет безопасным ограничить размер, указать Uid и GID + mode. Для получения дополнительной информации по этому вопросу, пройдите по ссылкам перечисленным в секции #Смотрите также.
/etc/fstab
tmpfs /www/cache tmpfs rw,size=1G,nr_inodes=5k,noexec,nodev,nosuid,uid=648,gid=648,mode=1700 0 0
Смотрите справочную страницу mount
для получения дополнительной информации. Полезная опция монтирования из справочной страницы является опция default
. По крайней мере понятная.
Перезагрузитесь, для того чтобы изменения вступили в силу. Обратите внимание, что может быть заманчивым, выполнить mount -a
, чтобы сделанные изменения вступили в силу немедленно, это сделает недоступными какие-либо файлы, которые в настоящее время находятся в этих каталогах (например, особенно проблематично для запуска программ с файлами блокировки). Тем не менее, если все они пусты, она должна быть безопасной для запуска mount -a
, вместо перезагрузки (или смонтируйте их в индивидуальном порядке).
После применения изменений, вы можете убедиться в том, что они вступили в силу, посмотрев в /proc/mounts
и используя findmnt
:
$ findmnt --target /tmp
TARGET SOURCE FSTYPE OPTIONS /tmp tmpfs tmpfs rw,nosuid,nodev,relatime
TMPFS также может быть временно изменен, без необходимости в перезагрузке, например, когда в ближайшее время необходимо выполнить большую работу компиляции. В этом случае вы можете запустить:
# mount -o remount,size=4G,noatime /tmp
Отключить автоматическое монтирование
Systemd, может автоматически устанавливать /tmp
как tmpfs, даже если у вас нет записи в вашем /etc/fstab
.
Для отключения автоматического монтирования, выполните следующую команду:
# systemctl mask tmp.mount
Файлы больше не будут хранится в tmpfs, но будут на вашем блочном устройстве.
Содержание /tmp
теперь будет сохранятся между перезагрузками, чего вам бы не хотелось.
Чтобы сохранить прежнее поведение и очищать каталог /tmp
атоматически когда вы перезагружаете машину, рассмотрите возможность использования tmpfiles.d(5)
:
/etc/tmpfiles.d/tmp.conf
# смотрите tmpfiles.d(5) # очистка каталога /tmp всегда включена D! /tmp 1777 root root 0 # удалить файлы в каталоге /var/tmp старше 10 дней D /var/tmp 1777 root root 10d # namespace mountpoints (PrivateTmp=yes) are excluded from removal x /tmp/systemd-private-* x /var/tmp/systemd-private-* X /tmp/systemd-private-*/tmp X /var/tmp/systemd-private-*/tmp
Решение проблем
Не получается открытие символьных ссылок в tmpfs от root
Учитывая что /tmp
использует TMPFS, измените текущую директорию на /tmp
, а затем создайте файл и создайте символическую ссылку на этот файл в том же каталог /tmp
. При попытке открыть файл, созданный с помощью символической ссылки, вы получите ошибку "доступ запрещён". Ожидается, что это как /tmp
содержит "прилипший" набор битов.
Такое поведение можно контролировать с помощью /proc/sys/fs/protected_symlinks
или просто через SYSCTL: sysctl -w fs.protected_symlinks=0
. Чтобы это работало постоянно, смотрите Sysctl#Configuration.