预写式日志(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