linux删除oracle表空间文件后空间不释放

2014-10-20

linux删除oracle表空间文件后空间不释放

[oracle@server140 data8]$ df -h /data8
Filesystem Size Used Avail Use% Mounted on
/dev/sda3 414G 375G 19G 96% /data8
[oracle@server140 data8]$ du -sh /data8
57G /data8

未释放磁盘空间原因:

在Linux或者Unix系统中,通过rm或者文件管理器删除文件将会从文件系统的目录结构上解除链接(unlink).然而如果文件是被打开的(有一个进程正在使用),那么进程将仍然可以

读取该文件,磁盘空间也一直被占用。而我删除的是oracle的告警log文件删除的时候文件应该正在被使用

如何让进程释放呢?

一种方法是kill掉相应的进程,或者停掉使用这个文件的应用,让os自动回收磁盘空间
我这个环境有很多进程在使用的这个文件,停掉进程有点麻烦,再有就是风险很大

当linux打开一个文件的时候,Linux内核会为每一个进程在/proc/ 『/proc/nnnn/fd/目录(nnnn为pid)』建立一个以其pid
为名的目录用来保存进程的相关信息,而其子目录fd保存的是该进程打开的所有文件的fd(fd:file descriptor)。

kill进程是通过截断proc文件系统中的文件可以强制要求系统回收分配给正在使用的的文件。
这是一项高级技术,仅到管理员确定不会对运行中的进程造成影响时使用。应用程序对这种方
式支持的并不好,当一个正在使用的文件被截断可能会引发不可预知的问题

所以我还是采用停应用来解决
restart oracle数据库,发现对应的空间被释放了

例如
[oracle@server140 ~]$ lsof |grep deleted|grep 201406
oracle 15718 oracle 26u REG 8,3 43754995712 3801090 /data8/oracle/viewer_data_ts_201406_1.dbf (deleted)
oracle 15718 oracle 28u REG 8,3 40533770240 3801091 /data8/oracle/viewer_data_ts_201406_2.dbf (deleted)
oracle 28836 oracle 62u REG 8,3 43754995712 3801090 /data8/oracle/viewer_data_ts_201406_1.dbf (deleted)
oracle 28836 oracle 63u REG 8,3 40533770240 3801091 /data8/oracle/viewer_data_ts_201406_2.dbf (deleted)
oracle 28838 oracle 62u REG 8,3 43754995712 3801090 /data8/oracle/viewer_data_ts_201406_1.dbf (deleted)
oracle 28838 oracle 63u REG 8,3 40533770240 3801091 /data8/oracle/viewer_data_ts_201406_2.dbf (deleted)

cd /proc/15718/fd|grep 201406
ll
lrwx------ 1 oracle oinstall 64 Oct 20 12:37 26 -> /data8/oracle/viewer_data_ts_201406_1.dbf (deleted)
lrwx------ 1 oracle oinstall 64 Oct 20 12:37 28 -> /data8/oracle/viewer_data_ts_201406_2.dbf (deleted)

重启连接的服务后,搞定

分类:Linux数据库 | 标签: |

相关日志

评论被关闭!