в чем основная причина «Выполняется задание по созданию нестабильных файлов и каталогов»

в чем основная причина «Выполняется задание по созданию нестабильных файлов и каталогов»

Застрял на «Выполняется начальное задание по созданию энергозависимых файлов и каталогов» после перезагрузки сервера(Debian 9.5, 64-бит), и решить этим"boot-stuck-at-a-start-job-run-is-create-volatile-files-and-directories".

Я не могу понять, что такоепервопричинаэтого вопроса, хотя поиск по многим вопросам, которые не относятся кпервопричинаа просто разнообразные решения, которые меня не удовлетворяют.

Мы не достигли предела файла или (под)каталога и устанавливаем dir_nlinkдля ext4.

# sudo tune2fs -l /dev/debian-vg/root | grep dir_nlink
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype needs_recovery extent
 64bit flex_bg sparse_super large_file huge_file dir_nlink extra_isize metadata_csum

И их больше, чем50%вместимость inodeи disk.

Исходный /tmpкаталог содержит только небольшие файлы и каталоги, а также только общее использование дискового пространства.1G.

Некоторая информация:

$ cat /proc/cmdline
BOOT_IMAGE=/boot/vmlinuz-4.9.0-7-amd64 root=/dev/mapper/debian--vg-root ro net.ifnames=0 biosdevname=0 console0=tty0 console=ttyS0,115200n8 quiet

$ mount
sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime)
proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)
udev on /dev type devtmpfs (rw,nosuid,relatime,size=4077900k,nr_inodes=1019475,mode=755)
devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000)
tmpfs on /run type tmpfs (rw,nosuid,noexec,relatime,size=817924k,mode=755)
/dev/mapper/debian--vg-root on / type ext4 (rw,relatime,errors=remount-ro,data=ordered)
securityfs on /sys/kernel/security type securityfs (rw,nosuid,nodev,noexec,relatime)
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev)
tmpfs on /run/lock type tmpfs (rw,nosuid,nodev,noexec,relatime,size=5120k)
tmpfs on /sys/fs/cgroup type tmpfs (ro,nosuid,nodev,noexec,mode=755)
cgroup on /sys/fs/cgroup/systemd type cgroup (rw,nosuid,nodev,noexec,relatime,xattr,release_agent=/lib/systemd/systemd-cgroups-agent,name=systemd)
pstore on /sys/fs/pstore type pstore (rw,nosuid,nodev,noexec,relatime)
cgroup on /sys/fs/cgroup/cpu,cpuacct type cgroup (rw,nosuid,nodev,noexec,relatime,cpu,cpuacct)
cgroup on /sys/fs/cgroup/devices type cgroup (rw,nosuid,nodev,noexec,relatime,devices)
cgroup on /sys/fs/cgroup/pids type cgroup (rw,nosuid,nodev,noexec,relatime,pids)
cgroup on /sys/fs/cgroup/perf_event type cgroup (rw,nosuid,nodev,noexec,relatime,perf_event)
cgroup on /sys/fs/cgroup/net_cls,net_prio type cgroup (rw,nosuid,nodev,noexec,relatime,net_cls,net_prio)
cgroup on /sys/fs/cgroup/memory type cgroup (rw,nosuid,nodev,noexec,relatime,memory)
cgroup on /sys/fs/cgroup/cpuset type cgroup (rw,nosuid,nodev,noexec,relatime,cpuset)
cgroup on /sys/fs/cgroup/freezer type cgroup (rw,nosuid,nodev,noexec,relatime,freezer)
cgroup on /sys/fs/cgroup/blkio type cgroup (rw,nosuid,nodev,noexec,relatime,blkio)
systemd-1 on /proc/sys/fs/binfmt_misc type autofs (rw,relatime,fd=36,pgrp=1,timeout=0,minproto=5,maxproto=5,direct,pipe_ino=9039)
mqueue on /dev/mqueue type mqueue (rw,relatime)
hugetlbfs on /dev/hugepages type hugetlbfs (rw,relatime)
debugfs on /sys/kernel/debug type debugfs (rw,relatime)
tmpfs on /run/user/1000 type tmpfs (rw,nosuid,nodev,relatime,size=817920k,mode=700,uid=1000,gid=1000)

$ lsblk
NAME                MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
vda                 254:0    0 1000G  0 disk 
└─vda1              254:1    0 1000G  0 part 
  └─debian--vg-root 253:0    0    3T  0 lvm  /
vdb                 254:16   0    4T  0 disk 
vdc                 254:32   0    2T  0 disk 
└─debian--vg-root   253:0    0    3T  0 lvm  /

$ blkid
/dev/vda1: UUID="ijfyeQ-***" TYPE="LVM2_member" PARTUUID="d6***"
/dev/mapper/debian--vg-root: UUID="2d2294a9-***" TYPE="ext4"
/dev/vdc: UUID="PXrGC9-***" TYPE="LVM2_member"

$ sudo find /tmp/ | wc -l
28905144

решение1

Как вы показываете с помощью своей sudo find /tmp/ | wc -lкоманды, у вас действительно около 30 миллионов записей в /tmp. Вы можете начать с нового /tmpкаталога, как указано в других ответах, и, вероятно, вам следует это сделать, но, как вы уже догадались, если вы не докопаетесь до сути, вы окажетесь в той же ситуации.

К сожалению, у этой проблемы может быть множество причин. Например, одна проблема, с которой я столкнулся лично, — это atdсхождение с ума и начало создания пустых файлов в /tmpбезумном цикле (речь идет о тысячах в секунду или что-то в этом роде). Я не говорю, что это ваш случай, так как atэто непопулярный инструмент в наши дни, но вам придется посмотреть на имена файлов /tmpи попытаться угадать, откуда они взялись, основываясь на их именах и, возможно, временных метках.

Попробуйте sudo find /tmp -ls | moreпоискать какие-нибудь подсказки. Надеюсь, они будут очевидны.

решение2

Существует как минимум две причины вашей ситуации:

  • 1,28905144результат find /tmp/ | wc -lпоказывает, что у вас есть тонны файлов в/тмпкаталог. Очевидно,/tmpкаталог не был очищен нормальнопри загрузке или при выключении.
  • 2, /каталог устанавливался на большое значение, емкость которого достигла. При большем пространстве обращение к жесткому диску (я полагаю, это не SSD) будет медленнее.

Совет:

  • 1, проверьте, нормально ли создаются файлы в каталоге /tmp, и вы выясните причину.
  • 2, сделать /каталог не более, если это возможно, или используйте высокопроизводительные носители, такие как SSD (NVMe).

Связанный контент