SQL Server数据库日常检查
1.1代码检查从昨天到现在,SQL代理Job有没有运行失败的,会把运行失败的Job名字,步骤,运行时间,错误等级,错误原因罗列出来,方便查看。
----1.1 Check Job Fail List From Last Day To NowSELECT j.[name],h.step_id,h.step_name,h.run_date,h.run_time,h.sql_severity,h.message,h.serverFROM msdb.dbo.sysjobhistory hINNER JOIN msdb.dbo.sysjobs jON h.job_id = j.job_idINNER JOIN msdb.dbo.sysjobsteps sON j.job_id = s.job_idAND h.step_id = s.step_idWHERE h.run_status = 0 -- FailureAND h.run_date > CONVERT(int,CONVERT(varchar(10), DATEADD(DAY, -1, GETDATE()), 112))ORDER BY h.instance_id DESC;
1.2 检查两天内,运行时间超过30分钟的Job,并按执行时间长短排序,时间2天和运行时间30分钟,都是可以调整的,可以调整为自己需要的检查范围。代码会把执行Job的名称,运行时间,平均执行时间列出来。看是否有突然变化的运行情况。
----1.2 Check Jobs With Long Duration:30minutes(can modify to other value) From Last 2 Day To NowSELECT sj.name, sja.start_execution_date,DATEDIFF (minute ,sja.start_execution_date,sja.stop_execution_date ) AS ExecutedMin,ja.AvgRuntimeOnSucceed/60 as AvgRuntimeOnSucceedMinFROM msdb.dbo.sysjobactivity AS sjaINNER JOIN msdb.dbo.sysjobs AS sj ON sja.job_id = sj.job_id INNERjoin(SELECT job_id,AVG((run_duration/10000 * 3600) + ((run_duration%10000)/100*60) + (run_duration%10000)%100)+NULLIF(0,STDEV((run_duration/10000 * 3600) + ((run_duration%10000)/100*60) + (run_duration%10000)%100)) AS 'AvgRuntimeOnSucceed'FROM msdb.dbo.sysjobhistoryWHERE step_id = 0 AND run_status = 1GROUP BY job_id) jaON sj.job_id = ja.job_idWHERE sja.start_execution_date IS NOT NULL --作业有开始AND sja.stop_execution_date IS not NULL --作业结束AND sja.start_execution_date>DATEADD(DAY,-2,GETDATE()) --作业2天内开始and DATEDIFF (minute ,sja.start_execution_date,sja.stop_execution_date )>30order by ExecutedMin desc
1.3 检查数据库错误日志,默认读取的是当前log,筛选的是Error开头的错误日志,可以根据需要筛选其他关键字。
----1.3 Check SQL Error LogDROP TABLE IF EXISTS #errorLog; -- this is new syntax in SQL 2016 and laterCREATE TABLE #errorLog (LogDate DATETIME, ProcessInfo VARCHAR(64), [Text] VARCHAR(MAX));INSERT INTO #errorLogEXEC sp_readerrorlogSELECT *FROM #errorLog aWHERE EXISTS (SELECT *FROM #errorLog bWHERE [Text] like 'Error:%'AND a.LogDate = b.LogDateAND a.ProcessInfo = b.ProcessInfo)
1.4 检查含有数据库文件的磁盘的空间大小,可以看到剩余百分比,实际大小,使用大小等。
----1.4 Check HDD Free Spaceselect distinctconvert(varchar(512), b.volume_mount_point) as [volume_mount_point], convert(varchar(512), b.logical_volume_name) as [logical_volume_name], convert(decimal(18,1), round(((convert(float, b.available_bytes) / convert(float, b.total_bytes)) * 100),1)) as [Drive_Free_Percent], convert(bigint, round(((b.available_bytes / 1024.0)/1024.0),0)) as [Drive_Free_MB], convert(bigint, round(((b.total_bytes / 1024.0)/1024.0),0)) as [Drive_Total_MB], convert(bigint, round((((b.total_bytes - b.available_bytes) / 1024.0)/1024.0),0)) as [Drive_Used_MB]from sys.master_files as [a]CROSS APPLY sys.dm_os_volume_stats(a.database_id, a.[file_id]) as [b]order by volume_mount_point
1.5 检查数据库数据文件和日志文件的大小,默认排除了id为4以下的系统数据库,可以根据需要调整,只观察自己需要的数据库。
----1.5 Check DB Data And Log Sizeselect distinct db_name(a.database_id) as [DatabaseName],database_id, a.name as [Logical_Name], convert(decimal(28,2), round(((a.size * 8.0) / 1024.00),2)) as [SizeMB]from sys.master_files as [a]where database_id>4order by DatabaseName,Logical_Name
1.1代码检查从昨天到现在,SQL代理Job有没有运行失败的,会把运行失败的Job名字,步骤,运行时间,错误等级,错误原因罗列出来,方便查看。
----1.1 Check Job Fail List From Last Day To NowSELECT j.[name],h.step_id,h.step_name,h.run_date,h.run_time,h.sql_severity,h.message,h.serverFROM msdb.dbo.sysjobhistory hINNER JOIN msdb.dbo.sysjobs jON h.job_id = j.job_idINNER JOIN msdb.dbo.sysjobsteps sON j.job_id = s.job_idAND h.step_id = s.step_idWHERE h.run_status = 0 -- FailureAND h.run_date > CONVERT(int,CONVERT(varchar(10), DATEADD(DAY, -1, GETDATE()), 112))ORDER BY h.instance_id DESC;
1.2 检查两天内,运行时间超过30分钟的Job,并按执行时间长短排序,时间2天和运行时间30分钟,都是可以调整的,可以调整为自己需要的检查范围。代码会把执行Job的名称,运行时间,平均执行时间列出来。看是否有突然变化的运行情况。
----1.2 Check Jobs With Long Duration:30minutes(can modify to other value) From Last 2 Day To NowSELECT sj.name, sja.start_execution_date,DATEDIFF (minute ,sja.start_execution_date,sja.stop_execution_date ) AS ExecutedMin,ja.AvgRuntimeOnSucceed/60 as AvgRuntimeOnSucceedMinFROM msdb.dbo.sysjobactivity AS sjaINNER JOIN msdb.dbo.sysjobs AS sj ON sja.job_id = sj.job_id INNERjoin(SELECT job_id,AVG((run_duration/10000 * 3600) + ((run_duration%10000)/100*60) + (run_duration%10000)%100)+NULLIF(0,STDEV((run_duration/10000 * 3600) + ((run_duration%10000)/100*60) + (run_duration%10000)%100)) AS 'AvgRuntimeOnSucceed'FROM msdb.dbo.sysjobhistoryWHERE step_id = 0 AND run_status = 1GROUP BY job_id) jaON sj.job_id = ja.job_idWHERE sja.start_execution_date IS NOT NULL --作业有开始AND sja.stop_execution_date IS not NULL --作业结束AND sja.start_execution_date>DATEADD(DAY,-2,GETDATE()) --作业2天内开始and DATEDIFF (minute ,sja.start_execution_date,sja.stop_execution_date )>30order by ExecutedMin desc
1.3 检查数据库错误日志,默认读取的是当前log,筛选的是Error开头的错误日志,可以根据需要筛选其他关键字。
----1.3 Check SQL Error LogDROP TABLE IF EXISTS #errorLog; -- this is new syntax in SQL 2016 and laterCREATE TABLE #errorLog (LogDate DATETIME, ProcessInfo VARCHAR(64), [Text] VARCHAR(MAX));INSERT INTO #errorLogEXEC sp_readerrorlogSELECT *FROM #errorLog aWHERE EXISTS (SELECT *FROM #errorLog bWHERE [Text] like 'Error:%'AND a.LogDate = b.LogDateAND a.ProcessInfo = b.ProcessInfo)
1.4 检查含有数据库文件的磁盘的空间大小,可以看到剩余百分比,实际大小,使用大小等。
----1.4 Check HDD Free Spaceselect distinctconvert(varchar(512), b.volume_mount_point) as [volume_mount_point], convert(varchar(512), b.logical_volume_name) as [logical_volume_name], convert(decimal(18,1), round(((convert(float, b.available_bytes) / convert(float, b.total_bytes)) * 100),1)) as [Drive_Free_Percent], convert(bigint, round(((b.available_bytes / 1024.0)/1024.0),0)) as [Drive_Free_MB], convert(bigint, round(((b.total_bytes / 1024.0)/1024.0),0)) as [Drive_Total_MB], convert(bigint, round((((b.total_bytes - b.available_bytes) / 1024.0)/1024.0),0)) as [Drive_Used_MB]from sys.master_files as [a]CROSS APPLY sys.dm_os_volume_stats(a.database_id, a.[file_id]) as [b]order by volume_mount_point
1.5 检查数据库数据文件和日志文件的大小,默认排除了id为4以下的系统数据库,可以根据需要调整,只观察自己需要的数据库。
----1.5 Check DB Data And Log Sizeselect distinct db_name(a.database_id) as [DatabaseName],database_id, a.name as [Logical_Name], convert(decimal(28,2), round(((a.size * 8.0) / 1024.00),2)) as [SizeMB]from sys.master_files as [a]where database_id>4order by DatabaseName,Logical_Name
SQL Server数据库日常检查的更多相关文章
- .NET跨平台之旅:升级至ASP.NET 5 RC1,Linux上访问SQL Server数据库
今天微软正式发布了ASP.NET 5 RC1(详见Announcing ASP.NET 5 Release Candidate 1),.NET跨平台迈出了关键一步. 紧跟这次RC1的发布,我们成功地将 ...
- SQL Server数据库定时自动备份
SQL Server 数据库定时自动备份[转] 在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库.而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求 ...
- C#操作access和SQL server数据库代码实例
在C#的学习中,操作数据库是比较常用的技术,而access和sql server 数据库的操作却有着不同.那么,有哪些不同呢? 首先,需要引用不同的类.因为有着不同的数据引擎. access:usin ...
- python 使用pymssql连接sql server数据库
python 使用pymssql连接sql server数据库 #coding=utf-8 #!/usr/bin/env python#------------------------------ ...
- NetBeans连接SQL server数据库教程
不废话,直接开始 1.下载sqljdbc.jar 可以从微软中国官方网站下载 SQLJDBC微软中国 笔者提供一个网盘链接Sqljdbc.jar 4个压缩包视版本选择,SQL 2012 用sqljdb ...
- SQL Server数据库备份的镜像
SQL Server数据库备份的镜像 一个完整备份可以分开镜像 USE master GO BACKUP DATABASE [testdatabase] TO DISK = N'C:\testdata ...
- SQL Server数据库镜像的页面自动修复原理
SQL Server数据库镜像的页面自动修复原理 主库页面损坏 镜像库页面损坏 LSN用来保证事务的时序 LSN保存在每个数据页面的页头 在同一台机器,内存中的数据页和磁盘中的数据页保持同步依靠的是数 ...
- Sql Server数据库备份和恢复:原理篇
本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...
- SQL Server 数据库分离与附加
一.概述 SQL Server提供了“分离/附加”数据库.“备份/还原”数据库.复制数据库等多种数据库的备份和恢复方法.这里介绍一种学习中常用的“分离/附加”方法,类似于大家熟悉的“文件拷贝”方法,即 ...
- 在易语言中调用MS SQL SERVER数据库存储过程方法总结
Microsoft SQL SERVER 数据库存储过程,根据其输入输出数据,笼统的可以分为以下几种情况或其组合:无输入,有一个或多个输入参数,无输出,直接返回(return)一个值,通过output ...
随机推荐
- 关于 Windows6.1-KB2999226-x64.msu 此更新不适用你的计算机解决办法
前言 今天被这个破问题坑了很长时间,网上一大堆扯跳过那个检查,通过提取 cab 文件然后直接用命令安装,我可以明确的告诉你不是那样的解决的,因为我实际用命令装过也装不上(这里我吐槽一下,我猜你最初的问 ...
- github上fork2.4k,star8.7k的这款状态机,原来长这样!
大家好,我是陶朱公Boy. 前言 上一篇文章<关于状态机的技术选型,最后一个真心好>我跟大家聊了一下关于"状态机"的话题. 于是就有小伙伴私信我,自己项目也考虑引入co ...
- WEB入门——信息搜集1-20
WEB1--查看源码 查看源码即可得flag. WEB2--JS前端禁用 查看源码即可得flag. JavaScript实现禁用的方法简单来说就是当用户使用键盘执行某一命令是返回的一种状态,而这种状态 ...
- js-day05-对象
为什么要学习对象 没有对象时,保存网站用户信息时不方便,很难区别 对象是什么 1.对象是一种数据类型 2.无序的数据集合 对象有什么特点 1.无序的数据的集合 2.可以详细的描述某个事物' 对象使用 ...
- 【Java Web】项目通用返回模块ServerResponse:枚举code状态码、泛型返回值、序列化注解限制数据
一.枚举类编写ResponseCode package com.boulderaitech.common; /** * 编写枚举类的步骤 * (1)编写所需的变量 * (2)编写枚举类构造方法 * ( ...
- 【Java进阶】五分钟快速掌握JVM优化概念、常用命令、工具、JUC、多线程、GC等知识
〇.概述 (一)资料 史上最全最详细的JVM优化方案:http://www.360doc.com/content/22/0513/10/34195792_1031121509.shtml (二)内容概 ...
- 5:Echarts数据可视化-多条曲线、多个子图、TreeMap类似盒图、树形图、热力图、词云
〇.目标 本次实验主要基于Echarts的Python库实现高维数据.网络和层次化数据.时空数据和文本数据的可视化,掌握可视化的操作流程和相关库的使用. 一.绘制平行坐标系 平行坐标是信息可视化的一种 ...
- 【Hadoop学习】上:组成介绍、生态体系、环境准备、不同运行模式测试
目录: 入门(上) HDFS(中) MapReduce&Yarn(下) 优化(补充) 一.大数据概述 概念 特点:VVVV 应用场景 二.Hadoop到大数据生态 1.Hadoop生态圈.发展 ...
- 在Maven中出现javax.mail中文乱码问题解决记录
学习Java时,看廖雪峰大神文章使用了javax.mail来发送SMTP邮件.在加入中文时,发现收到的邮件里中文都是乱码. 按照一般经验,多半是编码的问题.然而在代码中,会涉及到编码的地方已经全部设置 ...
- 记一次 .NET 某工控MES程序 崩溃分析
一:背景 1.讲故事 前几天有位朋友找到我,说他的程序出现了偶发性崩溃,已经抓到了dump文件,Windows事件日志显示的崩溃点在 clr.dll 中,让我帮忙看下是怎么回事,那到底怎么回事呢? 上 ...