sys.master_files不能准确展示Tempdb数据库大小

简介: # 问题提出 老鸟这两周一直没有找到机会略菜鸟,因为菜鸟最近一直在参加百阿培训。这不,刚好菜鸟过完买买买的双十一回来,老鸟逮着机会劈头盖脸问道:“菜鸟啊,你去研究下为什么MSSQL Server系统视图sys.master_files不能准确展示Tempdb数据库数据文件大小啊?”。 # 场景复盘 菜鸟一脸懵逼:“什么?不准确,不会吧?我一直都是用它来统计数据库文件大小的啊,有什么问

问题提出

老鸟这两周一直没有找到机会略菜鸟,因为菜鸟最近一直在参加百阿培训。这不,刚好菜鸟过完买买买的双十一回来,老鸟逮着机会劈头盖脸问道:“菜鸟啊,你去研究下为什么MSSQL Server系统视图sys.master_files不能准确展示Tempdb数据库数据文件大小啊?”。

场景复盘

菜鸟一脸懵逼:“什么?不准确,不会吧?我一直都是用它来统计数据库文件大小的啊,有什么问题呀?”,菜鸟满脸茫然的开始咨询G哥。
为了便于观察,菜鸟先将Tempdb的数据文件初始大小设置为10MB

USE [master]
GO
ALTER DATABASE [tempdb] MODIFY FILE ( NAME = N'tempdev', SIZE = 10MB )
GO

查看tempdb数据库Disk Usage:Right click on tempdb => Reports => Standard Reports => Disk Usage
01.png

创建测试表并插入数据

use tempdb
go

if OBJECT_ID('dbo.test', 'U') is not null
    drop table dbo.test

GO
create table dbo.test
(
    id int identity(1,1) not null primary key
    ,large_column char(5120) not null
)
GO

set nocount on
declare
    @do int = 0
;
while @do < 2000
begin
    INSERT INTO dbo.test
    select REPLICATE(NEWID(), 5120/36)
    
    set @do = @do + 1;
end
GO
exec sys.sp_spaceused test

查看测试表大小为16MB
02.png

通过以下三种方式获取tempdb数据库文件大小:
系统视图:sys.master_files看到是10MB,sys.database_files得到是20MB;
查看Windows物理文件:Windows Explorer看到的是20MB;
GUI:通过GUI看到的Currently Allocated Space也是10MB。
GUI查看数据库空间的方法:
03.png
三种统计方法的对比图
04.png

“哇,果真耶,老鸟不愧是老鸟,对得起这个响当当的名号。但是到底哪个是正确的呢,数据库物理文件大小到底是10MB还是20MB?”,菜鸟带着这个疑问一番翻云覆雨后的研究后,终于知道了事情的真相。

原因分析

sys.master_files: 由于Tempdb是SQL Server每次启动时候重新创建,这个系统视图反应的是tempdb数据库文件的初始大小,MSSQL Server会采用异步方式来更新它。换话句话说,SQL Server每次启动会根据这个系统视图中记录的数据库文件大小来创建Tempdb,当我们手动修改数据库初始文件大小的时候,这个系统视图数据会被更新,比如:

USE [master]
GO
ALTER DATABASE [tempdb] MODIFY FILE ( NAME = N'tempdev', SIZE = 10MB )
GO

sys.database_files:这个系统视图展示的数据库文件大小是准确的,会被系统及时更新,但是在使用的时候,需要指定特定的数据库名称。
GUI方式获取数据库文件大小:通过Profiler工具跟踪发现,使用GUI方式实际上是从sys.master_files系统视图中获取的数据,所以对于Tempdb也不准确。
05.png
Windows Explorer:这种方式查看Windows空间占用情况是准确的。

参考链接:
[sys.master_files does not show accurate size information]
(https://connect.microsoft.com/SQLServer/feedback/details/377223/sys-master-files-does-not-show-accurate-size-information)

最后结论

sys.master_files只有在统计tempdb数据库时,无法拿到准确的数据库文件大小;sys.database_files可以拿到准确的数据库文件大小,但是需要指定到特定的数据库下;GUI方式在获取tempdb数据库文件大小背后实际上是通过sys.master_files系统视图获取的,所以,统计也不准确;通过Windows 方式获取的数据库文件大小是准确无误的。

目录
相关文章
|
5月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
448 158
|
5月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1058 152
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
822 156
|
5月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
436 156
|
5月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
535 161
|
6月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
5月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
5月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。