linux删除oracle表空间文件后空间不释放
2014-10-20linux删除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、数据库 | 标签: database |相关日志
- oracle中drop一个表,让数据文件释放空间
- oracle批量杀掉死锁进程
- ORA-00257: archiver error. Connect internal only, until freed. (DBD ERROR: OCISessionBegin)
- oracle同义词SYNONYM
- substr()函数
- oracle create dblink
- oracle 启动归档模式
- oracle表空间文件
- nagios check_oracle_health install shell
- oracle最大连接数processes
- nagios check_oracle_health
- cx_Oracle for python
- 数据库查询重复行shell脚本
- oracle导入txt数据文件实例
- mysql导入txt数据文件实例
- 修改NLS_CHARACTERSET和NLS_NCHAR_CHARACTERSET字符集
- NLS_NCHAR_CHARACTERSET和NLS_CHARACTERSET的区别
- 如何安装mysql-5.6.12
- 设置NLS_LANG环境变量
- Oracle Golden Gate数据库同步技术
- mysql或oracle合并行函数
- Oracle InstantClient安装步骤
- shell sqlplus run sql
- oracle误删datafile
- mysqld_safe — MySQL Server Startup Script
- 如何禁用mysql端口3306
- oracle触发器实例 (8)
- sql语句处理BLOB (8)
- Drizzle A database for the Cloud (1)
- SGA/PGA的设置与调整 (9)
- 根据v$SGA_TARGET_ADVICE设置SGA SIZE (6)
- shmmax/shmall和sga_max_size/sga_target应该设置多大 (3)
- exp/imp和expdp/impdp的逻辑哲学 (1)
- oracle安装后期stop big port (1)
- OLTP和OLAP的区别 (3)
- mysql创建数据库及用户 (1)
- Mysql分支MariaDB简介 (6)
- ORA-01843: not a valid month (3)
- sql语句where 1=1和1=2的作用 (4)
- 如何安装mysql-5.5.31 (8)
- rlwrap实现sqlplus使用上下键查历史命令
- CentOS_x64_6.3 install Oracle 10.2.0.1报错ins_emdb.mk (2)