Oracle的块修改跟踪

Block chage tracking是 Oracle10g 的一个新特性,Block change tracking进程记录自从上一次0级备份以来数据块的变化,并把这些信息记录在跟踪文件中。RMAN使用这个文件判断增量备份中需要备份的变更数据。这极大的提高了备份性能和速度,RMAN可以不再扫描整个文件以查找变更数据。

 默认情况下数据库是禁用块修改跟踪的(如果使用了OMF特性,ORACLE会自动创建块修改跟踪文件),因为这可能会带来一些额外的开销。不过该特性对于增量备份毕竟相当有用,因此要看你的取舍,如果你的数据库极少有修改操作,同时你希望增量备份尽可能快,并且创建的增量备份集尽可能小,那启用块修改跟踪还是有意义的,并且这也不会太影响到数据库的性能。

块修改跟踪文件是基于整个数据库的,如果使用了OMF,该文件创建于DB_CREATE_FILE_DEST参数指定的目录下,当然你也可以手动修改该文件到其它路径,不过如果是RAC环境,块修改跟踪文件必须创建在共享存储上,确保所有节点都能访问到它。块修改跟踪文件中最多只能保存基于相同0级的,最近8天的增量备份所需信息,因此如果超出,则块修改跟踪文件就起不到作用了。

#启用块修改跟踪功能,并创建修改跟踪问文件

SQL>alter database enable block change tracking using file'/orabackup/ore01/blocktraces/changed_block_tracking.log';

Database altered.

SQL>

# 判断当前设置可以查询视图v$block_change_tracking,该视图记录了块修改跟踪文件的状态, 路径及文件大小

SQL> desc v$block_change_tracking;

 Name                        Null? Type

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

 STATUS                           VARCHAR2(10)

 FILENAME                        VARCHAR2(513)

 BYTES                           NUMBER

 

SQL> select * from v$block_change_tracking;


STATUS     FILENAME                                                                                             BYTES
---------- ------------------------------------------------------------------------------------   ----------------
ENABLED    /oradata/seven/blocktraces/changed_block_tracking.log     11599872

SQL>


#启用Block Change Tracking功能后,Oracle会启动一个ctwr进程,这个进程负责跟踪数据的变化。

[oracle@DBA2 bin]$ ps -ef|grep ctwr
oracle   12468     1  1 16:41 ?        00:00:00 ora_ctwr_orcl2


#关闭块修改跟踪功能. 同时该命令也会导致块修改跟踪文件的清除。

SQL> alter database disable block change tracking;

Database altered.




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

版权所有,转载请注明作者及原文链接,否则追究法律责任!

QQ:      584307876

作者:    Seven

原文链接:  http://blog.csdn.net/sunjiapeng/article/details/8468457

邮箱:     [email protected]

你可能感兴趣的:(Oracle的块修改跟踪)