Chinaunix首页 | 论坛 | 博客
  • 博客访问: 74476
  • 博文数量: 20
  • 博客积分: 430
  • 博客等级: 下士
  • 技术积分: 132
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-04 09:32
文章分类

全部博文(20)

文章存档

2011年(20)

我的朋友

分类: Oracle

2011-07-28 15:36:26

RAC环境ORACLE其中一个节点报告大量的cannot allocate new log提示,详细信息如下:

ORACLE Instance xxdb2 - Can not allocate log, archival required
Tue Dec 1 16:04:35 2009
Thread 2 cannot allocate new log, sequence 7466
All online logs needed archiving
Current log# 3 seq# 7465 mem# 0: +XXDBGROUP/xxdb/onlinelog/group_3.268.6409755
Current log# 3 seq# 7465 mem# 1: +XXDBGROUP/xxdb/onlinelog/group_3.269.6409755

检查上面的提示,其中有一行是"All online logs needed archiving". 说明所有的redo log都需要归档。

导致这个问题的原因是redo log的group太少,当大transaction运行的时候,将所有的redo log都用了,transaction还没有完成。


解决的方法是增加redolog 的group或增大group各member的尺寸,我选择增加group数量的方法。过程如下:

检查现在的归档日志情况:

SQL> select * from v$log;

GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIM
---------- ---------- ---------- ---------- ---------- --- ----------------------------- ---------

1 1 7501 104857600 1 NO CURRENT 504828041 01-DEC-09
2 1 7500 104857600 1 YES INACTIVE 503944970 01-DEC-09

GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIM
---------- ---------- ---------- ---------- ---------- --- ----------------------------- ---------
3 2 7464 104857600 1 NO ACTIVE 503944966 01-DEC-09
4 2 7465 104857600 1 NO CURRENT 504828036 01-DEC-09

4 rows selected.

发现现在数据库的两个节点上,每个节点有2组日志,计划每个节点增加到4组。过程如下:

SQL> alter database add logfile thread 1 group 5 ;

SQL> Database altered.

SQL> alter database add logfile thread 2 group 6 ;

SQL> Database altered.

SQL> alter database add logfile thread 1 group 7 ;

SQL> Database altered.

SQL> alter database add logfile thread 2 group 8 ;

SQL> Database altered.
阅读(1740) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

zengmuansha2015-06-02 09:48:20

你的集群的是不? 日志大小是多少? 是不是 归档大小基本上是REDO LOG的一半?