时间用久了我的阿里云服务器下面的磁盘空间越来越少了,需要对无效的大文件进行清除删除.我通过find 命令查找到nginx/logs/ 目录西面有好几个大的日志文件.因此想对其清除,但是当我删除文件后,发现磁盘的空间并没有变化.具体的操作如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
//首先查看自己的系统目前的磁盘空间 可用2.1G
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda1 20G 17G 2.1G 89% /
tmpfs 498M 0 498M 0% /dev/shm
//去查找nginx的access.log日志 日志文件大于100M的
[root@localhost ~]# find /usr/local/nginx/logs/ -size +100M -
exec
ls -lh {} \;
-rw-r--r-- 1 root root 1.2G Sep 7 10:23 /usr/local/nginx/logs/access.log
//删除这个大文件 (请先备份或者迁移)
[root@localhost ~]# rm -rf /usr/local/nginx/logs/access.log
//查看磁盘空间~~OMG奇怪了.明明删除了,可用空间还在是2.1G
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda1 20G 17G 2.1G 89% /
tmpfs 498M 0 498M 0% /dev/shm
//查找nginx/logs/下 已经没发现大文件了
[root@localhost ~]# find /usr/local/nginx/logs/ -size +100M -
exec
ls -lh {} \;
//重启Nginx--为啥要重启请看下方的原理
[root@localhost ~]# service nginx restart
Stopping nginx: [ OK ]
Starting nginx: [ OK ]
//再次查看磁盘空间 瞬间萌萌哒.可用空间变成了3.3G了
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda1 20G 16G 3.3G 83% /
tmpfs 498M 0 498M 0% /dev/shm
|
关于CentOS删除文件后未释放磁盘空间原因:在Linux或者Unix系统中,通过rm或者文件管理器删除文件将会从文件系统的目录结构上解除链接(unlink).然而如果文件是被打开的(有一个进程正在使用),那么进程将仍然可以读取该文件,磁盘空间也一直被占用。而我删除的是nginx的日志log文件,删除的时候文件应该正在被使用.
lsof全名list opened files,也就是列举系统中已经被打开的文件。我们都知道,linux环境中,任何事物都是文件,设备是文件,目录是文件,甚至sockets也是文件。用好lsof命令,对日常的linux管理非常有帮助。
解决方法:首先获得一个已经被删除但是仍然被应用程序占用的文件列表,如下所示:
1
2
3
4
5
|
[root@localhost logs]# lsof |grep deleted
nginx 24747 root 12w REG 202,1 95721 663021 /usr/local/nginx/logs/access.log (deleted)
nginx 24749 root 12w REG 202,1 95721 663021 /usr/local/nginx/logs/access.log (deleted)
......
[root@localhost logs]#
|
如何让进程释放呢?一种方法是kill掉相应的进程,或者停掉使用这个文件的应用,让os自动回收磁盘空间。