zoukankan      html  css  js  c++  java
  • SQL Server中的database checkpoint

    基于性能方面的考虑, 数据库引擎会在内存(buffer cache)中执行数据库数据页(pages)的修改, 不会再每次做完修改之后都把修改了的page写回到磁盘上. 更准确的说, 数据库引擎定期在每个数据库上生成一个checkpoint. Checkpoint会把当前内存中的修改了的页(dirty pages)还有transaction log的信息从内存中写入到磁盘, 还要记录关于tranaction log的信息.

    数据库引擎支持下面几种checkpoint:

    • automatic - 在后台定期自动生成checkpoint来达到服务器配置所要求的recovery interval标准的时间上限. automatic checkpoint执行的多少是基于突出的写操作的数量和数据库引擎是否检测到写延迟超过了20毫秒来决定的.
    • indirect - 在后台执行来让某一个数据库达到用户指定的target revovery time标准. 默认的target revovery time是0, 这样会引发automatic checkpoint设定在该数据库上生效. 如果你之前用了ALTER DATABASE来配置TARGET_RECOVERY_TIME大于0了, 那么这个大于0的值就会生效, 而不是让针对server instance设置的该值起作用.
    • manual - 每当你执行Transact-SQL中的CHECKPOINT命令时会生成manual 的checkpoint. manual checkpoint会在你当前连接了的数据库上升小. 默认, manual checkpoint会执行一直到结束. Trrottling的工作机制跟automatic checkpoint是一样的.
    • internal - 会被许多服务器操作引发, 比如说备份, 数据库的快照(snapshot), 用以确保磁盘的镜像跟当前的log的状态保持一致.

     

    举例:

    --启用indirect checkpoint
    ALTER DATABASE tpce SET TARGET_RECOVERY_TIME = 1 SECONDS
    go
    
    --启用automatic checkpoint
    ALTER DATABASE tpce SET TARGET_RECOVERY_TIME = 0 SECONDS
    go
    

     

     

    参考资料

    ======================

    Database Checkpoints (SQL Server)

    http://msdn.microsoft.com/en-us/library/ms189573.aspx

  • 相关阅读:
    C# winform 获取鼠标点击位置
    C# 读取带有命名空间的xml
    ImageUtility辅助类
    C# 读取XML
    C# 根据生日获取年龄
    C# 将 WebService 封装成动态库
    C# 生成条形码
    C# Ftp Client 基本操作
    C# SQL帮助类
    C# 解压缩文件
  • 原文地址:https://www.cnblogs.com/awpatp/p/4030521.html
Copyright © 2011-2022 走看看