- 浏览: 4367096 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (634)
- Oracle日常管理 (142)
- Oracle体系架构 (45)
- Oracle Tuning (52)
- Oracle故障诊断 (35)
- RAC/DG/OGG (64)
- Oracle11g New Features (48)
- DataWarehouse (15)
- SQL, PL/SQL (14)
- DB2日常管理 (9)
- Weblogic (11)
- Shell (19)
- AIX (12)
- Linux/Unix高可用性 (11)
- Linux/Unix日常管理 (66)
- Linux桌面应用 (37)
- Windows (2)
- 生活和工作 (13)
- 私人记事 (0)
- Python (9)
- CBO (15)
- Cognos (2)
- ORACLE 12c New Feature (2)
- PL/SQL (2)
- SQL (1)
- C++ (2)
- Hadoop大数据 (5)
- 机器学习 (3)
- 非技术 (1)
最新评论
-
di1984HIT:
xuexilee!!!
Oracle 11g R2 RAC高可用连接特性 – SCAN详解 -
aneyes123:
谢谢非常有用那
PL/SQL的存储过程和函数(原创) -
jcjcjc:
写的很详细
Oracle中Hint深入理解(原创) -
di1984HIT:
学习了,学习了
Linux NTP配置详解 (Network Time Protocol) -
avalonzst:
大写的赞..
AIX内存概述(原创)
今天同事让我把undo表空间缩小为原来的40GB,之前由于开发商的需求,将undo表空间扩大到了200GB之大,现在需要缩小为40GB。虽然整件事有点不和逻辑,但事已至此也用不管他们怎么想的,毕竟人家跟客户走得近,而且有些事也不是我说得算,照做就是了。下面是过程
SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bi
PL/SQL Release 10.2.0.5.0 - Production
CORE 10.2.0.5.0 Production
TNS for IBM/AIX RISC System/6000: Version 10.2.0.5.0 - Productio
NLSRTL Version 10.2.0.5.0 - Production
查看当前undo表空间使用情况
SQL> SELECT DISTINCT STATUS "状态",
2 COUNT(*) "EXTENT数量",
3 SUM(BYTES) / 1024 / 1024 / 1024 "UNDO大小"
4 FROM DBA_UNDO_EXTENTS
5 GROUP BY STATUS;
???? EXTENT???? UNDO????
--------- ---------- ----------
EXPIRED 3524 49.8547363
UNEXPIRED 2985 162.694336
万幸,由于已经是下班时间,没有获得的undo表空间,今天就能完成全部工作,偷乐中。准备数据文件如下
#lslv lv_undo_tmp01
LOGICAL VOLUME: lv_undo_tmp01 VOLUME GROUP: cxdatavg
LV IDENTIFIER: 00f65ad200004c000000012e3d0271ff.104 PERMISSION: read/write
VG STATE: active/complete LV STATE: closed/syncd
TYPE: jfs2 WRITE VERIFY: off
MAX LPs: 512 PP SIZE: 512 megabyte(s)
COPIES: 1 SCHED POLICY: striped
LPs: 80 PPs: 80
STALE PPs: 0 BB POLICY: relocatable
INTER-POLICY: maximum RELOCATABLE: no
INTRA-POLICY: middle UPPER BOUND: 4
MOUNT POINT: N/A LABEL: None
MIRROR WRITE CONSISTENCY: off
EACH LP COPY ON A SEPARATE PV ?: yes (superstrict)
Serialize IO ?: NO
STRIPE WIDTH: 4
STRIPE SIZE: 64m
DEVICESUBTYPE : DS_LVZ
COPY 1 MIRROR POOL: None
COPY 2 MIRROR POOL: None
COPY 3 MIRROR POOL: None
确认当前undo表空间
SQL> show parameter undo
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_management string AUTO
undo_retention integer 900
undo_tablespace string UNDOTBS1
创建新的undo表空间undotemptbs1
SQL> create undo tablespace UNDOTEMPTBS1 datafile '/dev/rlv_undo_tmp01';
create undo tablespace UNDOTEMPTBS1 datafile '/dev/rlv_undo_tmp01'
*
ERROR at line 1:
ORA-01144: File size (5242879 blocks) exceeds maximum of 4194303 blocks
报错ORA-01144,仔细检查后才发现在没有使用大表空间的情况下,原来单个数据文件超过了32GB,导致报错ORA-01144,具体原因如下
rowid在磁盘上需要10 个字节(byte)的存储空间并使用18 个字符来显示它包含下列组件:
数据对象编号:每个数据对象如表或索引在创建时都分配有此编号,并且此编号在数据库中是唯一的;
相关文件编号:此编号对于一个表空间中的每个文件是唯一的;
块编号:表示包含此行的块在文件中的位置;
行编号:标识块头中行目录位置的位置;
在内部数据对象编号需要32位(bit),相关文件编号需要10位(bit),块编号需要22位(bit),位行编号需要16位,加起来总共是80位或10 个字节,ROWID 使用以64为基数的编码方案来显示该方案将6个位置用于数据对象,编号3个位置用于相关文件编号,6个位置用于块编号,3个位置用于行编号以64为基数的编码方案使用字符A-Z a-z 0-9 + 和/共64 个字符,如下例所示:
AAAB/R AAB AAAGmS AAA
由于block是22位(bit),
22bit就是一个22位二进制数,换算成十进制就是 2的22次方-1=4194303 也就是说,一个datafile最多容纳这么多个blocks
数据块大小(block size)为2K的数据文件的size最大只能是8G,而依此类推8K数据块的一个数据文件的最大size只能是32G。系统中undo表空间只能使用8k的小表空间,故undo最大的单个数据文件为32GB。
于是创建单个文件大小为30GB的undo表空间
SQL> create undo tablespace UNDOTEMPTBS1 datafile '/dev/rlv_undo_tmp01' size 30G;
Tablespace created.
切换数据库默认undo表空间为UNDOTEMPTBS1
SQL> alter system set undo_tablespace=UNDOTEMPTBS1;
System altered.
SQL> show parameter undo_tablespace
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_tablespace string UNDOTEMPTBS1
删除原有undo表空间UNDOTBS1
SQL> drop tablespace UNDOTBS1 including contents and datafiles;
Tablespace dropped.
SQL> show parameter undo_tablespace
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_tablespace string UNDOTEMPTBS1
创建undo表空间UNDOTBS1,这里/dev/rlv_cx_undo1_1和/dev/rlv_cx_undo1_2是之前undo表空间使用的数据文件
SQL> create undo tablespace UNDOTBS1
2 datafile '/dev/rlv_cx_undo1_1' size 20400m,
'/dev/rlv_cx_undo1_2' size 20400m; 3
Tablespace created.
切换数据库默认undo表空间为UNDOTBS1
SQL> alter system set undo_tablespace=UNDOTBS1;
System altered.
删除原有undo表空间UNDOTEMPTBS1
SQL> drop tablespace UNDOTEMPTBS1 including contents and datafiles;
Tablespace dropped.
确认当前undo表空间
SQL> SHOW PARAMETER UNDO_tablespace
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_tablespace string UNDOTBS1
SQL> set linesize 150
SQL> column file_name format a65
SQL> column tablespace_name format a20
SQL> select f.tablespace_name tablespace_name,round((d.sumbytes/1024/1024/1024),2) total_g,
round(f.sumbytes/1024/1024/1024,2) free_g,
round((d.sumbytes-f.sumbytes)/1024/1024/1024,2) used_g,
round((d.sumbytes-f.sumbytes)*100/d.sumbytes,2) used_percent
from (select tablespace_name,sum(bytes) sumbytes from dba_free_space group by tablespace_name) f,
(select tablespace_name,sum(bytes) sumbytes from dba_data_files group by tablespace_name) d
where f.tablespace_name= d.tSQL> SQL> 2 3 4 5 6 7 ablespace_name
order by d.tablespace_name;
TABLESPACE_NAME TOTAL_G FREE_G USED_G USED_PERCENT
-------------------- ---------- ---------- ---------- ------------
。。。。。。。。。。。。。省略若干行。。。。。。。。。。。。
SYSAUX 9.96 8.56 1.4 14.03
SYSTEM 9.96 8.76 1.2 12.06
UNDOTBS1 39.84 39.84 0 .01
UNDOTBS2 39.84 13.73 26.12 65.54
USERS 4.98 2.3 2.68 53.89
WFLTAIS_DAT 19.92 19.92 0 0
。。。。。。。。。。。。。省略若干行。。。。。。。。。。。。
SQL> select file_name from dba_data_files where file_name like '%undo%';
FILE_NAME
-----------------------------------------------------------------
/dev/rlv_cx_undo1_1
/dev/rlv_cx_undo2_1
/dev/rlv_cx_undo1_2
/dev/rlv_cx_undo2_2
准备删除多余的数据文件,查看状态如下
#lsvg -l cxdatavg|grep undo
lv_cx_undo1_2 jfs2 40 40 4 open/syncd N/A
lv_cx_undo2_2 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_3 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_4 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_5 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_6 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_7 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_8 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_9 jfs2 40 40 4 open/syncd N/A
lv_cx_undo1_10 jfs2 40 40 4 open/syncd N/A
lv_undo_tmp01 jfs2 80 80 4 closed/syncd N/A
lv_cx_undo1_1 jfs2 40 40 4 open/syncd N/A
lv_cx_undo2_1 jfs2 40 40 4 open/syncd N/A
发现数据文件出了lv_undo_tmp01,其他的状态都还是open,查看
$ fuser /dev/rlv_cx_undo1_3
/dev/rlv_cx_undo1_4: 25428220
$ fuser /dev/rlv_cx_undo1_4
/dev/rlv_cx_undo1_4: 25428220
$ fuser /dev/rlv_cx_undo1_5
/dev/rlv_cx_undo1_5: 25428220
$ fuser /dev/rlv_cx_undo1_6
/dev/rlv_cx_undo1_6: 25428220
$ fuser /dev/rlv_cx_undo1_7
/dev/rlv_cx_undo1_7: 25428220
$ fuser /dev/rlv_cx_undo1_8
/dev/rlv_cx_undo1_8: 25428220
$ fuser /dev/rlv_cx_undo1_9
/dev/rlv_cx_undo1_9: 25428220
$ fuser /dev/rlv_cx_undo1_10
/dev/rlv_cx_undo1_10: 25428220
$ ps -ef|grep 25428220
dsg 25428220 19660886 0 May 14 - 101:08 oraclezgcxdb1 (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
oracle 28770354 11141152 0 19:09:42 pts/2 0:00 grep 25428220
全都是因为dsg的25428220还在访问那些数据文件。百度了下,有的说是重启可以解决问题。个人觉得重启还不如kill,性质都一样。由于公司采用了dsg的数据同步软件进行数据同步,重启也需要经过客户同意,工作比较繁琐,也就先放着看看,看过一段时间会不会自动释放。
虽然还有后续工作,但至少已经完成了基本目标,聊以自慰,下班。
本文原创,装载请注明出处、作者
如有错误,欢迎指正
邮箱:czmcj@163.com
评论
2、生产库,aix系统
2,oracle会认为这个表空间的size会超过32G,这个还是没能理解。还望麻烦你
3,你的系统是AIX的?
1,为何要准备数据文件
2, create undo tablespace UNDOTEMPTBS1 datafile '/dev/rlv_undo_tmp01';这里并没有指定undo 表空间的大小,为何oracle会认为这个表空间的size会超过32G
1、准备数据文件是为了建立新的undo表空间做切换用
2、请仔细看下该lv的大小为40GB
1,为何要准备数据文件
2, create undo tablespace UNDOTEMPTBS1 datafile '/dev/rlv_undo_tmp01';这里并没有指定undo 表空间的大小,为何oracle会认为这个表空间的size会超过32G
发表评论
-
Oracle 11g、12c大量错误登陆尝试带来的数据库异常
2018-07-16 09:21 1469APPLIES TO: Oracle Database - ... -
如何定位那些SQL产生了大量的redo日志
2018-05-15 14:38 1694在ORACLE数据库的管理、 ... -
When Memory_target Is Set and Swap Size Is Not Big (Doc ID 2356025.1)
2018-03-16 18:13 1125Kkjcre1p: unable to sp ... -
Transparent Hugepage is not getting disabled (Doc ID 2279458.1)
2018-03-16 18:10 777Transparent Hugepage is ... -
Troubleshooting: "log file sync" Waits (文档 ID 1376916.1)
2017-03-09 14:32 1296What is a 'log file sync' wai ... -
log file sync总结
2017-03-09 14:36 3126log file sync等待时间发生在redo log从 ... -
Oracle Log File Sync Wait Event
2017-03-08 18:46 1117The Oracle “log file sync” wai ... -
Tuning ‘log file sync’ Event Waits
2017-03-08 18:41 807Tuning ‘log file sync’ Event ... -
Diagnosing buffer busy waits with the ash_wait_chains.sql script (v0.2)
2017-03-08 16:56 777Diagnosing buffer busy waits w ... -
Advanced Oracle Troubleshooting Guide – Part 11: Complex Wait Chain Signature An
2017-03-08 16:05 1013Here’s a treat for the hard-co ... -
Oracle 10046 SQL TRACE
2017-03-08 15:19 891为什么我们要使用10046 trace? 10046 ... -
Automatic Storage Management
2016-11-03 15:33 805SYSASM Role When Automatic ... -
ASM FAQ
2016-11-03 15:29 669ASM FAQ Oracle Automatic ... -
Oracle ALTER PROFILE语法
2016-10-10 11:36 3335ALTER PROFILE Purpose Use th ... -
Oracle FGA审计
2016-09-20 09:42 1313大家对trigger可能比较熟悉,但Oracle还有一个叫 ... -
Secret.txt
2016-09-14 17:20 0考试登录账号:YAMAC0043865 Chen1988协会网 ... -
Oracle Data Pump Internals
2016-09-13 16:38 722IntroductionOracle Data Pump w ... -
UDEV SCSI Rules Configuration for ASM in Oracle Linux 5, 6 and 7
2016-09-12 16:32 796UDEV SCSI Rules Configuration ... -
Cannot Allocate New Log
2016-02-21 12:28 5361故障报错 Thread 1 cannot allocat ... -
Oracle flashback dropped tablespace(原创)
2015-11-15 22:21 1940Oracle官方并不推荐在数据库物理结构发生改变的情况下进行 ...
相关推荐
比较深入浅出的描述了基于oracle10g/11g的UNDO表空间的管理
oracle 收缩undo表空间,需要收缩Undo表空间时特别有用。
演示如何收缩Oracle数据库的undo表空间
oracle Undo表空间管理,oracle 学习人员必看的不可缺少的资料。
undo表空间恢复
Oracle释放过度使用的Undo表空间,脚本
oracle 9i UNDO表空间数据文件丢失恢复得全过程。。
undo 表空间利用率 处理 事务 回滚等介绍 以及如何切换undo表空间
地震前兆Oracle数据库UNDO表空间持续增长修复.pdf
oracle 数据库的 undo表空间管理 全面分析介绍
innodb_undo_directory:指定单独存放undo表空间的目录,默认为.(即datadir),可以设置相对路径或者绝对路径。该参数实例初始化之后虽然不可直接改动,但是可以通过先停库,修改配置文件,然后移动undo表空间文件...
ORACLE的UNDO表空间
Oracle中,当Temp和Undo表空间无限增大时,回收这部分空间就是个问题
甲骨论-08-Undo表空间管理 本章详细介绍了undo表空间的工作原理以及与undo相关的数据字典
一定要意识到,如果 undo 表空间中存在空间压力时,我们不保证前镜像一定会保留这么长时间。 因此,以下公式可用于计算佳 undo 表空间大小: 从 Oracle 10g 开始,您可以选择使用 GUARANTEE 选项,以确保在...
Oracle 12c中的表空间管理、用户和角色、临时Undo
Oracle 9i数据库中自动Undo表空间管理.pdf
如何Shrink Undo表空间,释放过度占用的空间
UNDO表空间用来存放改变前的旧值。里面也有段区块,ORACLE自动建立生成、自动使用UNDO段。 作为高级别的DBA是需要知道ORACLE如何使用UNDO段的。 1 Undo表空间及管理方式 ORACLE开始一个事务的时候,会用到表空间。...