创建index 使用Online导致的问题(95天)

在本地的测试库中,本来空间就不足,结果创建了一个表有600多万条记录,想创建一个index. 物理段有340多M.

临时段大小有100M,结果想创建一个索引,总是报临时表空间不足的错误。

[ora11g@rac1 test]$ ksh test.sh "create unique index t_pk on t(object_id) tablespace pool_data nologging online;" 
create unique index t_pk on t(object_id) tablespace pool_data nologging online 
                            * 
ERROR at line 1: 
ORA-01652: unable to extend temp segment by 128 in tablespace TEMPTS1

排除了索引所在的表空间不足的问题,实时监控了一下,发现确实临时表空间使用率在瞬间飙到100%,然后就报了ORA-01652的错误。

在尝试各种方法之后,先扩大临时段再次尝试。

alter database tempfile '/u03/ora11g/oradata/TEST01/temp01.dbf' resize 200M;
---结果再次尝试的时候,就有了如下的错误。 
create unique index t_pk on t(object_id) tablespace pool_data nologging online 
                            * 
ERROR at line 1: 
ORA-00603: ORACLE server session terminated by fatal error 
ORA-01114: IO error writing block to file  (block # ) 
ORA-01114: IO error writing block to file 201 (block # 15439) 
ORA-27072: File I/O error 
Additional information: 4 
Additional information: 15439 
Additional information: 4096 
Process ID: 5683 
Session ID: 18 Serial number: 103
Elapsed: 00:00:21.11 
ERROR: 
ORA-03114: not connected to ORACLE

一看就有些崩溃了,以为数据库又挂了。一看进程,还在,还能连接。

[ora11g@rac1 dbm_lite]$ ps -ef|grep smon 
ora11g    2357     1  0 05:32 ?        00:00:01 ora_smon_TEST01 
ora11g    5746  5327  0 06:27 pts/0    00:00:00 grep smon

查看alert日志。

Fri Jun 06 06:26:14 2014 
alter database tempfile '/u03/ora11g/oradata/TEST01/temp01.dbf' resize 200M 
Completed: alter database tempfile '/u03/ora11g/oradata/TEST01/temp01.dbf' resize 200M 
Fri Jun 06 06:26:39 2014 
online index (re)build cleanup: objn=15331 maxretry=2000 forever=0 
Fri Jun 06 06:26:57 2014 
Non critical error OR

那就再次尝试创建,结果错误接二连三。

再次创建,提示索引已经存在了。 create unique index t_pk on t(object_id) tablespace pool_data nologging * ERROR at line 1: ORA-00955: name is already used by an existing object

那我删除重建呢。

drop index t_pk 
           * 
ERROR at line 1: 
ORA-08104: this index object 15334 is being online built or rebuilt

试试force选项。

drop index t_pk force 
* 
ERROR at line 1: 
ORA-29862: cannot specify FORCE option for dropping non-domain index

查看Index的状态,显示是valid

********** INDEX DETAILS INFO *****************
INDEX_NAME                     TABLESPACE INDEX_TYPE UNIQUENES PAR COLUMN_LIST                    TABLE_TYPE STATUS   NUM_ROWS LAST_ANAL G 
------------------------------ ---------- ---------- --------- --- ------------------------------ ---------- ------ ---------- --------- - 
T_PK                           POOL_DATA  NORMAL     UNIQUE    NO  OBJECT_ID                      TABLE      VALID                       N
TABLE_NAME                     INDEX_NAME                     CLUSTERING_FACTOR     BLOCKS   NUM_ROWS 
------------------------------ ------------------------------ ----------------- ---------- ---------- 
T                              T_PK                                                  39174    6856704

那我再次rebuild 可以吗?

alter index t_pk rebuild parallel 4 
* 
ERROR at line 1: 
ORA-08104: this index object 15334 is being online built or rebuilt

无奈,总不能一直等着吧。而且过了好一会儿,也不见有进展。

如果在生产环境中,那绝对算是一次事故。在早期版本中,可能只有重启,让smon来做清理了。

不知道从10g还是11g开始,有dbms_repair包,里面还包括了一个蛮实用的方法。可以解决这个问题。

SQL> declare 
  2  isClean boolean; 
  3  
  4  begin 
  5  isClean := FALSE; 
  6  while isClean=FALSE loop 
  7  isClean := dbms_repair.online_index_clean(dbms_repair.all_index_id, 
  8  dbms_repair.lock_wait); 
  9  dbms_lock.sleep(2); 
10  end loop; 
11  exception 
12  when others then 
13  RAISE; 
14  end; 
15  /
PL/SQL procedure successfully completed.

运行成功后,再次尝试。

alter index t_pk rebuild parallel 4 
* 
ERROR at line 1: 
ORA-01418: specified index does not exist

这终于是我期望的结果了,看来在生产中,index的online rebuild也要慎重使用。

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-06-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

ORA-01092 ORA-12432: LBAC error: zllegnp:OCIStmtExecute 故障一例

    最近由于数据库hang住,无奈之下直接干掉了pmon进程,再次启动的时候收到了ORA-01092: ORACLE instance terminated...

441
来自专栏乐沙弥的世界

又一例SPFILE设置错误导致数据库无法启动

--========================================

653
来自专栏乐沙弥的世界

crs_register/crs_unregister 注册与移除RAC服务

    crs_register命令主要是将资源注册到CRS。该方法通常结合crs_stat -p 或者crs_profile先创建配置文件。同时crs_reg...

642
来自专栏Hadoop数据仓库

Oracle通过HSODBC访问mysql

一、环境 OS:Linux myhostname 2.6.9-42.ELsmp #1 SMP Sat Aug 12 09:39:11 CDT 2006 i686...

1729
来自专栏乐沙弥的世界

Linux/Unix shell 自动导入Oracle数据库

      使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份...

622
来自专栏杨建荣的学习笔记

dataguard中需要注意的一些数据文件操作(r8笔记第21天)

因为最近需要做一个测试,就顺手搭建了一套简单的dg环境。不过碰到了一些小问题。 数据库环境是11gR2,备库是开在open状态,配置了dg broker,一切都...

33810
来自专栏杨建荣的学习笔记

由一条日志警告所做的调优分析(r3笔记第40天)

这个案例发生有段时间了,但是今天无意中看到当时的邮件,感觉还是收益匪浅,看来还是细节决定成败啊。从一些日志或trace 文件中的警告信息中我们可以发掘出潜在的问...

3243
来自专栏乐沙弥的世界

无法成功执行catalog.sql,ORA-04045 ORA-04064

      最近同事报料,数据库无法执行一些关于数据字典的查询。即使是查询dba_users都会出现错误。从错误日志来看,全部是数据字典的一些错误信息,而用户数...

763
来自专栏杨建荣的学习笔记

关于两个简单问题的分析(r9笔记第10天)

工作中碰到问题当然是见怪不怪了,而处理这些问题也是我们的价值所在。 今天处理了几个看起来比较有意思的小问题,当然究其原因,要不是不规范,要不就是基本功不够扎实。...

2794
来自专栏乐沙弥的世界

配置sqlnet.ora限制IP访问Oracle

--========================== -- 配置sqlnet.ora 限制IP访问Oracle --===================...

634

扫码关注云+社区