• 网络学院
  • 新手学堂
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
ShrinkUndo表空间释放过度占用的空间
广告位
  站点:
  • 首 页
  • 最新更新
  • 软件分类
  • 国内软件
  • 国外软件
  • 汉化软件
  • 源码下载
  • 字体下载
ShrinkUndo表空间释放过度占用的空间
软件发布 ShrinkUndo表空间释放过度占用的空间
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回首页 | 文章首页 | 认证考试 | Oracle认证 | Oracle动态 | ShrinkUndo表空间释放过度占用的空间

ShrinkUndo表空间释放过度占用的空间

 

添加时间: 2008-4-30 21:52:44  作者: Oracle动态  阅读次数:0   来源: http://www.d9soft.com

 

 

       

环境:
OS:Red Hat Enterprise Linux AS release 4 (Nahant)
DB:Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
一台Oracle10gR2数据库报出如下错误:

ORA-1653: unable to extend table SYSMAN.MGMT_SYSTEM_ERROR_LOG by 8 in  tablespace SYSAUX  ORA-1653: unable to extend table SYSMAN.MGMT_SYSTEM_ERROR_LOG by 8 in  tablespace SYSAUX  ORA-1653: unable to extend table SYSMAN.MGMT_SYSTEM_ERROR_LOG by 8 in  tablespace SYSAUX  ORA-1653: unable to extend table SYSMAN.MGMT_SYSTEM_ERROR_LOG by 8 in  tablespace SYSAUX  ORA-1653: unable to extend table SYSMAN.MGMT_SYSTEM_ERROR_LOG by 8 in  tablespace SYSAUX       

登陆 检查 ,发现是SYSAUX表空间空间用尽,不能扩展,尝试手工扩展SYSAUX表空间:
alter database datafile '+ORADG/danaly/datafile/sysaux.266.600173881' resize 800m Tue Nov 29 23:31:38 2005 ORA-1237 signalled during: alter database datafile 
'+ORADG/danaly/datafile/sysaux.266.600173881' resize 800m...

出现ORA-1237错误,提示空间不足。这时候我才认识到是磁盘空间可能被用完了.

是谁"偷偷的"用了那么多空间呢(本来有几十个G的Free磁盘空间的)?
检查数据库表空间占用空间情况:
SQL> select tablespace_name,sum(bytes)/1024/1024/1024 GB   2  from dba_data_files group by tablespace_name   3  union all   4  select tablespace_name,sum(bytes)/1024/1024/1024 GB   5  from dba_temp_files group by tablespace_name order by GB; TABLESPACE_NAME                        GB ------------------------------ ---------- USERS                          .004882813 UNDOTBS2                        .09765625 SYSTEM                         .478515625 SYSAUX                         .634765625 WAPCM_TS_VISIT_DETAIL            .9765625 HY_DS_DEFAULT                           1 MINT_TS_DEFAULT                         1 MMS_TS_DATA2                        1.375 MMS_IDX_SJH                             2 MMS_TS_DEFAULT                          2 IVRCN_TS_DATA                           2 TABLESPACE_NAME                        GB ------------------------------ ---------- MMS_TS_DATA1                            2 CM_TS_DEFAULT                           5 TEMP                           20.5498047 UNDOTBS1                       27.1582031 15 rows selected.       

不幸的发现,UNDO表空间已经扩展至27G,而TEMP表空间也扩展至20G,这2个表空间加起来占用了47G的磁盘空间,导致了空间不足。
显然曾经有大事务占用了大量的UNDO表空间和Temp表空间,Oracle的AUM(Auto Undo Management)从出生以来就经常出现只扩展,不收缩(shrink)的情况(通常我们可以设置足够的UNDO表空间大小,然后取消其自动扩展属性).
现在我们可以采用如下步骤回收UNDO空间:

1.确认文件
SQL> select file_name,bytes/1024/1024 from dba_data_files   2  where tablespace_name like 'UNDOTBS1'; FILE_NAME -------------------------------------------------------------------------------- BYTES/1024/1024 --------------- +ORADG/danaly/datafile/undotbs1.265.600173875           27810       

2.检查UNDO Segment状态
SQL> select usn,xacts,rssize/1024/1024/1024,hwmsize/1024/1024/1024,shrinks   2  from v$rollstat order by rssize;        USN      XACTS RSSIZE/1024/1024/1024 HWMSIZE/1024/1024/1024    SHRINKS ---------- ---------- --------------------- ---------------------- ----------          0          0            .000358582             .000358582          0          2          0            .071517944             .071517944          0          3          0             .13722229              .13722229          0          9          0            .236984253             .236984253          0         10          0            .625144958             .625144958          0          5          1            1.22946167             1.22946167          0          8          0            1.27175903             1.27175903          0          4          1            1.27895355             1.27895355          0          7          0            1.56770325             1.56770325          0          1          0            2.02474976             2.02474976          0          6          0             2.9671936              2.9671936          0 11 rows selected.       


3.创建新的UNDO表空间

SQL> create undo tablespace undotbs2; Tablespace created.       


4.切换UNDO表空间为新的UNDO表空间

SQL> alter system set undo_tablespace=undotbs2 scope=both; System altered.       


此处使用spfile需要注意,以前曾经记录过这样一个案例:Oracle诊断案例-Spfile案例一则
5.等待原UNDO表空间所有UNDO SEGMENT OFFLINE

SQL> select usn,xacts,status,rssize/1024/1024/1024,hwmsize/1024/1024/1024,shrinks   2 from v$rollstat order by rssize;        USN      XACTS STATUS          RSSIZE/1024/1024/1024 HWMSIZE/1024/1024/1024    SHRINKS ---------- ---------- --------------- --------------------- ---------------------- ----------         14          0 ONLINE                     .000114441             .000114441          0         19          0 ONLINE                     .000114441             .000114441          0         11          0 ONLINE                     .000114441             .000114441          0         12          0 ONLINE                     .000114441             .000114441          0         13          0 ONLINE                     .000114441             .000114441          0         20          0 ONLINE                     .000114441             .000114441          0         15          1 ONLINE                     .000114441             .000114441          0         16          0 ONLINE                     .000114441             .000114441          0         17          0 ONLINE                     .000114441             .000114441          0         18          0 ONLINE                     .000114441             .000114441          0          0          0 ONLINE                     .000358582             .000358582          0        USN      XACTS STATUS          RSSIZE/1024/1024/1024 HWMSIZE/1024/1024/1024    SHRINKS ---------- ---------- --------------- --------------------- ---------------------- ----------          6          0 PENDING OFFLINE             2.9671936              2.9671936          0 12 rows selected.       


再看:

11:32:11 SQL> /        USN      XACTS STATUS          RSSIZE/1024/1024/1024 HWMSIZE/1024/1024/1024    SHRINKS ---------- ---------- --------------- --------------------- ---------------------- ----------         15          1 ONLINE                     .000114441             .000114441          0         11          0 ONLINE                     .000114441             .000114441          0         12          0 ONLINE                     .000114441             .000114441          0         13          0 ONLINE                     .000114441             .000114441          0         14          0 ONLINE                     .000114441             .000114441          0         20          0 ONLINE                     .000114441             .000114441          0         16          0 ONLINE                     .000114441             .000114441          0         17          0 ONLINE                     .000114441             .000114441          0         18          0 ONLINE                     .000114441             .000114441          0         19          0 ONLINE                     .000114441             .000114441          0          0          0 ONLINE                     .000358582             .000358582          0 11 rows selected. Elapsed: 00:00:00.00       


6.删除原UNDO表空间

11:34:00 SQL> drop tablespace undotbs1 including contents; Tablespace dropped. Elapsed: 00:00:03.13       


7. 检查 空间情况
由于我使用的ASM 管理 ,可以使用10gR2提供的信工具asmcmd来察看空间占用情况.
 

[oracle@danaly ~]$ export ORACLE_SID=+ASM [oracle@danaly ~]$ asmcmd ASMCMD> du  Used_MB      Mirror_used_MB   21625               21625 ASMCMD> exit       

空间已经释放。

 

 

 

上下文章:

 

上一篇文章: Oracle加入Grails开源计划提升Java生产力 下一篇文章: 深度分析:Oracle收购JBoss&BEA开源kodo

相关文章:

  • ShrinkUndo表空间释放过度占用的空间
  • ShrinkUndo表空间,释放空间
  • ShrinkUndo表空间,释放空间
  • 在Oracle中获取磁盘空间的使用情况
  • Oracle 快速删除数据字典管理的表空间

 

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

Oracle认证分类导航

  • Oracle动态
  • Oracle指导
  • Oracle题库

本类经典文章推荐

  • 在ORACLE的存储过程中如何做简单的...
  • Oracle下调数据库许可价格以适应多...
  • 想知道OCP证书在加拿大值多少钱吗
  • Oracle全球客户支持副总裁汤姆...
  • Oracle中国前员工述说公司高层内部...
  • Oracle发布免费数据库管理工具Rap...
  • 甲骨文打算收购企业智能软件与中间...
  • Oracle将收购Jboss?相关各方保持...
  • Oracle或将收购Jboss?相关各方保...
  • 甲骨文意外泄漏数据库安全漏洞

Oracle动态阅读排行

  • 专家答疑Oracle热点问题
  • 微软推出免费的真实试验环境
  • Oracle OCP DBA 认证介绍
  • ORACLE考试 1Z0-023:Oracle8i结构...
  • Oracle认证价值
  • OCP认证完全指南[1]
  • ORACLE公司传奇创建史
  • 官方消息:Oracle8i认证即将退休
  • Oracle10g认证最新消息
  • Oracle10g认证考试途径详解

Oracle认证阅读总排行

  • 实例:Oracle导出EXCEL文件
  • Oracle企业管理器(OEM 2.1)使用...
  • 服务器和客户机是怎样连接的
  • 讲述电信禁止路由上网的破解方法
  • 入门基础:连接常见错误及解决方法
  • oracle—如何在PL/SQL中读写操作系...
  • 安装Oracle 9i数据库服务器
  • schema的常用脚本:gettrig.sql
  • 考试大学习教室[oracle问题集(一...
  • 学习Oracle的几点建议(适合初学者...

广告位置

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2007 D9soft.com 第九软件网 版权所有