Перейти к основному содержанию

Linux — после удаление файла не освободилось место

Linux

Случается так, что место на Linux сервере заканчивается. Админу нужно срочно удалить что-нибудь большое и ненужное. Админ находит кандидата на удаление, удаляет его, и... место не освобождается. Как быть?

Вот так и у меня неожиданно на выходных на сервере закончилось место. Быстро проверяю процент использования дисков:

df -h

lsof

Два диска забиты на 100%. Печаль, почищу сначала первый диск. Нахожу большой ненужный файл под названием cloud_api_ru.log, терабайт так на восемь, удаляю его, а диск как был забит на 100%, так и остался.

Получается, что файл только пометился на удаление и в настоящий момент открыт какой-то программой. Сервер перезагрузить нельзя, а место нужно освобождать прямо сейчас.

Узнаю номер процесса, который держит файл открытым:

lsof | grep имя_файла

lsof

Итак, файл держит rsyslog с идентификатором процесса 1752. Засада. rsyslog я не могу кильнуть в данный момент. Но я могу найти символьную ссылку на файловый дескриптор и стереть содержимое файла:

ls -l /proc/идентификатор_процесса/fd | grep имя_файла
ls -l /proc/1752/fd | grep cloud

Получаю:

l-wx------ 1 root root 64 окт.  16 11:22 12 -> /путь_к_файлу

Где 12 — это дескриптор.

Ссылка на удалённый файл:

/proc/идентификатор_процесса/fd/дескриптор

Стираю содержимое файла:

cat /dev/null > /proc/идентификатор_процесса/fd/дескриптор
cat /dev/null > /proc/1752/fd/12

Проверяю место:

df -h

lsof

Место освободилось. Файл всё ещё открыт процессом rsyslog, в него продолжают записываться свежие данные, но основное содержимое уже стёрто.

Наученный горьким опытом, на втором диске я буду не удалять подобные файлы, а стирать их содержимое:

cat /dev/null > /путь_к_файлу

Теги

 

Похожие материалы

Seafile сервер для Linux версия 7.0.2

13 июня 2019 года вышла новая версия сервера Seafile для Linux — 7.0.2. Релиз уже не помечен как beta. Прошлый раз я пробовал обновить Seafile Server 6.3 до версии 7.0.0, но были проблемы и прошлось откатиться. На этот раз релиз получше. Обновлённый до 7.0.2 сервер заработал без ошибок. Да, да, прежде чем написать новость, я проверил версию на себе. Интерфейс стал удобнее и приятнее.