Lorsque de gros fichiers sont supprimés sur un serveur, les fichiers peuvent toujours être référencés par des processus, de sorte que le système de fichiers ne dispose pas de plus d'espace libre.
J'ai essayé d'utiliser lsof , mais il semble qu'il ne répertorie pas les fichiers supprimés. fuser -c
a mieux fonctionné, mais la liste des processus est tout simplement trop longue pour être vérifiée pour chaque processus, d'autant plus que chaque processus est un processus Oracle.
bash-3.2# fuser -c /var
/var: 105o 29999o 20444c 3528c 27258o 7715o 3864o 3862o 2494o 18205o 17450co 17445co 14912co 14824co 14818co 14816o 14814o 8532c 8530c 7633com 7118o 6958o 6790c 6784co 6734o 6693o 6689o 6684o 6675o 6635o 6594c 6548o 6547o 6546o 6545o 6544o 6543o 6542o 6541o 6540o 6537o 6535o 6456o 6128co 6113o 335o 245co 229o 161o 8o
bash-3.2# du -hs /proc
139T /proc
Il arrive parfois qu'un fichier soit supprimé par une application ou un utilisateur, par exemple un fichier journal et que ce fichier soit toujours référencé par un processus qui ne peut pas être redémarré.
Existe-t-il des méthodes propres à récupérer de l'espace disque sur les fichiers supprimés sans redémarrer le processus qui fait référence à ce fichier supprimé?
cp /dev/null file
cp /dev/null
est une commande nulle carcp
n'a rien à copier, une simple redirection est strictement équivalente:>file
ou même>file
Réponses:
Trouvez tous les descripteurs de fichiers ouverts.
Grep supprimé.
StdError à / dev / null
Production:
Ou vous pouvez utiliser awk
trouver / proc / * / fd -ls 2> / dev / null | awk '/ supprimé / {print $ 11}';
sortie awk (testée dans bash Ubuntu 12.04):
Recherchez et tronquez tous les fichiers supprimés (testé dans bash Ubuntu 12.04):
(NE FAITES PAS CELA SI VOUS NE SAVEZ PAS CE QUE VOUS FAITES)
-p invite avant d'exécuter tronquer
La meilleure façon est de tronquer manuellement
Troncature manuelle:
ou:
ou:
Prendre plaisir ;)
la source
Voici un exemple simple avec
less
:Supposons que nous ayons un fichier
my10MBfile
:Maintenant j'ouvre ce fichier avec
less
(oui, c'est un fichier binaire ... tant pis)Ensuite, je supprime ce fichier
Il est toujours là, mais supprimé. Regardez la 4ème colonne de la sortie lsof: File Descriptor numéro 4 ouvert pour Reading (4r)
Lançons GDB!
C'est ça!
Nos 10 Mo sont les bienvenus :)
Le processus est toujours en cours.
la source
Cette commande affichera tous les fichiers supprimés encore ouverts sur un système Solaris:
Vous pouvez tronquer ceux que vous êtes sûr de vouloir avec cette commande:
avec p étant l'identifiant du processus et x le descripteur de fichier renvoyé par la première commande.
Ne vous inquiétez pas si avec certains programmes, la taille indiquée par
ls
est restaurée à la taille avant la troncature après un certain temps, la taille réelle utilisée sur le disque sera beaucoup plus petite car le fichier est maintenant clairsemé.la source
Vous pouvez essayer d'aller dans le
/proc/<pid>/fd
répertoire et de tronquer le descripteur de fichier correspondant. Disons que fd = 3 points pour le fichier supprimé de pid == 123:la source
Aucune de ces solutions n'a fonctionné pour moi. Ce n'est qu'après avoir utilisé Bleachbit en tant que root que j'ai pu libérer correctement l'espace associé aux fichiers supprimés.
la source