理解SQLSERVER脏页

理解SQLSERVER脏页,第1张

概述很多关于SQLSERVER的书籍中都提到脏页,而脏页涉及到数据库的恢复模式,读写方式,并发等等, 什么是脏页,当客户端发送T-SQL语句到数据库时,数据库引擎执行修改数据时, 如果在内存中找不到数据,会先从磁盘读取数据到内存(这一个过程叫page fault,缺页错误), 然后在内存中修改数据,这个时候在数据库未执行检查点 *** 作或惰性写入器未执行写入之前, 磁盘和内存中的数据是不一致的,那么这些存在

很多关于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、数据库写入数据时,是先写入日志(这里没有实验,大家可以通过日志恢复模式了解这一点),然后写入内存,然后写入磁盘。

总结

以上是内存溢出为你收集整理的理解SQLSERVER脏页全部内容,希望文章能够帮你解决理解SQLSERVER脏页所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1174220.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存