Oracle使用logminer可以把oracle的redo log的信息看到,
当我看到logminer中的v$logmnr_contents视图中的信息,可以看到
这些字段里的具体内容有SCN,START_SCN,COMMIT_SCN,更让我奇怪的竟然是这里面竟然有一个rowid,难道说,记录的信息是按照row来算的?
这个动态视图的字段非常多,内容也非常多,
我看其中最小的单位是,rowid,其中还包括的存储单位,tablespace,segment ,table,data block,
也就是说,是按照最小的rowid
字段的内容还包括是执行的DML SQL语句,这也能说明,oracle在做checkpoint的时候
是根据redo中的信息来把是DBWN进程根据redo 日志中的信息来把
比较两个SCN,把SCN中的 redo的信息写入到datafile 里面
CKPT更新数据文件头里的SCN信息,
我看redo log中的信息有DML,有ROWID,有SEG_NAME,有TABLE_NAME,有TABLE_SPACE
有SESSION_ID,SQL_REDO,SQL_UNDO,有DATA_BLK#,有DATA_OBJ#,
ROWID这些字段的意义都是啥来着,ROWIDcan tell exactly where the row is
The physical addresss of this row
我想这条路我已经走到终点了
重点就是 logminer 挖掘出来的 redo log 里面的信息通过logminer分析redo日志的途径:
要安装LogMiner工具,必须首先要运行下面这样两个脚本,这两个脚本必须均以SYS用户身份运行。其中第一个脚本用来创建DBMS_LOGMNR包,该包用来分析日志文件。第二个脚本用来创建DBMS_LOGMNR_D包,该包用来创建数据字典文件。
1..$ORACLE_HOME/rdbms/admin/dbmslm.sql2. $ORACLE_HOME/rdbms/admin/dbmslmd.sql.
SQL> @d:\oracle\product\10.2.0\db_2\RDBMS\ADMIN\dbmslm.sql
程序包已创建。
授权成功。
SQL>@d:\oracle\product\10.2.0\db_2\RDBMS\ADMIN\dbmslmd.sql
程序包已创建。
使用LogMiner工具
1、创建数据字典文件(data-dictionary)
数据字典文件是一个文本文件,使用包DBMS_LOGMNR_D来创建。如果我们要分析的数据库中的表有变化,影响到库的数据字典也发生变化,这时就需要重新创建该字典文件。另外一种情况是在分析另外一个数据库文件的重作日志时,也必须要重新生成一遍被分析数据库的数据字典文件。
在ORACLE8I的时候,首先在init.ora初始化参数文件中,指定数据字典文件的位置,也就是添加一个参数UTL_FILE_DIR,该参数值为服务器中放置数据字典文件的目录。如:
UTL_FILE_DIR= (e:\Oracle\logs)
ORACLE9I后,推荐使用SPFILE启动,可以动态调整参数;
SQL>show parameter spfile
NAME TYPE VALUE
----------------------------------------------- ------------------------------
spfile string D:\ORACLE\PRODUCT\10.2.0\DB_2\
DATABASE\SPFILESGTEST2.ORA
SQL>alter system set utl_file_dir='d:\oracle\logs' scope=spfile;
系统已更改。
SQL>startup force
ORACLE 例程已经启动。
Total System Global Area 289406976bytes
FixedSize 1248600bytes
VariableSize 96469672bytes
DatabaseBuffers 188743680bytes
RedoBuffers 2945024bytes
数据库装载完毕。
数据库已经打开。
SQL>show parameter utl_file_dir
NAME TYPE VALUE
----------------------------------------------- ------------------------------
utl_file_dir string d:\oracle\logs
然后创建数据字典文件
SQL>@d:\dbms_logmnr_d.build.txt
PL/SQL 过程已成功完成。
脚本dbms_logmnr_d.build.txt
BEGIN
dbms_logmnr_d.build(
dictionary_filename=> 'logminer_dict.dat',
dictionary_location=> 'd:\oracle\logs');
END;
/
2、创建要分析的日志文件列表
Oracle的重作日志分为两种,在线(online)和离线(offline)归档日志文件,我这里主要分析归档日志,在线日志原理一样。
A.创建列表
SQL>execute dbms_logmnr.add_logfile(options =>dbms_logmnr.new,logfilename=>'D:\oracle\product\10.2.0\oradata\oracle9i\REDO01.LOG');
B.添加另外的日志文件到列表
SQL>execute dbms_logmnr.add_logfile(options=>dbms_logmnr.addfile,logfilename=>'D:\oracle\product\10.2.0\oradata\oracle9i\REDO02.LOG');
SQL>execute dbms_logmnr.add_logfile(options=>dbms_logmnr.addfile,logfilename=>'D:\oracle\product\10.2.0\oradata\oracle9i\REDO03.LOG');
删除
SQL> execute dbms_logmnr.add_logfile(options=>dbms_logmnr.removefile,logfilenam
e=>'D:\oracle\product\10.2.0\oradata\oracle9i\REDO03.LOG');
8.启动LogMiner进行分析
BEGIN
dbms_logmnr.start_logmnr(
dictfilename=> 'd:\oracle\logs\logminer_dict.dat');
END;
/
4、观察分析结果(v$logmnr_contents)
到现在为止,我们已经分析得到了重作日志文件中的内容。动态性能视图v$logmnr_contents包含LogMiner分析得到的所有的信息。
SELECTsql_redo FROM v$logmnr_contents;
对我来说,these things are total mess now ,because you know ,these
let me clear no
现在对我来说这些东西更像是一团乱麻,对的,就是一团乱麻
我觉得累了,也不再想去弄明白这些东西都是什么了xi
我只是脑子觉得累了,我在oracle的海洋里游泳游了两周
现在发现我喝了太多的oracle的海水,我现在要沉下去了
在沉下去之前,我想把我我在水里看到的东西记录下来
从哪个开始呢?
啊,让我们从redo开始吧,这是我开始这段旅程的原因