参数CONTROL_FILE_RECORD_KEEP_TIME和MAXLOGHISOTRY

--**************************************************

-- 参数 CONTROL_FILE_RECORD_KEEP_TIME 和MAXLOGHISOTRY

--**************************************************

参数 control_file_record_keep_time 是一 个 位于控制文件中比 较 重要的 参数 之一。 它决 定了控制文件里可重 复 使用的 记录 所能保存的

最小天 数 。 当 一 条 新的 记录 需要添加到可重用 记录 的空 间时 , 并 且最老的 记录 在可重用 记录 空 间 中 还没 有老化,即 实际 保留的天 数 未超 过这

个参数规 定的天 数 , 则 控制文件中可重用 记录 部分的空 间将 被自 动扩 展,此 时 控制文件尺寸 将会变 大。

一、control_file_record_keep_time 定 义 信息

1 . 参数 的描述信息

Property Description

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

Parameter type Integer

Default value 7 (days) -- 缺省

Modifiable ALTER SYSTEM -- 使用ALTER SYSTEM 修改

Range of values 0 to 365 (days) -- 的范 围从 0-365

Basic No

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

2 . 官方定 义

CONTROL_FILE_RECORD_KEEP_TIME specifies the minimum number of days before a reusable record in the control file

can be reused. In the event a new record needs to be added to a reusable section and the oldest record has not

aged enough, the record section expands. If this parameter is set to 0 , then reusable sections never expand ,

and records are reused as needed.

Note:

This parameter applies only to records in the control file that are circularly reusable (such as archive log

records and various backup records ). It does not apply to records such as datafile , tablespace , and redo

thread records , which are never reused unless the corresponding object is dropped from the tablespace.

3 . 可重用的模 块

ARCHIVED LOG BACKUP CORRUPTION

BACKUP DATAFILE BACKUP PIECE

BACKUP REDO LOG BACKUP SET

COPY CORRUPTION DATAFILE COPY

DELETED OBJECT LOGHISTORY

OFFLINE RANGE

二、MAXLOGHISOTRY

这个参数 ,咋一看,貌似眼熟的不得了。 没错 ,在 创 建控制文件的 时 候被使用。

没 印象? 参 考 这 里: Oracle 控制文件( CONTROLFILE )

从 字面上的意思 来 分析即可知, 该参数 用于控制日志 历 史 记录 。即 归档 日志的 记录数应 在控制文件 设 定 MAXLOGHISOTRY 参数 的范 围

之 内 ,或者 说 v$log_history 视图 里所有 归档 日志文件 总数 必 须 小于等于 MAXLOGHISOTRY 的 设 定 值 。

一旦 归档 日志超 过这个 最大 数 目,且 参数 control_file_record_keep_time 设 定的 值 在 备份 的保留策略之外,即可以被重用或老化

, 则从头 覆盖以前的 归档 志文件 项 。也即是 v$log_history 里的相 应记录会 被 清 除。

事 实 上, 当 在初始化控制文件的 时 候, 设 定 MAXLOGHISOTRY 的 值来决 定 为 保存 归档 日志 记录 信息分配多大的空 间 。 该值设 定之后,

其分配的空 间将 不再 动态扩 展。我 们 知道 RMAN 备份 恢 复 ,日志 归档时 的信息都 将 存 储 在控制文件或恢 复 目 录 之中。 既 然已分配存 储 空 间

不能自 动扩 展,那新的 归档 信息 该 如何追加呢?即由 参数 control_file_record_keep_time 中保留 时间来 确定是否 将过时 的信息 给 覆盖。

注:v$log_history 在Oracle 8 i 后由v$archived_log 代替。 并 且 maxloghistory 不限制能 够插 入到 v$archived_log 中的 记录数 。

SQL > select * from v$version;

BANNER

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

Oracle Database 10 g Enterprise Edition Release 10.2 .0.4.0 - 64 bi

PL / SQL Release 10.2 .0.4.0 - Production

CORE 10.2 .0.4.0 Production

TNS for Solaris: Version 10.2 .0.4.0 - Production

NLSRTL Version 10.2 .0.4.0 - Production

-- 看几 最大的 MAX 置的

SQL > select TYPE ,RECORDS_TOTAL from v$controlfile_record_section

2 where type in ( 'REDO LOG' , 'DATAFILE' , 'CKPT PROG%' , 'REDO THREAD' , 'ARCHIVED LOG' );

TYPE RECORDS_TOTAL

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

REDO THREAD 8 --> MAXINSTANCES

REDO LOG 32 --> MAXLOGFILES

DATAFILE 968 --> MAXDATAFILES

ARCHIVED LOG 83536 --> MAXLOGHISTORY

-- ARCHIVED LOG 的明 信息

SQL > select * from v$controlfile_record_section where type like '%ARCHIVED LOG%' ;

TYPE RECORD_SIZE RECORDS_TOTAL RECORDS_USED FIRST_INDEX LAST_INDEX LAST_RECID

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

ARCHIVED LOG 584 83536 83536 52748 52747 679267

从 上面的 查询 中可以看到 为 MAXLOGHISTORY 分配的空 间 大小以及 记录总数 ,已是使用的 记录总数 。

视图 v$archived_log 中 记录 的 归档 日志 数

SQL > select count (*) from v$archived_log;

COUNT (*)

----------

83536

SQL > select min (FIRST_TIME), min (COMPLETION_TIME), max (FIRST_TIME), max (COMPLETION_TIME) from

2 v$archived_log;

MIN (FIRST_TIME) MIN (COMPLETION_TIME MAX (FIRST_TIME) MAX (COMPLETION_TIME

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

2011 - 04 - 24 12 : 59 : 01 2011 - 04 - 24 13 : 02 : 00 2011 - 06 - 05 23 : 00 : 49 2011 - 06 - 06 03 : 19 : 21

在使用RMAN 备份 且 备份 信息 没 有使用恢 复 目 录 的情 况 下,即使用控制文件 来 存 储 恢 复 信息。那 么 control_file_record_keep_time

中 设 定的 值应当轻 量 级 得大于 应 用所需 备份 保留的 时间 ( 基于 时间 的保留 参数 ) 。

假定使用控制文件保存 备份 恢 复 信息,每周 进 行一次全 备 ,且 备份 保留恢 复 窗口 为 7 天, 则 建 议将 control_file_record_keep_time

设 置 为 10 或14 。

三、 Log History 超出MAXLOGHISTORY 的情形

有些情 况 下, Log History 超出MAXLOGHISTORY 的情形,什 么 ? Log History 超出MAXLOGHISTORY ?那不是 会 自 动扩 展 吗 ?是的,正常

情 况 下 应当扩 展控制文件。 Log History 大于MAXLOGHISTORY 而 没 有自 动 控制 扩 展的情形是存在的。 产 生 该 情 况则 是空 间 分配所引起的。

假定有下面的情形, 创 建控制文件 时 指定 MAXLOGHISTORY 的 值为 100 ,而Log History 中 则 保留了 227 条记录 。 Why ?

在 创 建控制文件 时 , 会为 每 个 部分分配相 应 的大小和空 间 。而每 个 部分的空 间 分配根据 Oracle 的 块 而不是依据 当时设 定的 记录数 。

在控制文件中, log history 的 单条记录 大小通常是固定的, 为 36 字 节 。因此, 100 个记录 ( MAXLOGHISTORY )需要3600 个 字 节 。控制文

件 块 的大小 与数 据 块 的大小一 样 ,同 样 有 db_block_size 控制。因此特定 数 目的 块将为 Log History 部分分配。例如,如果

DB_BLOCK_SIZE 为 8192 ,那 么 一 个块 就足 够 了。在 这个块 中,我 们 有 8192/ 36 ,大 约 227 个记录 。如果 DB_BLOCK_SIZE 为 2048 ,那 么将 分

配2 个 快,但是只 创 建 113 个记录 。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

使用shell批量监控磁盘坏块(二) (r7笔记第80天)

之前分享了第一篇 使用shell批量监控磁盘坏块(一),今天来简单说说这个需求的实现内容 。 首先主要思路是通过中控的机器来发送监控的细节,然后返回结果。 ?...

3674
来自专栏杨建荣的学习笔记

关于Flashback的小测试(r10笔记第15天)

对于Oracle的Flashback来说,在11g里面有了一个很细微的变化,可以说是一个很不错的福利,那就是开启闪回不需要重启数据库至mount状态下,...

3414
来自专栏Java学习123

IBM WebSphere MQ 系列(四) 使用MQ命令

7046
来自专栏乐沙弥的世界

Oracle OWI 等待事件视图(v$session_wait/v$session_event/v$system_event)

    通常情况下,用户提交一条SQL语句,总会存在这样或那样的等待事件。也就是说由于所需资源被占用导致进程不得不处于等待状态。Oracle为我们提供了获取这些...

1013
来自专栏乐沙弥的世界

Oracle 密码文件

DBA用户:具有sysdba,sysoper权限的用户被称为dba用户。默认情况下sysdba角色中存在sys用户,sysoper角色中存在system用户

1304
来自专栏码匠的流水账

nginx lua重置请求参数及常量备忘

2441
来自专栏张戈的专栏

[svn: E155004]svn update报database is locked错误的解决办法

今天突然发现项目更新脚本在拉代码的时候抛出了一个如下错误: svn: E155004: Working copy '/home/svn/***/trunk/st...

1.3K8
来自专栏杨建荣的学习笔记

记一次dg故障的处理总结(r6笔记第63天)

今天早上收到一条报警短信,提示是dg的接收出了问题,从v$dataguard_status得到的最新记录如下: 2015-09-18 07:13:36.0 Fe...

2665
来自专栏PHP在线

如何将 Text, XML, CSV 数据文件导入 MySQL

原文出处: freenik@Jianshu 将 外部数据导入(import)数据库是在数据库应用中一个很常见的需求。其实这就是在数据的管理和操作中的ETL (...

3808
来自专栏乐沙弥的世界

delete archivelog all 无法彻底删除归档日志?

    最近在因归档日志暴增,使用delete archivelog all貌似无法清除所有的归档日志,到底是什么原因呢?

941

扫码关注云+社区

领取腾讯云代金券