很多关于SQLSERVER的书籍中都提到脏页,而脏页涉及到数据库的恢复模式,读写方式,并发等等,
什么是脏页,当客户端发送T-SQL语句到数据库时,数据库引擎执行修改数据时,
如果在内存中找不到数据,会先从磁盘读取数据到内存(这一个过程叫page fault,缺页错误),
然后在内存中修改数据,这个时候在数据库未执行检查点操作或惰性写入器未执行写入之前,
磁盘和内存中的数据是不一致的,那么这些存在于内存中的被修改数据页叫做脏页。
/* 查看脏页 */ --查看脏页,这一步获取到的数据库脏页信息中没有dbo.T_PARTITION表的脏页信息 select ?DB_NAME(database_id) as 'database', ?COUNT(page_id) as 'dirty pages' from sys.dm_os_buffer_descriptors where is_modified=1 group by DB_NAME(database_id) order by COUNT(page_id) desc go
--先更新数据, update dbo.T_PARTITION set NUMBER=600 go --获取脏页,此时dbo.T_PARTITION表所在数据库出现脏页信息 select ?DB_NAME(database_id) as 'database', ?COUNT(page_id) as 'dirty pages' from sys.dm_os_buffer_descriptors where is_modified=1 group by DB_NAME(database_id) order by COUNT(page_id) desc go --移除干净页面 dbcc dropcleanbuffers go --查看脏页,dbo.T_PARTITION表所在数据库脏页信息依然存在 select ?DB_NAME(database_id) as 'database', ?COUNT(page_id) as 'dirty pages' from sys.dm_os_buffer_descriptors where is_modified=1 group by DB_NAME(database_id) order by COUNT(page_id) desc go --执行检查点,将脏页写入内存 checkpoint 1 go --查看脏页,dbo.T_PARTITION表所在数据库脏页信息被写入磁盘,脏页信息被清除了 select ?DB_NAME(database_id) as 'database', ?COUNT(page_id) as 'dirty pages' from sys.dm_os_buffer_descriptors where is_modified=1 group by DB_NAME(database_id) order by COUNT(page_id) desc go
--由上面的代码可以看出: --1、数据库先是在内存中修改数据,然后通过检查点(惰性写入器这个没办法实验)执行写入磁盘的操作以完成数据库持久化特性。 --2、数据库写入数据时,是先写入日志(这里没有实验,大家可以通过日志恢复模式了解这一点),然后写入内存,然后写入磁盘。
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|