sqlserver 中一些常看的指标和清除缓存的方法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver 中一些常看的指标和清除缓存的方法相关的知识,希望对你有一定的参考价值。
参考技术A 如何查看磁盘I/O操作信息SET
STATISTICS
IO
ON
命令是一个
使
SQL
Server
显示有关由
Transact-SQL
语句生成的磁盘活动量的信息。
我们在分析索引性能的时候,会非常有用。
启用了这个属性后,我们在执行
SQL
语句后,会收到类似如下的信息,这有利于我们分析SQL的性能:
(3999
row(s)
affected)
表
'ChargeCL'。扫描计数
1,逻辑读取
9547
次,物理读取
0
次,预读
0
次,lob
逻辑读取
0
次,lob
物理读取
0
次,lob
预读
0
次。
其中的
lob
逻辑读取、lob
物理读取、lob
预读
这三个指标是
读取
text、ntext、image
或大值类型
(varchar(max)、nvarchar(max)、varbinary(max))
时的指标。
而
逻辑读取、物理读取、预读
是对普通数据页的读取。
使用
SQL
Server
Management
Studio
Standard
Reports
我们在
SQL
Server
Management
Studio
中,选择数据库服务器,或者具体数据库,或者Security
--
Logins
时,或者Management
时,Notification
Services
或者
SQL
Server
Agent
对象时候,都会看到SQL
Server
替我们提供的一些现成报表,这些报表的数据,有利于我们分析数据库的状态。
比如在
SQL
Server
索引基础知识(1)---
记录数据的基本格式
http://blog.joycode.com/ghj/archive/2008/01/02/113290.aspx
中,我们就使用数据表占用空间的报表
具体报表可以参考以下链接:
SQL
Server
Management
Studio
Standard
Reports
-
Overview
http://blogs.msdn.com/buckwoody/archive/2007/10/09/sql-server-management-studio-standard-reports-overview.aspx
测试中,释放缓存的一些方法
尤其查询语句性能测试时,数据是否被缓存,这是测试中一个重要点。下面几个命令帮助我们清除缓存。方便测试。
清除缓存有关的命令:
SQL
2000里面除了dbcc
unpintable好像就没有了
而且这个操作也不会立即释放表内存Buffer
(DBCC
UNPINTABLE
does
not
cause
the
table
to
be
immediately
flushed
from
the
data
cache.
It
specifies
that
all
of
the
pages
for
the
table
in
the
buffer
cache
can
be
flushed
if
space
is
needed
to
read
in
a
new
page
from
disk.)
SQL
2005/2008让DBA能够更自由的对SQL所占用的内存空间做处理
如:
CHECKPOINT
将当前数据库的全部脏页写入磁盘。“脏页”是已输入缓存区高速缓存且已修改但尚未写入磁盘的数据页。CHECKPOINT
可创建一个检查点,在该点保证全部脏页都已写入磁盘,从而在以后的恢复过程中节省时间。
DBCC
DROPCLEANBUFFERS
从缓冲池中删除所有清除缓冲区。
DBCC
FREEPROCCACHE
从过程缓存中删除所有元素。
DBCC
FREESYSTEMCACHE
从所有缓存中释放所有未使用的缓存条目。SQL
Server
2005
数据库引擎会事先在后台清理未使用的缓存条目,以使内存可用于当前条目。但是,可以使用此命令从所有缓存中手动删除未使用的条目。
另外还可以
sp_cursor_list
查看全部游标
DBCC
OPENTRAN查看数据库打开事务状态等
SQL Server 缓存清除与内存释放
Sql Server系统内存管理在没有配置内存最大值,很多时候我们会发现运行SqlServer的系统内存往往居高不下。这是由于他对于内存使用的策略是有多少闲置的内存就占用多少,直到内存使用虑达到系统峰值时(预留内存根据系统默认预留使用为准,至少4M),才会清除一些缓存释放少量的内存为新的缓存腾出空间。
这些内存一般都是SqlServer运行时候用作缓存的,例如你运行一个select语句,执行个存储过程,调用函数;
1. 数据缓存:执行个查询语句,SqlServer会将相关的数据页(SqlServer操作的数据都是以页为单位的)加载到内存中来,下一次如果再次请求此页的数据的时候,就无需读取磁盘了,大大提高了速度。
2.执行命令缓存:在执行存储过程,自定函数时,SqlServer需要先二进制编译再运行,编译后的结果也会缓存起来,再次调用时就无需再次编译。
在我们执行完相应的查询语句,或存储过程,如果我们不在需要这些缓存,我可以将它清除,DBCC管理命令缓存清除如下:
1)清除存储过程缓存
DBCC FREEPROCCACHE
--注:方便记住关键字 FREEPROCCACHE可以拆解成 FREE(割舍,清除) PROC(存储过程关键字简写),CACHE(缓存)
2)清除会话缓存
DBCC FREESESSIONCACHE
--注: FREE(割舍,清除) SESSION(会话) CACHE(缓存)
3)清除系统缓存
DBCC FREESYSTEMCACHE(‘All‘)
--注:FREE SYSTE MCACHE
4)清除所有缓存
DBCC DROPCLEANBUFFERS
--注: DROP CLEAN BUFFERS
虽然我们已经清除了缓存,但是sql并未释放相应占用的内存。它只是腾出新的空间为之后所执行脚本所用。SqlServer 并没有提供任何命令允许我们释放不用到的内存。因此我们只能通过动态调整Sql Server可用的物理内存设置来强迫它释放内存。
操作原理是调整内存配置大小。手动操作方法:
1.打开SqlServer Management(企业管理器);
2.打开SqlServer实例的属性面板;
3.找到内存设置,改变其中的最大服务器内存使用即可。
使用脚本操作:
1 --强制释放内存 2 3 CREATE procedure[dbo].ClearMemory 4 5 as 6 7 begin 8 9 --清除所有缓存 10 11 DBCC DROPCLEANBUFFERS 12 13 --打开高级配置 14 15 exec sp_configure‘show advanced options‘, 1 16 17 --设置最大内存值,清除现有缓存空间 18 19 exec sp_configure‘max server memory‘, 256 20 21 EXEC (‘RECONFIGURE‘) 22 23 --设置等待时间 24 25 WAITFOR DELAY ‘00:00:01‘ 26 27 --重新设置最大内存值 28 29 EXEC sp_configure‘max server memory‘,4096 30 31 EXEC (‘RECONFIGURE‘) 32 33 --关闭高级配置 34 35 exec sp_configure‘show advanced options‘,0 36 37 GO
下面提供内存查看功能的一些脚本语句:
5)内存使用情况
SELECT *FROM sys.dm_os_performance_counters
WHERE counter_nameIN(‘Target Server Memory (KB)‘,‘Total Server Memory (KB)‘)
6) 内存状态
DBCC MemoryStatus
7)查看最小最大内存
SELECT configuration_idasid,nameas 名称,minimumas配置最小值,maximumas 最大值,
is_dynamic as 是否动态值, is_advanced as 是否优先,value_in_use AS 运行值,
description as 描述 FROMsys.configurations
以上是关于sqlserver 中一些常看的指标和清除缓存的方法的主要内容,如果未能解决你的问题,请参考以下文章