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

 

posted @ 2016-12-01 17:58  安小  阅读(181)  评论(0编辑  收藏  举报