热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Oracle10g添加、删除日志组

这个实际上是个比较常见的错误。通常来说是因为在日志被写满时会切换日志组,这个时候会触发一次checkpoint,DBWR会把内存中的脏

这个实际上是个比较常见的错误。通常来说是因为在日志被写满时会切换日志组,这个时候会触发一次checkpoint,DBWR会把内存中的脏

做日常巡检的时候发现alert日志中有这个错误

Thread 1 cannot allocate new log, sequence 319708

Checkpoint not complete

这个实际上是个比较常见的错误。通常来说是因为在日志被写满时会切换日志组,这个时候会触发一次checkpoint,,DBWR会把内存中的脏块往数据文件中写,只要没写结束就不会释放这个日志组。如果归档模式被开启的话,还会伴随着ARCH写归档的过程。如果redo log产生的过快,当CPK或归档还没完成,LGWR已经把其余的日志组写满,又要往当前的日志组里面写redo log的时候,这个时候就会发生冲突,数据库就会被挂起。并且一直会往alert.log中写类似上面的错误信息。

Oracle给出的建议是:

Add additional log group

Increase size of redo logs

#########################################################

select * from v$log;

select bytes/1024/1024 from v$log;

select * from v$logfile;

#通过以上命令查看日志组、日志文件的状态

#添加3个新的日志组

alter database add logfile group 4 '/u01/app/oradata/destdb/destdb/redo04.log' size 300m;

alter database add logfile group 5 '/u01/app/oradata/destdb/destdb/redo05.log' size 300m;

alter database add logfile group 6 '/u01/app/oradata/destdb/destdb/redo06.log' size 300m;

#通过执行下面的命令,将新添加的日志组的状态切换为“非unused”,将需要删除的日志组切换为“unused”

alter system switch logfile;

#删除老的日志组,在线增加日志组的时候,删除日志组的时候只能删除日志组状态为 INACTIVE 的日志组。

alter database drop logfile group 1;

alter database drop logfile group 2;

alter database drop logfile group 3;

#最后去os上删除老的日志组的物理文件

删除/u01/app/oradata/destdb/destdb/redo01、02、03.log

--------------------------------------分割线 --------------------------------------

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2

--------------------------------------分割线 --------------------------------------


推荐阅读
author-avatar
后悔不够狠
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有