zoukankan      html  css  js  c++  java
  • Oracle调整联机日志大小

    近期一个项目反馈月底高峰期时系统整体性能下降,抓取对应的AWR和ASH查看,等待事件排第一位的竟然是redo日志切换。进一步看每秒的日志量是5M多,而日志文件大小仅有200M。建议项目上调整日志大小,经验证确认性能问题明显下降,现记录调整联机日志的操作。

    imageimage

    数据初始化日志有3组,每组50M。我们建议将日志添加到6组,根据实际情况设日志大小,建议设置为1~2G,我这里设成2G;

    归档模式下请确保所有日志已经归档,再进行日志文件大小的调整

    日志状态说明

    UNUSED未使用过的(新的)

    INACTIVE静态的(非激活状态)

    ACTIVE活动的(激活状态)

    CURRENT正在写的状态

    以下示例将重设联机日志,原三组各50M的日志改为六组各2G。

    第一步、查询联机日志大小及位置

    SQL> select group#,bytes/1024/1024,status from v$log;

    GROUP# BYTES/1024/1024 STATUS

    ------------------------------------------------------

    1 50 INACTIVE

    2 50 INACTIVE

    3 50 CURRENT

    这里有3组重做日志,每组50M,目前第3组日志正在写

    SQL> select * from v$logfile;

    GROUP# STATUS TYPE MEMBER

    ---------------- ---------------- ----------- ----------------------------------------

    1 ONLINE /data1/oracle/oradata/ora11r2/redo01.log

    2 ONLINE /data1/oracle/oradata/ora11r2/redo02.log

    3 ONLINE /data1/oracle/oradata/ora11r2/redo03.log

    第二步、添加新的日志组

    每组2048M,累计增加到6组日志

    SQL> alter database add logfile group 4 '/data1/oracle/oradata/ora11r2/redo04.log' size 2048M;

    Database altered.

    SQL> alter database add logfile group 5 '/data1/oracle/oradata/ora11r2/redo05.log' size 2048M;

    Database altered.

    SQL> alter database add logfile group 6 '/data1/oracle/oradata/ora11r2/redo06.log' size 2048M;

    Database altered.

    添加完成,再用第一步的SQL查看是否添加成功和大小

    SQL> select group#,bytes/1024/1024,status from v$log;

    GROUP# BYTES/1024/1024 STATUS

    ------------------------------------------------------

    1 50 INACTIVE

    2 50 INACTIVE

    3 50 CURRENT

    4 2048 UNUSED

    5 2048 UNUSED

    6 2048 UNUSED

    这里看到4、5、6三组日志已成功添加

    第三步、切换日志,并删除之前的日志组

    将日志切换到新建的日志组,删除之前的1、2、3日志组

    SQL> alter system switch logfile;

    Database altered.

    注意事项:删除日志组时,日志组状态要为非激活状态才可以删除(重启数据库,使得group1,group2,group3都是inactive状态)

    SQL> alter database drop logfile group 3;

    Database altered.

    SQL> alter database drop logfile group 2;

    Database altered.

    SQL> alter database drop logfile group 1;

    Database altered.

    日志组1、2、3成功删除

    SQL> select group#,bytes/1024/1024,status from v$log;

    GROUP# BYTES/1024/1024 STATUS

    ------------------------------------------------------

    4 2048 CURRENT

    5 2048 UNUSED

    6 2048 UNUSED

    这里看到只有4、5、6三组日志,表明已经成功将1、2、3删除

    注意事项:执行删除日志组命令后,其实只是在数据字典中删掉了对于日志信息。你到操作系统日志目录下查看,你会发现日志文件还在,只有手动删除,才能真正的删除日志文件。

    第四步、重建原日志组

    重建1、2、3日志组并将日志文件大小设为2048M

    SQL> alter database add logfile group 1 '/data1/oracle/oradata/ora11r2/redo01.log'size 2048M;

    Database altered.

    SQL> alter database add logfile group 2 '/data1/oracle/oradata/ora11r2/redo02.log' size 2048M;

    Database altered.

    SQL> alter database add logfile group 3 '/data1/oracle/oradata/ora11r2/redo03.log' size 2048M;

    Database altered.

    日志组1、2、3重建完成

    使用第1步、第2步的SQL查询验证

    SQL> select group#,bytes/1024/1024,status from v$log;

    GROUP# BYTES/1024/1024 STATUS

    ------------------------------------------------------

    1 2048 UNUSED

    2 2048 UNUSED

    3 2048 UNUSED

    4 2048 CURRENT

    5 2048 UNUSED

    6 2048 UNUSED

    SQL> select * from v$logfile;

    GROUP# STATUS TYPE MEMBER

    ---------------- ---------------- ----------- ----------------------------------------

    1 ONLINE /data1/oracle/oradata/ora11r2/redo01.log

    2 ONLINE /data1/oracle/oradata/ora11r2/redo02.log

    3 ONLINE /data1/oracle/oradata/ora11r2/redo03.log

    4 ONLINE /data1/oracle/oradata/ora11r2/redo04.log

    5 ONLINE /data1/oracle/oradata/ora11r2/redo05.log

    6 ONLINE /data1/oracle/oradata/ora11r2/redo06.log

  • 相关阅读:
    Hadoop一直处于安全模式(hadoop去掉保护模式)
    日考
    MySQL中文编码
    Mussel使用系列(二):开始写我们的第一个Mussel插件项目
    什么是Mussel
    Mussel使用系列(四):从容器中访问Mussel的插件项目
    Mussel使用系列(三):Mussel插件树的构成及初步使用
    Mussel使用系列(五):插件项目之间的调用
    Mussel使用系列(一):Mussel配置文件演示
    C#委托探索之猫和老鼠
  • 原文地址:https://www.cnblogs.com/zhaoguan_wang/p/4949232.html
Copyright © 2011-2022 走看看