Oracle使用块更改跟踪改善增量备份的性能

1.概述

增量备份的块更改跟踪功能,通过在块更改跟踪文件中的每个数据文件中记录更改的块来提高增量备份的性能。

此文件是存储在数据库区域中的小型二进制文件。

RMAN在生成重做时,跟踪更改的块。

如启用了块更改跟踪,则RMAN将使用更改跟踪文件来识别增量备份的更改块,从而避免扫描数据文件中的每个块。

RMAN仅在增量级别大于0时使用块更改跟踪,因为0级增量备份包括所有块。

2.检查是否开启块更改跟踪

sql 复制代码
COL STATUS   FORMAT A8
COL FILENAME FORMAT A60
SELECT STATUS,FILENAME FROM V$BLOCK_CHANGE_TRACKING;

3.启用块更改跟踪

sql 复制代码
--确保已设置初始化参数
SHOW PARAMETER DB_CREATE_FILE_DEST

--如果未设置参数,并且数据库已打开,则执行以下命令
ALTER SYSTEM SET DB_CREATE_FILE_DEST = '/disk1/bct/' SCOPE=BOTH SID='*';

--启用块更改跟踪
ALTER DATABASE ENABLE BLOCK CHANGE TRACKING;
或者指定位置创建块更改跟踪文件
ALTER DATABASE ENABLE BLOCK CHANGE TRACKING USING FILE '/mydir/rman_change_track.f' REUSE;
注意:REUSE选项告知 Oracle 数据库使用指定名称覆盖任何现有的块更改跟踪文件。

4.禁用块更改跟踪

sql 复制代码
ALTER DATABASE DISABLE BLOCK CHANGE TRACKING;
注意:禁用后,数据库将从操作系统中删除块更改跟踪文件。

5.更改块更改跟踪文件的位置

sql 复制代码
--确认当前位置
COL STATUS FORMAT A8
COL FILENAME FORMAT A60
SELECT STATUS,FILENAME FROM V$BLOCK_CHANGE_TRACKING;

--关闭数据库
SHUTDOWN IMMEDIATE

--使用操作系统命令,将更改跟踪文件移动到新的位置
mv rman_change_track.f /new

--执行命令移动至新位置
ALTER DATABASE RENAME FILE '/disk1/bct/RDBMS/changetracking/o1_mf_2f71np5j_.chg' TO '/disk2/bct/RDBMS/changetracking/o1_mf_2f71np5j_.chg';

--打开数据库
ALTER DATABASE OPEN;

--如果情况不允许,无法关闭数据库,则执行以下命令
ALTER DATABASE DISABLE BLOCK CHANGE TRACKING;
ALTER DATABASE ENABLE BLOCK CHANGE TRACKING USING FILE 'new_location';

在这种情况下,将丢失块更改跟踪文件的内容。在下次完成 0 级增量备份之前,RMAN 必须扫描整个文件。
相关推荐
hao_wujing8 分钟前
攻击模型的恶意行为检测
网络·数据库·php
秃头摸鱼侠1 小时前
MySQL查询语句(续)
数据库·mysql
MuYiLuck1 小时前
【redis实战篇】第八天
数据库·redis·缓存
睡觉待开机1 小时前
6. MySQL基本查询
数据库·mysql
大熊猫侯佩2 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(三)
数据库·swiftui·swift
大熊猫侯佩2 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(二)
数据库·swiftui·swift
大熊猫侯佩2 小时前
用异步序列优雅的监听 SwiftData 2.0 中历史追踪记录(History Trace)的变化
数据库·swiftui·swift
大熊猫侯佩2 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(一)
数据库·swiftui·swift
Ares-Wang2 小时前
负载均衡LB》》HAproxy
运维·数据库·负载均衡
AI.NET 极客圈2 小时前
.NET 原生驾驭 AI 新基建实战系列(四):Qdrant ── 实时高效的向量搜索利器
数据库·人工智能·.net