热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

重做日志文件基本维护简析

重做日志文件最重要的用途就是用来恢复数据(其实你也可以用来logminer),它记录着systemglobalarea(sga)当中的databasebuffercache(高速缓存区)的所有变更信息,记录到logbuffer;不过在某些特殊...SyntaxHighlighte

重做日志文件最重要的用途就是用来恢复数据(其实你也可以用来logminer),它记录着system global area(sga)当中的database buffer cache(高速缓存区)的所有变更信息,记录到log buffer;不过在某些特殊情况下比如sqlldr direct等直接写入操作例外,这些例外将不会被记录。因此,使用redo log在实例崩溃情况下来恢复尚未写入数据文件的的数据。  www.2cto.com  
 
针对每个实例,只有一个写进程LGWR;重做日志文件建议至少两个组,每个组至少两个成员文件,同一个组内的成员之间是内容相同的副本拷贝,同组内的成员大小保持一致,当然建议所有的成员大小都一致,为了避免相关的LGWR等待影响数据库性能,一个比较有用的建议是将成员文件在物理磁盘上分散存放。
 
提到重做日志文件不得不提到重做日志缓存区log buffer,以及一个重要的进程LGWR日志写进程,该进程负责建log buffer的内容写入到redo logfile,具体的触发条件如下:
 
◆ 当发出commit命令的时候
◆ 当log buffer的空间写满到1/3的时候或者当log buffer的空间写满1MB的记录的时候
◆ 当每3秒钟超时的时候
◆ 当DBWn需要写入数据文件的操作之前的时候
◆ 当切换日志文件的时候
 
0. 查看日志文件
SELECT group#, sequence#, bytes, members, status  FROM v$log;--组号、序列号、大小、成员数量、状态【UNUSED-从未使用过;CURRENT-当前使用中;ACTIVE-活动的,进行恢复的使用将会被用到;INACTIVE-非活动的;CLEARING_CURRENT-正在清除当前日志文件中已经关闭的线程;CLEARING-类似的,在执行ALTER DATABASE CLEAR LOGFILE之后将被清空为空日志之后将转化为UNUSED】
 
select * from v$logfile;--状态【INVALID-该文件不可访问;STALE-该文件内容不完全,比如正在添加一个文件成员;DELETED-该文件不再被使用;空白-正在使用】
SELECT groups, current_group#, sequence# FROM v$thread;--组数量、当前组、序列号
 
1. 查看log buffer  www.2cto.com  
show parameter log_buffer
伴随着重做日志而来的还有一个重要的信息,那就是是否将日志文件进行归档。数据库可以运行在归档模式(archivelog)和非归档模式(noarchivelog)下。
2. 查看归档模式
archive log list;
select log_mode from v$database;
select archiver from v$instance;
3. 归档方式切换
为了简单,这里使用oracle 10g来演示。
SQL*Plus: Release 10.2.0.5.0 - Production on Tue May 8 15:49:39 2012
 
Copyright (c) 1982, 2010, Oracle.  All Rights Reserved.
 
Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
 
SQL> archive log list;
Database log mode           No Archive Mode
Automatic archival           Disabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     158
Current log sequence           160
--目前未归档,我们要切换为归档,首先设置归档目录
SQL> alter system set log_archive_dest_1='location=/u01/oracle/10g/arch' scope=spfile;
 
System altered.
--关闭数据库
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
--启动实例mount状态
SQL> startup mount;    
ORACLE instance started.
 
Total System Global Area 1610612736 bytes
Fixed Size            2096632 bytes
Variable Size          469762568 bytes
Database Buffers     1124073472 bytes
Redo Buffers           14680064 bytes
Database mounted.
--打开归档模式
SQL> alter database archivelog;
  www.2cto.com  
Database altered.
--打开数据库
SQL> alter database open;
 
Database altered.
--检查归档模式
SQL> archive log list;
Database log mode           Archive Mode
Automatic archival           Enabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     158
Next log sequence to archive   160
Current log sequence           160
 
--手工切换日志文件
SQL> archive log list;
Database log mode           Archive Mode
Automatic archival           Enabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     159
Next log sequence to archive   161
Current log sequence           161
SQL> alter system switch logfile;
 
System altered.
 
SQL> archive log list;
Database log mode           Archive Mode
Automatic archival           Enabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     160
Next log sequence to archive   162
Current log sequence           162
 
SQL> alter system archive log current;
 
System altered.
 
SQL> archive log list;
Database log mode           Archive Mode
Automatic archival           Enabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     161
Next log sequence to archive   163
Current log sequence           163
 
--切换为非归档模式
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup mount;
ORACLE instance started.
 
Total System Global Area 1610612736 bytes
Fixed Size            2096632 bytes
Variable Size          469762568 bytes
Database Buffers     1124073472 bytes
Redo Buffers           14680064 bytes
Database mounted.
SQL> alter database noarchivelog;
 
Database altered.
 
SQL> alter database open;
  www.2cto.com  
Database altered.
 
SQL> archive log list;
Database log mode           No Archive Mode
Automatic archival           Disabled
Archive destination           /u01/oracle/10g/arch
Oldest online log sequence     158
Current log sequence           160
 
4. 日志文件维护
4.1. 增加日志组
sys@GT9I> select group# from v$log;
 
    GROUP#
----------
     1
     2
     3
 
sys@GT9I> select group#,member from v$logfile order by 1;
 
    GROUP# MEMBER
---------- --------------------------------------------------
     1 /u01/oracle/9i/oradata/gt9i/redo01.log
     2 /u01/oracle/9i/oradata/gt9i/redo02.log
     3 /u01/oracle/9i/oradata/gt9i/redo03.log
 
现在增加一组包含2个成员的日志组:
sys@GT9I>  alter database add logfile group 4 ('/u01/oracle/9i/oradata/gt9i/redo04a.log','/u01/oracle/9i/oradata/gt9i/redo04b.log') size 20M;
 
Database altered.
 
sys@GT9I> select group# from v$log;
 
    GROUP#
----------
     1
     2
     3
     4
 
sys@GT9I> select group#,member from v$logfile order by 1;
 
    GROUP# MEMBER
---------- --------------------------------------------------
     1 /u01/oracle/9i/oradata/gt9i/redo01.log
     2 /u01/oracle/9i/oradata/gt9i/redo02.log
     3 /u01/oracle/9i/oradata/gt9i/redo03.log
     4 /u01/oracle/9i/oradata/gt9i/redo04a.log
     4 /u01/oracle/9i/oradata/gt9i/redo04b.log
 
4.2. 增加日志成员
sys@GT9I>  alter database add logfile  member '/u01/oracle/9i/oradata/gt9i/redo04c.log' to group 4;
 
Database altered.
 
sys@GT9I> select group#,member from v$logfile order by 1;
 
    GROUP# MEMBER
---------- --------------------------------------------------
     1 /u01/oracle/9i/oradata/gt9i/redo01.log
     2 /u01/oracle/9i/oradata/gt9i/redo02.log
     3 /u01/oracle/9i/oradata/gt9i/redo03.log
     4 /u01/oracle/9i/oradata/gt9i/redo04a.log
     4 /u01/oracle/9i/oradata/gt9i/redo04b.log
     4 /u01/oracle/9i/oradata/gt9i/redo04c.log
  www.2cto.com  
可以看到在添加成员的时候没有使用文件大小的属性选项,这是因为同组内的成员应当保持大小一致。
4.3. 删除日志成员
sys@GT9I>  alter database drop logfile  member '/u01/oracle/9i/oradata/gt9i/redo04c.log';
 
Database altered.
 
sys@GT9I> select group#,member from v$logfile order by 1;
 
    GROUP# MEMBER
---------- --------------------------------------------------
     1 /u01/oracle/9i/oradata/gt9i/redo01.log
     2 /u01/oracle/9i/oradata/gt9i/redo02.log
     3 /u01/oracle/9i/oradata/gt9i/redo03.log
     4 /u01/oracle/9i/oradata/gt9i/redo04a.log
     4 /u01/oracle/9i/oradata/gt9i/redo04b.log
 
4.4. 删除日志组
sys@GT9I>  alter database drop logfile group 4
  2  ;
 
Database altered.
 
sys@GT9I> select group# from v$log;
 
    GROUP#
----------
     1
     2
     3
 
sys@GT9I> select group#,member from v$logfile order by 1;
 
    GROUP# MEMBER
---------- --------------------------------------------------
     1 /u01/oracle/9i/oradata/gt9i/redo01.log
     2 /u01/oracle/9i/oradata/gt9i/redo02.log
     3 /u01/oracle/9i/oradata/gt9i/redo03.log
5. 日志挖掘
日志挖掘也即是logminer。
首先创建字典文件。
sys@GT9I> alter system set utl_file_dir='/u01/oracle/9i/oradata/gt9i/dict' scope=spfile;
 
System altered.
 
sys@GT9I> startup force;
ORACLE instance started.
 
Total System Global Area  286752136 bytes
Fixed Size             740744 bytes
Variable Size          150994944 bytes
Database Buffers      134217728 bytes
Redo Buffers             798720 bytes
Database mounted.
Database opened.
 
sys@GT9I>
1 BEGIN
2 DBMS_LOGMNR_D.build (
3 dictionary_filename => 'mydict1.ora',
4 dictionary_location => '/u01/oracle/9i/oradata/gt9i/dict');
5 END;  www.2cto.com  
6 /
PL/SQL procedure successfully completed.
做些测试,我这里用另外一个用户执行创建表、插入、删除操作,还创建了一个过程,最后删除表和过程。
 
添加日志文件
查看下当前的日志文件:
sys@GT9I> select status,member from v$logfile;
 
STATUS       MEMBER
---------- --------------------------------------------------
       /u01/oracle/9i/oradata/gt9i/redo03.log
STALE       /u01/oracle/9i/oradata/gt9i/redo02.log
STALE       /u01/oracle/9i/oradata/gt9i/redo01.log
 
sys@GT9I> select * from v$log;
 
    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS     FIRST_CHANGE# FIRST_TIM
---------- ---------- ---------- ---------- ---------- --- ---------- ------------- ---------
     1        1          12  104857600         1 NO  INACTIVE        3389635 16-MAY-12
     2        1          10  104857600         1 NO  INACTIVE        3099675 14-MAY-12
     3        1          13  104857600         1 NO  CURRENT        3414320 16-MAY-12
这里是group=3的组是当前组。
BEGIN
DBMS_LOGMNR.add_logfile (
options     => DBMS_LOGMNR.new,
logfilename => '/u01/oracle/9i/oradata/gt9i/redo03.log');
/*
DBMS_LOGMNR.add_logfile (
options     => DBMS_LOGMNR.addfile,
logfilename => '/u01/oracle/9i/oradata/gt9i/redo01.log');
 
DBMS_LOGMNR.add_logfile (
options     => DBMS_LOGMNR.addfile,
logfilename => '/u01/oracle/9i/oradata/gt9i/redo02.log');
*/
END;
/
开始挖掘
首先开启参数,否则无法挖掘到ddl语句。
alter database add supplemental log data;
 
BEGIN
DBMS_LOGMNR.start_logmnr (
dictfilename => '/u01/oracle/9i/oradata/gt9i/dict/mydict1.ora',
starttime    => TO_DATE('20120516 16:20:00','yyyymmdd hh24:mi:ss'),
endtime      => TO_DATE('20120516 16:28:00','yyyymmdd hh24:mi:ss'));
END;
/
接着可以查询挖掘到的内容,注意必须在同一个会话内进行查询:
Select Scn, Operation, Sql_Redo, Sql_Undo From V$logmnr_Contents;
最后停止挖掘:
BEGIN  www.2cto.com  
DBMS_LOGMNR.end_logmnr;
END;
/
以上测试在9i测试通过,但是9i当中无法找到DDL语句;相反,找10g当中可以看到insert、delete等DDL语句,但是在10g当中开启挖掘的语句和9i的不一样,9i的开始挖掘语句在10g当中执行报错:缺失日志文件,可以使用如下语句开始挖掘:
Declare
Begin
   dbms_logmnr.start_logmnr(dictfilename =>'/u01/oracle/9i/oradata/gt9i/dict/mydict2.ora');
End;
 
-The End-
 
 
作者 gtlions

推荐阅读
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • SQL中UPDATE SET FROM语句的使用方法及应用场景
    本文详细介绍了SQL中UPDATE SET FROM语句的使用方法,通过具体示例展示了如何利用该语句高效地更新多表关联数据。适合数据库管理员和开发人员参考。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文详细介绍了如何使用ActionScript 3.0 (AS3) 连接并操作MySQL数据库。通过具体的代码示例和步骤说明,帮助开发者理解并实现这一过程。 ... [详细]
  • 在即将迎来26岁生日之际,作者的人生陷入了低谷。经过近三年的硕士学习后,最终决定退学,并且面临没有工作经验的困境。尽管如此,作者依然坚定地选择为自己的人生负责。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 本文详细介绍了美国最具影响力的十大财团,包括洛克菲勒、摩根、花旗银行等。这些财团在历史发展过程中逐渐形成,并对美国的经济、政治和社会产生深远影响。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
author-avatar
mobiledu2502918487
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有