Oracle中全量CHECKPOINT和增量CHECKPOINT的区别与作用

2024-05-16 10:28

本文主要是介绍Oracle中全量CHECKPOINT和增量CHECKPOINT的区别与作用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

全量CHECKPOINT和增量CHECKPOINT对用户都是透明的,而增量CHECKPOINT只不过是将全量CHECKPOINT要写的脏块分时间分批次写到数据文件中而已,此操作可以极大地减少对数据库性能的影响。

  1. 全量CHECKPOINT
    全量CHECKPOINT是指DBWR进程将脏缓冲区列表中的脏块一次性地写入数据文件中。该操作可以简单地分为2个步骤(这里假设执行全量CHECKPOINT的时间点为t1):
    (1)DBWR进程将t1时间点前的所有脏块写到数据文件。如果脏块很多,将引起大量的I/O写操作。如果DBWR进程数不够,写入速度将比较缓慢。
    (2)确定所有脏块都写进数据文件之后,CKPT进程更新控制文件和数据文件头。
    假如SGA中的脏块数量很多,那么DBWR进程一次性写脏块是非常消耗I/O的,这不仅加重了DBWR进程的负担,而且还可能因为I/O问题而影响业务,所以不建议频繁进行全量CHECKPOINT操作。
  2. 增量CHECKPOINT
    从Oracle 8开始,Oracle推出了增量CHECKPOINT这一特性,即DBWR进程将CKPTQ队列中的脏块不断地写往磁盘中,从而减轻磁盘I/O压力。Oracle是否启用增量CHECKPOINT,跟隐含参数_disable_incremental_checkpoints有关(默认开启增量CHECKPOINT)。增量CHECKPOINT操作步骤可以简单地分为3步:
    (1)BUFFER CACHE中脏块第一次被更新的时候产生的重做日志记录在重做日志文件中所对应的位置就称为LRBA(Low Redo Block Adress)。脏块按照LRBA顺序组成CKPTQ列表。DBWR进程扫描CKPTQ列表,依次将满足条件的脏块写进数据文件中,并在内存中递增CHECKPOINT NUMBER值,即SCN值。
    (2)脏块写成功之后,DBWR进程将脏块从CKPTQ队列中移走。
    (3)CKPT进程每隔3秒在控制文件中更新DBWR写脏块的进度,即增量CHECKPOINT所完成的RBA信息。
  3. 全量CHECKPOINT和增量CHECKPOINT区别
    增量CHECKPOINT时,CKPT进程不更新数据文件头信息,但会更新控制文中的CHECKPOINT PROGRESS RECORDS。可以DUMP控制文件观察当前实例LGWR进程写在线日志的进度情况。全量CHECKPOINT和增量CHECKPOINT的主要区别如下:
    写脏块的动作不同。全量CHECKPOINT会将BUFFER CACHE中某一时间点之前的所有脏块刷新到数据文件中,在脏块比较多的数据库中,全量CHECKPOINT操作可能会影响数据库的性能。增量CHECKPOINT则是将脏块第一次变脏的顺序分为不同的时间点逐批写到数据文件中,有点“细水长流”的感觉。
    更新的位置不同。全量CHECKPOINT完成之后,会更新内存、数据文件头、控制文件。而增量CHECKPOINT完成之后,只更新内存SCN值和控制文件。
    触发的条件不同。全量CHECKPOINT往往需要通过命令人为触发,而增量CHECKPOINT的触发受多种因素影响,如ONLINE REDOLOG大小、参数FAST_START_MTTR_TARGET等。

这篇关于Oracle中全量CHECKPOINT和增量CHECKPOINT的区别与作用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/994647

相关文章

SpringBoot 中 CommandLineRunner的作用示例详解

《SpringBoot中CommandLineRunner的作用示例详解》SpringBoot提供的一种简单的实现方案就是添加一个model并实现CommandLineRunner接口,实现功能的... 目录1、CommandLineRunnerSpringBoot中CommandLineRunner的作用

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

Java 关键字transient与注解@Transient的区别用途解析

《Java关键字transient与注解@Transient的区别用途解析》在Java中,transient是一个关键字,用于声明一个字段不会被序列化,这篇文章给大家介绍了Java关键字transi... 在Java中,transient 是一个关键字,用于声明一个字段不会被序列化。当一个对象被序列化时,被

解读@ConfigurationProperties和@value的区别

《解读@ConfigurationProperties和@value的区别》:本文主要介绍@ConfigurationProperties和@value的区别及说明,具有很好的参考价值,希望对大家... 目录1. 功能对比2. 使用场景对比@ConfigurationProperties@Value3. 核

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

关于Mybatis和JDBC的使用及区别

《关于Mybatis和JDBC的使用及区别》:本文主要介绍关于Mybatis和JDBC的使用及区别,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、JDBC1.1、流程1.2、优缺点2、MyBATis2.1、执行流程2.2、使用2.3、实现方式1、XML配置文件

Oracle 通过 ROWID 批量更新表的方法

《Oracle通过ROWID批量更新表的方法》在Oracle数据库中,使用ROWID进行批量更新是一种高效的更新方法,因为它直接定位到物理行位置,避免了通过索引查找的开销,下面给大家介绍Orac... 目录oracle 通过 ROWID 批量更新表ROWID 基本概念性能优化建议性能UoTrFPH优化建议注

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序