SQL SERVER 内存分配及常见内存问题 DMV查询
- 内存动态管理视图(DMV):
- SELECT [type] ,
- SUM(virtual_memory_reserved_kb) AS [VM Reserved] ,
- SUM(virtual_memory_committed_kb) AS [VM Committed] ,
- SUM(awe_allocated_kb) AS [AWE Allocated] ,
- SUM(shared_memory_reserved_kb) AS [SM Reserved] ,
- SUM(shared_memory_committed_kb) AS [SM Committed] ,
- SUM(multi_pages_kb) AS [Multipage Allocator] ,
- SUM(single_pages_kb) AS [SinlgePage Allocator],
- SUM(virtual_memory_reserved_kb)/(CASE WHEN SUM(virtual_memory_committed_kb)=0 THEN 1 ELSE SUM(virtual_memory_committed_kb) END ) AS [Reserved/Commit],
- SUM(single_pages_kb)+SUM(multi_pages_kb) AS Stolen,
- SUM(virtual_memory_committed_kb)+SUM(single_pages_kb) AS [SinlgePage Allocator]
- FROM sys.dm_os_memory_clerks
- GROUP BY [type]
- ORDER BY [type]
- 对于得出的数据:
- emoryclerk_sqlbufferpool:正常来说这个汇总值最大。
- CACHESTORE_OBJECP:触发器、存储过程、函数的执行计划缓存。
- CACHESTORE_SQLCP:动态T-SQL语句、预编译TSQL语句的执行计划缓存。
- CACHESTORE_PHDR:缓存视图、用户自定义函数信息,帮助SQL更快生成执行计划。
- CACHESTORE_XPROC:缓存扩展存储过程,sp_executesql,sp_cursor*,sp_Trace*等。
- CACHESTORE_TEMPTABLES:缓存临时对象。local temp table 、global temp table 、table variable等。
- CACHESTORE_CLRPROC:SQLCLR过程缓存。
- CACHESTORE_EVENTS:存储Service Broker的时间和消息。
- CACHESTORE_CURSORS:存储所有的游标,包括LocalTSQLcursors、Global TSQL cursor和API cursors等。
- USERSTORE_TOKENPERM:保存所有用户的安全上下文及各种跟安全相关的令牌,这些缓存条目用于检查查询累积性的权限。
- USERSTORE_SXC:暂时存放正在执行中的语句的PRC参数,如果参数过长,这部分内存的使用量会比较大。
内存中的数据页由哪些表格组成,各占多少?
- DECLARE @name NVARCHAR(100)
- DECLARE @cmd NVARCHAR(1000)
- DECLARE dbnames CURSOR
- FOR
- SELECT NAME
- FROM master.dbo.sysdatabases
- OPEN dbnames
- FETCH NEXT FROM dbnames INTO @name
- WHILE @@FETCH_STATUS = 0
- BEGIN
- SET @cmd = 'select b.database_id,db=db_name(b.database_id),p.object_id,p.index_id,buffer_count=count(*) from '
- + @name + '.sys.allocation_units a, ' + @name
- + '.sys.dm_os_buffer_descriptors b, ' + @name
- + '.sys.partitions p where a.allocation_unit_id=b.allocation_unit_id and a.container_id=p.hobt_id and b.database_id=db_id('''
- + @name
- + ''')
- group by b.database_id,p.object_id,p.index_id order by b.database_id,buffer_count desc '
- EXEC (@cmd)
- FETCH NEXT FROM dbnames INTO @name
- END
- CLOSE dbnames
- DEALLOCATE dbnames
- GO
可以查看各种对象各占多少内存:
- SELECT objtype ,
- SUM(size_in_bytes) / 1024 AS sum_size_in_KB ,
- COUNT(bucketid) AS cache_counts
- FROM sys.dm_exec_cached_plans
- GROUP BY objtype
分析具体存储哪些对象:
- SELECT usecounts ,
- refcounts ,
- size_in_bytes ,
- cacheobjtype ,
- objtype ,
- TEXT
- FROM sys.dm_exec_cached_plans cp
- CROSS APPLY sys.dm_exec_sql_text(plan_handle)
- ORDER BY objtype DESC ;
- GO
--使用DMV分析SQL SERVER 启动以来做read最多的语句
- --按照物理读的页面数排序,前50名
- SELECT TOP 50
- qs.total_physical_reads ,
- qs.execution_count ,
- qs.total_physical_reads / qs.execution_count AS [Avg IO] ,
- SUBSTRING(qt.text, qs.statement_start_offset / 2,
- ( CASE WHEN qs.statement_end_offset = -1
- THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2
- ELSE qs.statement_end_offset
- END - qs.statement_start_offset ) / 2) AS query_text ,
- qt.dbid ,
- dbname = DB_NAME(qt.dbid) ,
- qt.objectid ,
- qs.sql_handle ,
- qs.plan_handle
- FROM sys.dm_exec_query_stats qs
- CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
- ORDER BY qs.total_physical_reads DESC
- --按照逻辑读的页面数排序,前50名
- SELECT TOP 50
- qs.total_logical_reads ,
- qs.execution_count ,
- qs.total_logical_reads / qs.execution_count AS [Avg IO] ,
- SUBSTRING(qt.text, qs.statement_start_offset / 2,
- ( CASE WHEN qs.statement_end_offset = -1
- THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2
- ELSE qs.statement_end_offset
- END - qs.statement_start_offset ) / 2) AS query_text ,
- qt.dbid ,
- dbname = DB_NAME(qt.dbid) ,
- qt.objectid ,
- qs.sql_handle ,
- qs.plan_handle
- FROM sys.dm_exec_query_stats qs
- CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
- ORDER BY qs.total_logical_reads DESC
- --用DBCC强制释放部分SQL SERVER 内存缓存:
- DBCC FREESYSTEMCACHE
- DBCC FREESESSIONCACHE
- DBCC FREEPROCCACHE
- --查看操作系统内存状况
- SELECT total_physical_memory_kb / 1024 AS [物理内存(MB)] ,
- available_physical_memory_kb / 1024 AS [可用物理内存(MB)] ,
- system_cache_kb / 1024 AS [系统缓存内存总量(MB)] ,
- ( kernel_paged_pool_kb + kernel_nonpaged_pool_kb ) / 1024 AS [内核池内存总量(MB)] ,
- total_page_file_kb / 1024 AS [操作系统报告的提交限制的大小(MB)] ,
- available_page_file_kb / 1024 AS [未使用的页文件的总量(MB)] ,
- system_memory_state_desc AS [内存状态说明]
- FROM sys.dm_os_sys_memory
原文:http://blog.csdn.net/dba_huangzj/article/details/7531384
SQL SERVER 内存分配及常见内存问题 DMV查询的更多相关文章
- SQL SERVER 内存分配及常见内存问题(2)——DMV查询
原文:SQL SERVER 内存分配及常见内存问题(2)--DMV查询 内存动态管理视图(DMV): 从sys.dm_os_memory_clerks开始. SELECT [type] , SUM(v ...
- SQL SERVER 内存分配及常见内存问题(1)——简介
原文:SQL SERVER 内存分配及常见内存问题(1)--简介 一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解 ...
- SQL SERVER 内存分配及常见内存问题 简介
一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解SQL SERVER与windows是如何协调.共享内存.并且SQ ...
- 笔记26-徐 SQLSERVER内存分配和常见内存问题
1 --64位SQLSERVER 应用在IA64操作系统 7TB 2TB ...
- [转]SQL Server 性能调优(内存)
存储引擎自调整 sql server 是如何分配内存的 32bit地址空间的限制 用户模式vas分配和virtualalloc 非boffer pool 分配内存(保留内存) VAS调整 AWE ...
- 对于SQL Server,我需要多少内存
经常被问到的一个问题:对于SQL Server,我需要多少内存?这个问题还是有同样的典型的“看情况而定”答案.在今天的文章里,我们来详细看下“看情况而定的”的不同方面. 全新SQL Server安装 ...
- 如何修改SQL Server 2008 R2数据库的内存
本篇经验将和大家介绍如何修改SQL Server 2008 R2数据库的内存,希望对大家的工作和学习有所帮助! 工具/原料 SQL Sever 2008 R2数据库已安装 方法/步骤 1 打开 ...
- malloc内存分配与free内存释放的原理
malloc内存分配与free内存释放的原理 前段时间一直想看malloc的原理,在搜了好几篇malloc源码后遂放弃,晦涩难懂. 后来室友买了本深入理解计算机系统的书,原来上面有讲malloc的原理 ...
- rt-thread中动态内存分配之小内存管理模块方法的一点理解
@2019-01-18 [小记] rt-thread中动态内存分配之小内存管理模块方法的一点理解 > 内存初始化后的布局示意 lfree指向内存空闲区首地址 /** * @ingroup Sys ...
随机推荐
- java解析xml
一.Document对象相关 1.读取XML文件,获得document对象. SAXReader reader = new SAXReader(); ...
- Django的virtualenv环境搭建
安装virtualenv好处多多,可以让当前的项目使用单独的类库,实现系统类库的隔离,所以能够自由地控制当前项目类库的版本,不受系统类库的影响:还有其他N多好处. 下面是安装说明和使用示例: 首先安装 ...
- iOS常用的忽略警告
在iOS开发过程中,偶尔会碰到一些编译器警告,如果能够确定该警告不会影响到程序的正常运行,则可以手动告诉编译器忽略掉这个警告 iOS常用的忽略警告类型: 1.方法弃用警告 #pragma clang ...
- ListView用法总结
前言 列表,它作为一种非常重要的显示形式,不管是在web端还是在移动平台上,都是一种非常友好的,功能强大的展现形式.在Android中,ListView就接管了这一重任.尽管在Android5.X时代 ...
- 对InvokeAction简略分析了解验证失败为什么Action还会继续执行
一.前言 有些同学使用AuthorizationFilter来进行用户是否登录验证,如果未登录就跳到登录页. 很简单的一个场景,但是有些同学会发现虽然验证失败了,但是整个Action还会执行一遍. 于 ...
- .NET面试题解析(11)-SQL语言基础及数据库基本原理
系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 本文内容涉及到基本SQL语法,数据的基本存储原理,数据库一些概念.数据优化等.抱砖引玉,权当一个综合复习! ...
- Spring2:bean的使用
前言 Spring最基础的功能就是一个bean工厂,所以本文讲解的是Spring生成bean的种种方法及细节,Spring配置文件的名字是bean.xml,定义几个类: 一个Person类: publ ...
- Java关于流知识总结
流总结: 一.流的分类: 数据单位:字节流 字符流 方向: 输出流 输入流 角色: 节点流 套节流 字节流:以Stream结尾. 字符流:以Reader 和Writer 结尾. 输入流:所有带有 ...
- 让Redis在你的系统中发挥更大作用的几点建议
转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/105.html?1455868313 Redis在很多方面与其他数据库解决 ...
- PDO事务处理
PDO事务处理 2014-9-3 10:44:19 By jiancaigege==================================== 概要:将多条sql操作(增删改)作为一个操作单 ...