Sqlserver 监控使用磁盘空间情况

2023-09-14 10:28:33

最近遇到一个小问题:为了保存以往的一些数据,间了大量临时表,导致SQLserver 数据增长过快,不得不想个办法监控磁盘空间使用情况。

网上一般有几种办法:
一是使用 dm_os_volume_stats函数,缺点是 无法获取非数据库所在的磁盘空间使用情况。

二是使用 Exec master.dbo.xp_fixeddrives ,缺点是只有磁盘空间使用情况,没有总容量。

三是使用xp_fixeddrives+xp_cmdshell,虽然有现成的语句,但过于复杂,而且打开cmdshell是存在一定的风险。

所以,可以简化操作如下:
1、使用dm_os_volume_stats函数,获得所有磁盘信息,若某个磁盘不在其中,则先增加一个临时数据库

例如,如果数据只存放在c\d盘,E盘没有数据库但用于备份,也需要监控,可以临时建立数据库(其他磁盘可参考):

USE [master]
GO

/****** Object:  Database [TEMP_BT]    Script Date: 2023/9/14 8:59:38 ******/
DROP DATABASE IF EXISTS [TEMP_BT]
GO

/****** Object:  Database [TEMP_BT]    Script Date: 2023/9/14 8:59:38 ******/
CREATE DATABASE [TEMP_BT]
 CONTAINMENT = NONE
 ON  PRIMARY 
( NAME = N'TEMP_BT', FILENAME = N'E:\DATA\TEMP_BT.mdf' , SIZE = 1024KB , MAXSIZE = UNLIMITED, FILEGROWTH = 16KB )
 LOG ON 
( NAME = N'TEMP_BT_log', FILENAME = N'E:\DATA\TEMP_BT_log.ldf' , SIZE = 1024KB , MAXSIZE = 2GB , FILEGROWTH = 16KB )
GO


2、用dm_os_volume_stats函数获取磁盘信息,这些语句已经有现成的:

(假设数据库用 Data)

drop  table  if  exists   [Data].[dbo].[T_diskspace]
go

WITH T1 AS (
SELECT DISTINCT
REPLACE(vs.volume_mount_point,':\','') AS Drive_Name ,
CAST(vs.total_bytes / 1024.0 / 1024 / 1024 AS NUMERIC(18,2)) AS Total_Space_GB ,
CAST(vs.available_bytes / 1024.0 / 1024 / 1024  AS NUMERIC(18,2)) AS Free_Space_GB
FROM    sys.master_files AS f
outer APPLY sys.dm_os_volume_stats(f.database_id, f.file_id) AS vs
)
SELECT
GETDATE() as  sdate,
Drive_Name,
Total_Space_GB,
Total_Space_GB-Free_Space_GB AS Used_Space_GB,
Free_Space_GB,
CAST(Free_Space_GB*100/Total_Space_GB AS NUMERIC(18,2)) AS Free_Space_Percent
into  [Data].[dbo].[T_diskspace]
FROM T1

go

use [Data]
go

select *  from   [Data].[dbo].[T_diskspace]

go

完成后,如下图可见:

在这里插入图片描述
当然同时可删除 临时数据库:

use [master]
go

DROP DATABASE IF EXISTS [TEMP_BT]
GO

以上数据获取后运行一次保存即可,以后无需运行

3、用 Exec master.dbo.xp_fixeddrives 监控磁盘空间情况即可。

use [Data]
go

select *  from   [Data].[dbo].[T_diskspace]

go


drop table  if exists [dbo].[Temp_diskspace]
go

CREATE TABLE [dbo].[Temp_diskspace](
	[Drive_name] [nvarchar](500)  NULL,
	[Free_Space] [numeric](20,2)  NULL,
) ON [PRIMARY]
GO

insert into [Data].[dbo].[Temp_diskspace](Drive_Name,Free_Space)
Exec  master.dbo.xp_fixeddrives 

go



update [Data].[dbo].[T_diskspace] set sdate=GETDATE(),Free_Space_GB=cast(b.Free_Space/1024 as numeric(20,2))
from [Data].[dbo].[T_diskspace] a,[Data].[dbo].[Temp_diskspace] b
where a.Drive_Name=b.Drive_Name

go

update [Data].[dbo].[T_diskspace] set Used_Space_GB=Total_Space_GB-Free_Space_GB,
Free_Space_Percent=CAST(Free_Space_GB*100/Total_Space_GB AS NUMERIC(18,2)) 

drop  table if exists [dbo].[Temp_diskspace]
go

select *  from   [Data].[dbo].[T_diskspace]

go

这段代码每日运行即可

以上需要 SQLServer 2008 以上版本

更多推荐

您的开发团队是否面临效率陷阱?

“努力还是摸鱼?”这是一个职场老笑话了,当被问到这句话,人们往往回以礼貌一笑或单纯点头、做个鬼脸。这个笑话无伤大雅,但它总让人想起一个根深蒂固的观念:在工作时,我们必须时刻保持高效。在谷歌搜索“工作效率”,会弹出数百万结果,无论是关于自我提升的书籍,还是TED演讲,又或是提高工作效率的应用程序,比如“如何在工作中提高工

(10)(10.9) 术语表(三)

文章目录1Oilpan2OSD3PCB4PCM5PDB6PIC7PID8POI9PPM10PWM11PX4FMU/PX4IO12RTL13SiRFIII14Sketch15SVN16TelemetrySystem17Thermopile18UAV19VLOS20WAAS21Xbee22ZigBee1OilpanOilp

开学好用的电容笔有哪些推荐?平价触控笔推荐

尽管ApplePencil很贵,但是如果你有足够的预算的话,也可以考虑买一款。此外,iPad配备了一款电容笔,它不但能用于画画,也能用于记录笔记。苹果的原装电容笔,虽然功能强大,但是价格非常昂贵,而国产的平替型电容笔,无论是从手感上,还是从配置上,都能和苹果原装的Pencil相抗衡,最关键的是,价格只要一二百块钱。以下

【C++】C++ 语言对 C 语言的加强 ① ( 实用性增强 - 变量任意位置定义 | register 关键字增强 - 自动进行寄存器优化 )

文章目录一、实用性增强-变量任意位置定义二、register关键字增强-自动进行寄存器优化一、实用性增强-变量任意位置定义C语言定义变量位置:在C语言中,函数作用域中使用到的变量,必须在作用域开始的位置定义,一旦开始编写代码逻辑后,在逻辑代码行之间,不能定义变量;新版本的C语言编译器不会报错,可以在逻辑代码之间定义变量

初识canvas

对于一个前端人员来说,canvas是必须掌握的技能之一。如果你想像画画一样在浏览器上作画,那么canvas就可以做你的画布。接下啦我们就以画画的标准来初步认识下canvas1.画布画画的第一步你得有一张画纸或者画布,canvas标签就是我们的画布。画布都是有尺寸的,如果你想要做大一点的画那就需要大一点的画布,反之也是,

shell脚本命令

Shell命令是在类Unix操作系统中使用的命令行解释器(shell)中执行的命令。Shell命令可以用于执行系统命令、操作文件、进行文本处理、管理进程等。以下是一些常见的Shell命令:1.`ls`:列出当前目录下的文件和文件夹。2.`cd`:切换当前工作目录。3.`pwd`:显示当前工作目录的路径。4.`mkdir

linux下二进制安装docker最新版docker-24.0.6

一.基础环境本次实操是公司技术培训下基于centos7.9操作系统安装docker最新版docker-24.0.6,下载地址是:https://download.docker.com/linux/static/stable/x86_64/docker-24.0.6.tgz二.下载Docker压缩包mkdir-p/opt

docker学习1-基本概念

Dockerjar包+环境=镜像,镜像存在docker仓库中,随用随取,无需现配环境docker通过隔离机制,各个镜像之间互不干扰docker比vm轻量化,每次只需运行镜像即可,镜像占内存小启动快,虚拟机启动慢,占内存较大docker是基于go语言开发的开源项目虚拟机技术运行方式(资源占用多,冗余步骤多,启动慢):容器

el-table表格中加入输入框

<template><divclass="box"><divclass="btn"><el-buttontype="primary">发送评委</el-button><el-buttontype="primary"@click="flag=true"v-if="!flag">编辑</el-button><el-butt

Python案例|Pandas正则表达式

字符串的处理在数据清洗中占比很大。也就是说,很多不规则的数据处理都是在对字符串进行处理。Excel提供了拆分、提取、查找和替换等对字符串处理的技术。在Pandas中同样提供了这些功能,并且在Pandas中还有正则表达式技术的加持,让其字符串处理能力更加强大。01、正则正则就是正则表达式(RegularExpressio

C语言计算2的1024次方

C语言计算2的1024次方迅雷有这么一道笔试题,编程计算2的1024次方。所谓2的1024次方,就是有1024个2相乘,于是有些同学顺手就能写出代码:intmain(){intreslut=1;for(inti=0;i<1024;i++){result*=2;}printf("%d\n",result);return0

热文推荐