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)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
2012-10-17 Debug相关的一些小技巧
2011-10-17 记一次纠结的排错-用WinDBG解决WinDBG Hang的问题