1. 内存动态管理视图(DMV):
从sys.dm_os_memory_clerks开始。
  1. SELECT  [type] ,
  2. SUM(virtual_memory_reserved_kb) AS [VM Reserved] ,
  3. SUM(virtual_memory_committed_kb) AS [VM Committed] ,
  4. SUM(awe_allocated_kb) AS [AWE Allocated] ,
  5. SUM(shared_memory_reserved_kb) AS [SM Reserved] ,
  6. SUM(shared_memory_committed_kb) AS [SM Committed] ,
  7. SUM(multi_pages_kb) AS [Multipage Allocator] ,
  8. SUM(single_pages_kb) AS [SinlgePage Allocator],
  9. 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],
  10. SUM(single_pages_kb)+SUM(multi_pages_kb) AS Stolen,
  11. SUM(virtual_memory_committed_kb)+SUM(single_pages_kb) AS [SinlgePage Allocator]
  12. FROM    sys.dm_os_memory_clerks
  13. GROUP BY [type]
  14. ORDER BY [type]
其中type为Memory Clerk的名称,可以知道内存的用途。
  1. 对于得出的数据:
  1. emoryclerk_sqlbufferpool:正常来说这个汇总值最大。
  1. CACHESTORE_OBJECP:触发器、存储过程、函数的执行计划缓存。
  1. CACHESTORE_SQLCP:动态T-SQL语句、预编译TSQL语句的执行计划缓存。
  1. CACHESTORE_PHDR:缓存视图、用户自定义函数信息,帮助SQL更快生成执行计划。
  1. CACHESTORE_XPROC:缓存扩展存储过程,sp_executesql,sp_cursor*,sp_Trace*等。
  1. CACHESTORE_TEMPTABLES:缓存临时对象。local temp table 、global temp table 、table variable等。
  1. CACHESTORE_CLRPROC:SQLCLR过程缓存。
  1. CACHESTORE_EVENTS:存储Service Broker的时间和消息。
  1. CACHESTORE_CURSORS:存储所有的游标,包括LocalTSQLcursors、Global TSQL cursor和API cursors等。
  1. USERSTORE_TOKENPERM:保存所有用户的安全上下文及各种跟安全相关的令牌,这些缓存条目用于检查查询累积性的权限。
  1. USERSTORE_SXC:暂时存放正在执行中的语句的PRC参数,如果参数过长,这部分内存的使用量会比较大。
 

内存中的数据页由哪些表格组成,各占多少?

sys.dm_os_buffer_descriptors
  1. DECLARE @name NVARCHAR(100)
  2. DECLARE @cmd NVARCHAR(1000)
  3. DECLARE dbnames CURSOR
  4. FOR
  5. SELECT  NAME
  6. FROM    master.dbo.sysdatabases
  7. OPEN dbnames
  8. FETCH NEXT FROM dbnames INTO @name
  9. WHILE @@FETCH_STATUS = 0
  10. BEGIN
  11. SET @cmd = 'select b.database_id,db=db_name(b.database_id),p.object_id,p.index_id,buffer_count=count(*) from '
  12. + @name + '.sys.allocation_units a, ' + @name
  13. + '.sys.dm_os_buffer_descriptors b, ' + @name
  14. + '.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('''
  15. + @name
  16. + ''')
  17. group by b.database_id,p.object_id,p.index_id order by b.database_id,buffer_count desc '
  18. EXEC (@cmd)
  19. FETCH NEXT FROM dbnames INTO @name
  20. END
  21. CLOSE dbnames
  22. DEALLOCATE dbnames
  23. GO
 
会缓存执行计划的对象:
proc:存储过程
prepared:预定义语句
Adhoc:动态查询
ReplProc:复制筛选过程
Trigger:触发器
View:视图
Default:默认值
UsrTab:用户表
SysTab:系统表
Check:Check约束
Rule:规则
 

可以查看各种对象各占多少内存:

  1. SELECT  objtype ,
  2. SUM(size_in_bytes) / 1024 AS sum_size_in_KB ,
  3. COUNT(bucketid) AS cache_counts
  4. FROM    sys.dm_exec_cached_plans
  5. GROUP BY objtype

分析具体存储哪些对象:

  1. SELECT  usecounts ,
  2. refcounts ,
  3. size_in_bytes ,
  4. cacheobjtype ,
  5. objtype ,
  6. TEXT
  7. FROM    sys.dm_exec_cached_plans cp
  8. CROSS APPLY sys.dm_exec_sql_text(plan_handle)
  9. ORDER BY objtype DESC ;
  10. GO

--使用DMV分析SQL SERVER 启动以来做read最多的语句

  1. --按照物理读的页面数排序,前50名
  2. SELECT TOP 50
  3. qs.total_physical_reads ,
  4. qs.execution_count ,
  5. qs.total_physical_reads / qs.execution_count AS [Avg IO] ,
  6. SUBSTRING(qt.text, qs.statement_start_offset / 2,
  7. ( CASE WHEN qs.statement_end_offset = -1
  8. THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2
  9. ELSE qs.statement_end_offset
  10. END - qs.statement_start_offset ) / 2) AS query_text ,
  11. qt.dbid ,
  12. dbname = DB_NAME(qt.dbid) ,
  13. qt.objectid ,
  14. qs.sql_handle ,
  15. qs.plan_handle
  16. FROM    sys.dm_exec_query_stats qs
  17. CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
  18. ORDER BY qs.total_physical_reads DESC
  19. --按照逻辑读的页面数排序,前50名
  20. SELECT TOP 50
  21. qs.total_logical_reads ,
  22. qs.execution_count ,
  23. qs.total_logical_reads / qs.execution_count AS [Avg IO] ,
  24. SUBSTRING(qt.text, qs.statement_start_offset / 2,
  25. ( CASE WHEN qs.statement_end_offset = -1
  26. THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2
  27. ELSE qs.statement_end_offset
  28. END - qs.statement_start_offset ) / 2) AS query_text ,
  29. qt.dbid ,
  30. dbname = DB_NAME(qt.dbid) ,
  31. qt.objectid ,
  32. qs.sql_handle ,
  33. qs.plan_handle
  34. FROM    sys.dm_exec_query_stats qs
  35. CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
  36. ORDER BY qs.total_logical_reads DESC
  1. --用DBCC强制释放部分SQL SERVER 内存缓存:
  1. DBCC FREESYSTEMCACHE
  1. DBCC FREESESSIONCACHE
  1. DBCC FREEPROCCACHE
    1. --查看操作系统内存状况
    2. SELECT  total_physical_memory_kb / 1024 AS [物理内存(MB)] ,
    3. available_physical_memory_kb / 1024 AS [可用物理内存(MB)] ,
    4. system_cache_kb / 1024 AS [系统缓存内存总量(MB)] ,
    5. ( kernel_paged_pool_kb + kernel_nonpaged_pool_kb ) / 1024 AS [内核池内存总量(MB)] ,
    6. total_page_file_kb / 1024 AS [操作系统报告的提交限制的大小(MB)] ,
    7. available_page_file_kb / 1024 AS [未使用的页文件的总量(MB)] ,
    8. system_memory_state_desc AS [内存状态说明]
    9. FROM    sys.dm_os_sys_memory

原文:http://blog.csdn.net/dba_huangzj/article/details/7531384

SQL SERVER 内存分配及常见内存问题 DMV查询的更多相关文章

  1. SQL SERVER 内存分配及常见内存问题(2)——DMV查询

    原文:SQL SERVER 内存分配及常见内存问题(2)--DMV查询 内存动态管理视图(DMV): 从sys.dm_os_memory_clerks开始. SELECT [type] , SUM(v ...

  2. SQL SERVER 内存分配及常见内存问题(1)——简介

    原文:SQL SERVER 内存分配及常见内存问题(1)--简介 一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解 ...

  3. SQL SERVER 内存分配及常见内存问题 简介

    一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解SQL SERVER与windows是如何协调.共享内存.并且SQ ...

  4. 笔记26-徐 SQLSERVER内存分配和常见内存问题

    1 --64位SQLSERVER   应用在IA64操作系统                         7TB                         2TB               ...

  5. [转]SQL Server 性能调优(内存)

      存储引擎自调整 sql server 是如何分配内存的 32bit地址空间的限制 用户模式vas分配和virtualalloc 非boffer pool 分配内存(保留内存) VAS调整 AWE ...

  6. 对于SQL Server,我需要多少内存

    经常被问到的一个问题:对于SQL Server,我需要多少内存?这个问题还是有同样的典型的“看情况而定”答案.在今天的文章里,我们来详细看下“看情况而定的”的不同方面. 全新SQL Server安装 ...

  7. 如何修改SQL Server 2008 R2数据库的内存

    本篇经验将和大家介绍如何修改SQL Server 2008 R2数据库的内存,希望对大家的工作和学习有所帮助! 工具/原料   SQL Sever 2008 R2数据库已安装 方法/步骤   1 打开 ...

  8. malloc内存分配与free内存释放的原理

    malloc内存分配与free内存释放的原理 前段时间一直想看malloc的原理,在搜了好几篇malloc源码后遂放弃,晦涩难懂. 后来室友买了本深入理解计算机系统的书,原来上面有讲malloc的原理 ...

  9. rt-thread中动态内存分配之小内存管理模块方法的一点理解

    @2019-01-18 [小记] rt-thread中动态内存分配之小内存管理模块方法的一点理解 > 内存初始化后的布局示意 lfree指向内存空闲区首地址 /** * @ingroup Sys ...

随机推荐

  1. HTML5-布局的使用

    DIV布局: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UT ...

  2. 一些Python的惯用法和小技巧:Pythonic

    Pythonic其实是个模糊的含义,没有确定的解释.网上也没有过多关于Pythonic的说明,我个人的理解是更加Python,更符合Python的行为习惯.本文主要是说明一些Python的惯用法和小技 ...

  3. PDF

    源代码请从这里下载: http://download.csdn.net/source/2984395 使用的是JSP编程 ‍ 这是导出后的效果 ‍ 这是数据库中的内容 ‍ 部分代码: <%@ p ...

  4. 【Hello CC.NET】自动化发布时 Web.config 文件维护

    在 <[Hello CC.NET]CC.NET 实现自动化集成> 的 HellowWorld 中经实现: 1.获取源码 2.编译项目 3.集成测试 4.Ftp发布项目 5.创建安装包 6. ...

  5. 深入探究js中无所不在的this

    黄金守则: this对象是在运行时基于函数的执行环境绑定的:在全局函数中,this等于window而当函数被作为某个对象的方法调用时, this等于那个对象. 下面是一些相关实践: --------- ...

  6. java.sql.SQLException: No suitable driver 问题解决

    最近在学习java,用到c3p0数据库连接池,遇到一个很奇怪的现象,用main方法测试是可以正常连接数据库的,但是使用jsp调用代码,就会报如下图的错误! 最下面的java.sql.SQLExcept ...

  7. STSdb,最强纯C#开源NoSQL和虚拟文件系统 4.0 RC2 支持C/S架构

    STSdb是什么 再来说明一下STSdb是什么:STSdb是C#写的开源嵌入式数据库和虚拟文件系统,支持实时索引,性能是同类产品的几倍到几十倍,访问官方网站. 温故知新 之前发了文章<STSdb ...

  8. Visual Studio 2015速递(2)——提升效率和质量(VS2015核心竞争力)

    系列文章 Visual Studio 2015速递(1)——C#6.0新特性怎么用 Visual Studio 2015速递(2)——提升效率和质量(VS2015核心竞争力) Visual Studi ...

  9. spring源码分析(二)Aop

    创建日期:2016.08.19 修改日期:2016.08.20-2016.08.21 交流QQ:992591601 参考资料:<spring源码深度解析>.<spring技术内幕&g ...

  10. 自已写的Json序列化方法,可以序列话对象的只读属性

    /* * by zhangguozhan 2015/1/5 * P2B.Common.CJson.ConvertJson.ObjectToJson<SenderDomainModel>方法 ...