博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sql server08 查询优化系列 2系统性能分析
阅读量:6680 次
发布时间:2019-06-25

本文共 2090 字,大约阅读时间需要 6 分钟。

首先打开性能监视器工具  运行中输入 perfmon

sql server 现在通过 一组   动态管理视图(DMV) 和 动态管理函数(DMF) ,在内部提供相关数据.

sql server 的总体性能:

丢失索引

为了分析 丢失索引造成表扫描或者大的数据集检索的可能性, 使用如下计数器

对象 计数器
SQL SERVER:Access Methods
FreeSpace Scans/sec(每秒空闲空间扫描数)
Full Scans/sec  (每秒完全扫描数)

1.FreeSpace Scans/sec

这个计数器表示 在 没有物理顺序的表上的插入操作数量---堆表.

2.Full Scans/sec

这个计数器监视 基本表或索引 上下受限制的完全扫描次数.高值的主要原因:

  1. 丢失索引
  2. 请求过多的行

3.动态管理视图

检查丢失的索引 的另一个办法是 查询 动态管理视图

sys.dm_db_missing_index_details . 返回 可以根据数据上运行的查询计划 建议候选索引的信息.

sys.dm_db_index_usage_stats  返回索引的使用情况

select * from sys.dm_db_index_usage_stats where object_id= object_id('b') and index_id=1

结果:

可以看到 索引的最后浏览时间和表的更新时间, 这只是截取的部分列.

sys.dm_db_index_operational_stats  表值函数   查看正在使用的索引

 

数据库阻塞

对象 计数器
SQLServer:Latches Total Latch  Wait Time(ms)   总闩锁等待时间
SQLServer:Locks(_Total)
Lock TimeOuts/sec   每秒锁超时数
Lock Wait Time(ms) 锁等待时间
Number Of Deadlocks/sec  每秒死锁 数

 

1.Total Latch  Wait Time(ms)   总闩锁等待时间

闩锁 被sql server 用于保护 内部结构 如表行的完整性,不由用户控制.

2.Lock timeouts/sec 和 lock wait time(ms)

Lock timeouts/sec 为0 和lock wait time(ms) 很小,是我们所期待的.如果反之,那么说明数据库阻塞过多.

可以使用 sql profiler 的信息 或者 查询 sys.dm_exec_query_stats  来识别 开销较大的查询,来优化它.

3.number of deadlocks/sec

期望值为了0. 应该定位并解决死锁.

不可重用的执行计划

因为 生成存储过程查询的  执行计划需要 cpu周期,所以可以通过重用执行计划来减少cpu的压力.分析重编译的存储过程数量通过:

对象 计数器
SQLServer:Sql Statistics SQL Re-Compilations/sec  每秒 sql重编译数

 

总体表现

sql server还提供了 额外的性能计数器 来跟踪 sql server 系统的总体特征.

对象 计数器
SQL Server:General Statistics User Connections (用户连接数)
SQL Server:S QL Statistics Batch Requests/sec 每秒批请求数

 

1. User Connections (用户连接数)

当sqlserver 分布在多台机器上,坚持 此计数器 以评估多个sqlserver 实例上用户连接分布 好一些.

2.Batch Requests/sec 每秒批请求数

这个计数器 是 sql server上的负载的 好指标,

 

 

创建一个基线:

首先打开 性能检测器

添加一个  SQL Server:Latched 的  Latch Wait/sec 计数器:

之后便可以查看总闩锁等待时间 的 数值;

 

之后可以导出到html文件: 监视器窗口 任意位置 右击,

打开生成的html,页面显示如图:

 

使用性能计数器 列表 创建一个 计数器日志

可以自己来创建 自动 跟踪任意计数器,并记录成日志 .当然可以使用计划任务,定期执行>

用户定义  右键, 新建 数据收集器集.

 

命名,选择手动创建! 点击下一步:

选中 性能计数器; 下一步.

添加相应的计数器. 点击下一步:

直到完成的那一步.

选择 打开 数据收集器集 的属性.

选择计划:

就可以 定期执行这个监视了.

 

最小化性能监视器的开销

最小化开销的办法:

  1. 限制计数器数量,特别是 性能对象.
  2. 使用计数器日志 代替交互式地查看新跟那个监视器图形
  3. 在交互式地查看图形时 远程运行性能监视器;
  4. 将性能日志文件保存到不同的本地磁盘
  5. 增大 采样的间隔

转载于:https://www.cnblogs.com/Mr-Joe/archive/2012/05/11/2495878.html

你可能感兴趣的文章
NewCoder_13_E 通知小弟[缩点]
查看>>
Elasticsearch 空值过滤
查看>>
spring、springboot、springcloud的区别
查看>>
ActiveMQ入门实例
查看>>
POJ1797 Heavy Transportation
查看>>
MySQL查看和修改表的存储引擎
查看>>
py学习之道
查看>>
vs2015 + opencv3.4.0 + qt msvc2015_64-5.7.1 视屏显示
查看>>
关于——GCD
查看>>
2017-3-2 智慧吉首调研工作
查看>>
求解,一道嵌入式公司面试题
查看>>
easyUI的基础布局
查看>>
o(1)复杂度之双边滤波算法的原理、流程、实现及效果。
查看>>
Mongodb安装和基本命令
查看>>
python中requests模块使用
查看>>
git bash 常用命令 新手学习
查看>>
日记2014/06/25
查看>>
springboot+Druid+oracle 配置p6spy
查看>>
Maven编译、打war包
查看>>
WP8.1开发:简单的天气预报应用
查看>>