Network Security Internet Technology Development Database Servers Mobile Phone Android Software Apple Software Computer Software News IT Information

In addition to Weibo, there is also WeChat

Please pay attention

WeChat public account

Shulou

How to solve the problem that files have been deleted but space is not released in linux

2025-01-19 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Servers >

Share

Shulou(Shulou.com)06/01 Report--

This article mainly explains "how to solve the problem that the file has been deleted but the space is not released in linux". Interested friends may wish to have a look. The method introduced in this paper is simple, fast and practical. Let's let the editor take you to learn how to solve the problem that the file has been deleted but the space is not released in linux.

Generally speaking, the space will not be released after the file is deleted, but there are exceptions, such as the file is locked by the process, or a process has been writing data to the file. To understand this problem, you need to know the storage mechanism and storage structure of files under Linux.

1. Error phenomenon

The monitoring system of OPS sends a notification, reporting that a server is full. Log in to the server to check, and there is really no space in the root partition:

[root@localhost] # df-h

First of all, I will explain some deletion policies of the server. Because Linux does not have the Recycle Bin feature, all files to be deleted on the online server will be moved to the system / tmp directory first, and then the data in the / tmp directory will be cleared periodically. There is nothing wrong with this strategy itself, but it is found that there is no separate / tmp partition in the system partition of this server, so the data under / tmp actually takes up the space of the root partition. Now that you've found the problem, delete some of the larger data files in the / tmp directory and check the three largest data files under / tmp.

[root@localhost ~] # du-sh / tmp/* | sort-nr | head-3

Through the command output, it is found that there is a 66GB-sized file access_log in the / tmp directory. This file should be an access log file generated by Apache. Judging from the log size, the Apache log file has not been cleaned for a long time. It is basically determined that the root space caused by this file is full. After confirming that this file can be deleted, perform the following deletion operation:

[root@localhost ~] # rm / tmp/access_log

Then check to see if the system root partition space is freed:

[root@localhost] # df-h

As you can see from the output, the root partition space is still not freed. What's going on?

2. Solution

Generally speaking, space will not be released after deleting a file, but there are exceptions, such as a file is locked by a process, or a process has been writing data to the file. To understand this problem, you need to know the storage mechanism and storage structure of files under Linux.

The storage of a file in the file system is divided into two parts: the data part and the pointer part, the pointer is located in the meta-data of the file system, after the data is deleted, the pointer is removed from the meta-data, and the data part is stored on disk. After the pointer corresponding to the data is removed from the meta-data, the space occupied by the data part of the file can be overwritten and written to the new content. The reason why the space has not been released after the deletion of the access_log file is that the httpd process has been writing to the file. Although the access_log file has been deleted, the corresponding pointer part of the file has not been removed from the meta-data because of the process lock. Since the pointer is not deleted, the system kernel believes that the file has not been deleted, so it is not surprising that the query space is not released through the df command.

3. Troubleshooting

Now that you have an idea to solve the problem, let's see if any process has been writing data to the access_log file. Here, you need to use the lsof command under Linux, through which you can get a list of deleted files that are still occupied by the application. Execute the command as follows:

[root@localhost ~] # lsof | grep delete

As you can see from the output, the / tmp/access_log file is locked by the process httpd, and the httpd process keeps writing log data to this file. As you can see from column 7, the size of this log file is about 70GB, while the total size of the system root partition is only 100GB, so this file is the culprit that causes the system root partition to run out of space. The "deleted" status of the last column indicates that the log file has been deleted, but the space has not been freed because the process is still writing data to the file.

4. Solve the problem

At this point, the problem is basically clear, there are many ways to solve this kind of problem, the easiest way is to shut down or restart the httpd process, of course, you can restart the operating system, but these are not the best methods. To deal with the constant logging of files in this process, the best way to free the disk space occupied by files is to empty the file online, which can be done by using the following command:

[root@localhost ~] # echo "" > / tmp/acess.log

This method not only frees disk space immediately, but also ensures that the process continues to write logs to files. This method is often used to clean up log files generated by Apache, Tomcat, Nginx and other Web services online.

At this point, I believe you have a deeper understanding of "how to solve the problem that the file has been deleted but the space is not released in linux". You might as well do it in practice. Here is the website, more related content can enter the relevant channels to inquire, follow us, continue to learn!

Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.

Views: 0

*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.

Share To

Servers

Wechat

© 2024 shulou.com SLNews company. All rights reserved.

12
Report