zoukankan      html  css  js  c++  java
  • 重建redo文件

    需求背景

      由于前期安装oracle时redo文件大小或者路径规划不合理需要进行修改,以便满足性能测试要求。redo文件规划大小建议与生产环境一致。

    重做日志相关数据字典

      1、v$log  记录数据库中有多少个重做日志组,每个组中有多少个成员、日志大小及状态

      2、v$logfile 记录着每个日志组成员的属性、文件路径、文件名、状态等

    操作步骤

      1、查看现有日志组及重做文件大小

    SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log;
    
        GROUP#  SEQUENCE#     SIZEMB    MEMBERS     STATUS
    ---------- ---------- ---------- ----------   ---------  
             1    27             50          1     INACTIVE
             2    28             50          1     CURRENT
             3    29             50          1     INACTIVE

      STAUS状态值说明:

    inactive:表示实例恢复已不再需要这组联机重做日志组了。
    active:表示该组是活动的但不是当前组,实例恢复时需要这组日志。
    current:表示该组日志是当前组,该联机重做日志组是活动的,当前正在使用。
    unused:表示该日志组从未写过,是重做日志刚刚添加到状态。

      2、查看当前重做日志文件的状态和路径

    SQL> select group#,status,type,member from v$logfile;
    
        GROUP# STATUS  TYPE    MEMBER
    ---------- ------- ------- ---------------------------------------------
             3  ONLINE  /home/oracle/oradata/ora11g/redo03.log
             2  ONLINE  /home/oracle/oradata/ora11g/redo02.log
             1  ONLINE  /home/oracle/oradata/ora11g/redo01.log

      STATUS状态说明:

    空白:表示该文件正在使用。
    stale:表示该文件中的内容是不完全的。
    invalid:表示该文件是不可以被访问的。
    deleted:表示该文件已不再有用了。

      3、新增创建重做日志文件组group 4、group 5、group 6,文件大小设置为1000M。

    SQL> alter database add logfile group 4('/dev/vgoracle/lvredo4.log') size 1000M;
    
    Database altered.
    
    SQL> alter database add logfile group 5('/dev/vgoracle/lvredo5.log') size 1000M;
    
    Database altered.
    
    SQL> alter database add logfile group 6('/dev/vgoracle/lvredo6.log') size 1000M;
    
    Database altered.

      4、执行alert system switch logfile命令进行多次切换,直至group 4或者group 5日志组的状态为current。

    SQL> alter system switch logfile;
    
    System altered.
    
    SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log;
    
        GROUP#  SEQUENCE#     SIZEMB    MEMBERS     STATUS
    ---------- ---------- ---------- ----------   ---------  
             1    27             50          1     INACTIVE
             2    28             50          1     ACTIVE
             3    29             50          1     INACTIVE
             4    30             50          1     CURRENT
             5    31             50          1     NOUSE
             6    32             50          1     NOUSE

    5、执行alter system checkpoint手工执行同步数据,将redo文件记录写入数据文件。确保group 1、group 2、group 3文件组状态为INACTIVE。

    SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log;
    
        GROUP#  SEQUENCE#     SIZEMB    MEMBERS     STATUS
    ---------- ---------- ---------- ----------   ---------  
             1    27             50          1     INACTIVE
             2    28             50          1     INACTIVE
             3    29             50          1     INACTIVE
             4    30             50          1     CURRENT
             5    31             50          1     NOUSE
             6    32             50          1     NOUSE

      6、当日志组处于INACTIVE状态是,可以执行drop操作删除。对应的OS文件需手工删除。

    SQL> alter database drop logfile group 1;
    
    Database altered.
    
    SQL> alter database drop logfile group 2;
    
    Database altered.
    
    SQL> alter database drop logfile group 3;
    
    Database altered.

     7、操作完成。重新查看重做日志文件组状态

    SQL> select group#,sequence#,bytes/1024/1024 sizeMB,members,status from v$log;
    
        GROUP#  SEQUENCE#     SIZEMB    MEMBERS     STATUS
    ---------- ---------- ---------- ----------   ---------  
             4    30             1000          1     ACTIVE
             5    31             1000          1     NOUSE
             6    32             1000          1     NOUSE

    说明:如果习惯使用日志组1/2/3,可以按照上述过程重新操作一遍即可。

    8、清理被替换的redo文件

    rm /home/oracle/oradata/ora11g/redo01.log
    rm /home/oracle/oradata/ora11g/redo02.log
    rm /home/oracle/oradata/ora11g/redo03.log
  • 相关阅读:
    NLP(十六):Faiss应用
    推荐系统(一):DeepFm原理与实战
    NLP(十五):word2vec+ESIM进行文本相似度计算
    NLP(十四):Transformer—用BERT,RoBERTa,XLNet,XLM和DistilBERT文本分类
    1.22学习总结:流计算概述
    1.21学习总结:将RDD转换成DataFrame
    1.20学习总结:DataFrame保存及常用操作
    1.19学习总结:SparkSQL
    1.18学习总结:Spark向HBase写入数据
    1.17学习总结:编写程序读取HBase数据
  • 原文地址:https://www.cnblogs.com/linyfeng/p/7535286.html
Copyright © 2011-2022 走看看