• Thread 1 cannot allocate new log 的处理办法


    日志存储路径:

    D:appAdministratordiag dbmsorclorclalert(警告)

    D:oracle_dataorclREDOxx.LOG

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

    增加日志组:

    1、select group#,sequence#,bytes,members,status from v$log; 查看每组日志的状态

         select * from v$logfile; 查看日志路径
    GROUP# SEQUENCE# BYTES MEMBERS STATUS
    ---------- ---------- ---------- ---------- ----------------
    1 16946 52428800 1 INACTIVE ## 空闲的
    2 16947 52428800 1 INACTIVE ## 空闲的
    3 16948 52428800 1 CURRENT ##正在使用的
    2、

    alter database add logfile group 4 ('/opt/oradata/orclbj/redo04.log') size 200M; 增加1组日志组 视情况而定增加日志组的大小。

    alter database add logfile group 5 ('/opt/oradata/orclbj/redo05.log') size 200M;
    alter database add logfile group 6 ('/opt/oradata/orclbj/redo06.log') size 200M;
    3、alter system switch logfile; 切换日志组

    4、alter database drop logfile group 1; 删除日志组1 在线增加日志组的时候,删除日志组的时候只能删除 日志组状态为 INACTIVE 的日志组。
    ————————————————
    原文链接:https://blog.csdn.net/zonelan/article/details/7613519

    修改db_recovery_file_dest_size 修改大一点及删除归档日志:

    https://blog.csdn.net/e_wsq/article/details/78577270

  • 相关阅读:
    get函数理解
    get函数理解
    Absolute C++ 第9章字符串 编程练习4
    Absolute C++ 第9章字符串 编程练习4
    Absolute C++ 第9章字符串 编程练习4
    Absolute C++ 第9章字符串 编程练习4
    C字符串使用陷阱 “=”和“==” 学习笔记
    [Android]ListView中分割线的设置
    如何在adapter 中调用activity的方法
    Android开发中Handler的经典总结
  • 原文地址:https://www.cnblogs.com/nsw2018/p/15005383.html
Copyright © 2020-2023  润新知