Не работает ли параметр size для tmpfs в fstab?

Меня смущает, соблюдает ли мой / 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. Я понимаю, что это можно обойти, но я не хочу выяснять каждую программу, которая должна быть исключением.

1
задан 19 June 2020 в 13:58

1 ответ

В 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.

2
ответ дан 26 June 2020 в 13:05

Другие вопросы по тегам:

Похожие вопросы: