设为首页 收藏本站
查看: 649|回复: 0

[经验分享] Oracle UNDO表空间的管理

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-5-11 09:10:32 | 显示全部楼层 |阅读模式
UNDO表空间的管理是Oracle DBA最重要的日常工作之一,UNDO表空间用来暂时存储DML操作的数据,其主要作用有:
1、事务回滚
2、实例恢复
3、读一致性
4、闪回
下面是对UNDO表空间的一些操作
1、查看某个实例都有哪些表空间:select tablespace_name, contents from dba_tablespaces where contents = 'UNDO';
163?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
我们也可以用show parameter undo_tablespace名称查看,此命令只能查看当前默认UNDO表空间:
164?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
当然,我们也可以查看表空间及其对应的数据文件:select substr(file_name,1,60) UNDO_FILES from dba_data_files where tablespace_name = 'UNDOTBS1' order by 1;
165?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
查看UNDO表空间的大小、可用空间:
select * from (select
     a.tablespace_name,
     sum(a.bytes)/(1024*1024) total_space_MB,
     round(b.free,2) Free_space_MB,
     round(b.free/(sum(a.bytes)/(1024*1024))* 100,2) percent_free
    from dba_data_files a,
     (select tablespace_name,sum(bytes)/(1024*1024) free  from dba_free_space
     group by tablespace_name) b
   where a.tablespace_name = b.tablespace_name(+)
     group by a.tablespace_name,b.free)
where tablespace_name = 'UNDOTBS1';
166?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
2、创建UNDO表空间:
create undo tablespace undotbs3 datafile '/data1/oradata/undotbs03_1.dbf' size 100M autoextend on next 20M maxsize 500M;
上面命令中,指定UNDO表空间名称、对应数据文件、初始大小、自动扩展、每次扩展大小、最大扩展到多大
给UNDO表空间增加数据文件:
ALTER TABLESPACE UNDOTBS3 ADD DATAFILE ''/data1/oradata/undotbs03_2.dbf' SIZE 1024M AUTOEXTEND ON NEXT 100M MAXSIZE 2048M;
3、切换默认UNDO表空间:
alter system set undo_tablespace = UNDOTBS3;
4、删除不用的UNDO表空间:
首先查找都有哪些UNDO表空间及其名字;
然后查找默认UNDO表空间;
之后查找要删除的UNDO表空间的数据文件;
删除不用的UNDO表空间:drop tablespace UNDOTBS2;
167?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
这还不算完,在数据库中删除表空间后,其数据文件还在物理磁盘上存在,需要删除:
168?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
5、我们可以通过dba_undo_extents查看UNDO表空间的状态:
169?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
其中STATUS的状态有三个:UNEXPIRED、EXPIRED、ACTIVE
ACTIVE说明此时有大量的DML操作在写UNDO,UNEXPIRED状态是由ACTIVE状态的数据转换过来的,至于UNEXPIRED状态何时转换成EXPIRED,这个由当前系统的undo retention决定。
我们也可以通过v$UNDOSTAT来查看详细的UNDO信息:
SELECT TO_CHAR(BEGIN_TIME, 'MM/DD/YYYY HH24:MI:SS') BEGIN_TIME,TO_CHAR(END_TIME, 'MM/DD/YYYY HH24:MI:SS') ND_TIME,
UNDOTSN, UNDOBLKS, TXNCOUNT, MAXCONCURRENCY AS "MAXCON" FROM v$UNDOSTAT WHERE rownum <= 100;
171?method=get-resource&shareToken=66A605CEA7F94E1CBF5E015593B162B7&entryId=97497660.jpg
上面各列中:
BEGIN_TIME表示每条记录UNDO事务开始的时间
END_TIMEE表示每条记录UNDO事务结束的时间
上面每条记录的间隔是10分钟
UNDOTSN 在这段时间undo事务的数量
UNDOBLKS在这段时间占用的undo块的数量
TXNCOUNT事务的总数量
MAXCON这些UNDO事务过程中的最大数据库连接数
6、更改UNDO RETENTION
alter system set UNDO_RETENTION = 1800;
7、涉及到UNDO表空间的系统表:
    V$UNDOSTAT
    V$ROLLSTAT
    V$TRANSACTION
    DBA_UNDO_EXTENTS
    WRH$_UNDOSTAT
    WRH$_ROLLSTAT



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-215413-1-1.html 上篇帖子: Oracle服务器上Swap的配置 下篇帖子: Oracle、MySQL和SqlServe分页查询的语句区别 Oracle 空间
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表