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

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)

重启连接的服务后,搞定

相关日志

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值