Меня смущает, соблюдает ли мой / tmp, использующий tmpfs, параметр size
, который я дал ему в / etc / fstab
:
Мои записи fstab теперь читайте:
root_pool/var/tmp /tmp /var/tmp zfs rw,nodev,nosuid 0 0
tmpfs /tmp tmpfs rw,nodev,nosuid,noexec,nr_inodes=5k,size=2G,mode=1777 0 0
tmpfs /dev/shm tmpfs defaults,nodev,nosuid,nr_inodes=5k,mode=700,size=4G 0 0
Но, по словам du, он использует половину моей памяти (которая, как я понимаю, используется по умолчанию) вместо размера, который я хотел выделить для нее.
~ df /tmp
Filesystem 1K-blocks Used Available Use% Mounted on
tmpfs 65921428 0 65921428 0% /tmp
Значит, параметр size
просто не действует?
Я работаю с Ubuntu 20.04
Edit. Я могу смонтировать его вручную с помощью
sudo mount -oremount,size=4G /tmp
. Когда я это сделаю, / tmp
- это ожидаемые 20,04 ГБ.
Правка: статус systemd:
● tmp.mount - Temporary Directory (/tmp)
Loaded: loaded (/etc/systemd/system/tmp.mount; enabled; vendor preset: enabled)
Active: active (mounted) since Wed 2020-06-17 13:30:35 EDT; 8min ago
Where: /tmp
What: tmpfs
Docs: https://systemd.io/TEMPORARY_DIRECTORIES
man:file-hierarchy(7)
https://www.freedesktop.org/wiki/Software/systemd/APIFileSystems
Tasks: 0 (limit: 154317)
Memory: 76.0K
CGroup: /system.slice/tmp.mount
Jun 17 13:30:35 virtland systemd[1]: Mounting Temporary Directory (/tmp)...
Jun 17 13:30:35 virtland systemd[1]: Mounted Temporary Directory (/tmp).
и journalctl -u tmp.mount
-- Reboot --
Jun 17 13:27:50 virtland systemd[1]: tmp.mount: Directory /tmp to mount over is not empty, mounting an>
Jun 17 13:27:50 virtland systemd[1]: Mounting Temporary Directory (/tmp)...
Jun 17 13:27:50 virtland systemd[1]: Mounted Temporary Directory (/tmp).
Jun 17 13:29:43 virtland systemd[1]: Unmounting Temporary Directory (/tmp)...
Jun 17 13:29:43 virtland systemd[1]: tmp.mount: Succeeded.
Jun 17 13:29:43 virtland systemd[1]: Unmounted Temporary Directory (/tmp).
-- Reboot --
Jun 17 13:30:35 virtland systemd[1]: tmp.mount: Directory /tmp to mount over is not empty, mounting an>
Jun 17 13:30:35 virtland systemd[1]: Mounting Temporary Directory (/tmp)...
Jun 17 13:30:35 virtland systemd[1]: Mounted Temporary Directory (/tmp).
Edit2: установка размера tmpfs для / dev / shm
работает должным образом:
# in fstab
tmpfs /dev/shm tmpfs defaults,nodev,nosuid,nr_inodes=5k,mode=700,size=4G 0 0
tmpfs 13184288 2328 13181960 1% /run
tmpfs 4194304 41056 4153248 1% /dev/shm
tmpfs 5120 4 5116 1% /run/lock
tmpfs 65921432 0 65921432 0% /sys/fs/cgroup
tmpfs 65921432 0 65921432 0% /tmp
tmpfs 13184284 8 13184276 1% /run/user/1000
Кроме того, похоже, что опция noexec, хотя и рекомендуется многими руководствами по безопасности, проблематична, потому что некоторые программы (включая apt) должны выполняться из / tmp. Я понимаю, что это можно обойти, но я не хочу выяснять каждую программу, которая должна быть исключением.
В Ubuntu 20.04 модуль tmp.mount
изначально находится в /usr/share/systemd/tmp.mount
.
Изменения, сделанные системным администратором (пользователем), попадают в /etc/systemd/system/
, возможно, поэтому они имеют более высокий приоритет.
Я не знаю, почему ваш юнит находится в /etc/systemd/system/
.
Я предполагаю, что ваш модуль tmp.mount
в /etc/systemd/system/
мешает записи в fstab.
Чтобы подтвердить это, измените следующую строку в /etc/systemd/system/tmp.mount
Options=mode=1777,strictatime,nosuid,nodev
на
Options=mode=1777,strictatime,nosuid,nodev,size=YOURSIZE
Чтобы получить желаемое поведение, отключите и удалите модуль, определенный в /etc /systemd/system/tmp.mount
.