sqlserver 事务日志

预写式日志(Write-Ahead Logging (WAL))

--在数据写入到数据库之前,先写入到日志.

1.”Begin Tran”记录  -> 缓冲区
2. 日志                   -> 缓冲区
3. 数据                   -> 缓冲区数据页 (记为脏页)
4.”Commit”记录      -> 缓冲区
5. 缓冲区日志 -> 磁盘日志文件 (缓冲区中数据文件的LSN<磁盘日志文件末尾的LSN号)
6. 发送确认信息(ACK)到客户端 (SMSS,ODBC等)
7. Lazy Writer将缓冲区内的脏页 -> 磁盘文件中 (当缓冲区达到某一临界值时)
8. CheckPoint 将缓冲区内的脏页 -> 磁盘文件中 (根据服务器参数“恢复间歇”定期写数据,或者Alter DataBase以及关闭SQL Server服务器时)

参考原文:http://www.cnblogs.com/CareySon/archive/2012/02/14/2351149.html

上一篇:浅谈线程池(中):独立线程池的作用及IO线程池


下一篇:Unity 代码规范(PlateFace)1.0版本