博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
查看SqlServer的内存使用情况
阅读量:7197 次
发布时间:2019-06-29

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

SQL SERVER内存按存放数据的类型,大概可以分为三类:

1、buffer pool,存放数据页面的缓冲区,sql server数据都是存放在一个个8K的页面里,当用户需要使用这个页面上的数据时,都是把整个页面加载到内存的buffer pool区缓存起         来。

2、各类consumer:

      connect:SQL SERVER为每一个客户端连接分配一块内存,用来存储连接的信息,以及发过来的指令和缓存指令结果待待客户端取走

      无数据:表、存储过程、索引等的元数据

      锁:SQL SERVER中锁是稀有资源,会占用大量内存

      Query plan:缓存SQL的执行计划

      Optimizer:生成执行 计划过程中需要使用内存

3、线程内存:sql server会为每个线程分配0.5M的内存,用来存放线程的数据结构和相关信息

 

sql1:

-- 查询SqlServer总体的内存使用情况select      type        , sum(virtual_memory_reserved_kb) VM_Reserved        , sum(virtual_memory_committed_kb) VM_Commited        , sum(awe_allocated_kb) AWE_Allocated        , sum(shared_memory_reserved_kb) Shared_Reserved        , sum(shared_memory_committed_kb) Shared_Commited        --, sum(single_pages_kb)    --SQL2005、2008        --, sum(multi_pages_kb)        --SQL2005、2008from    sys.dm_os_memory_clerksgroup by typeorder by type-- 查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量-- 从这些信息可以看出,系统经常要访问的都是哪些表,有多大?select p.object_id, object_name=object_name(p.object_id), p.index_id, buffer_pages=count(*) from sys.allocation_units a,     sys.dm_os_buffer_descriptors b,     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()group by p.object_id,p.index_id order by buffer_pages desc -- 查询缓存的各类执行计划,及分别占了多少内存-- 可以对比动态查询与参数化SQL(预定义语句)的缓存量select    cacheobjtype        , objtype        , sum(cast(size_in_bytes as bigint))/1024 as size_in_kb        , count(bucketid) as cache_countfrom    sys.dm_exec_cached_plansgroup by cacheobjtype, objtypeorder by cacheobjtype, objtype-- 查询缓存中具体的执行计划,及对应的SQL-- 将此结果按照数据表或SQL进行统计,可以作为基线,调整索引时考虑-- 查询结果会很大,注意将结果集输出到表或文件中SELECT  usecounts ,        refcounts ,        size_in_bytes ,        cacheobjtype ,        objtype ,        TEXTFROM    sys.dm_exec_cached_plans cp        CROSS APPLY sys.dm_exec_sql_text(plan_handle)ORDER BY objtype DESC ;GO

sql2:

select OBJECT_NAME(object_id) 表名,COUNT(*) 页数,COUNT(*)*8/1024.0 Mb                            from   sys.dm_os_buffer_descriptors a,sys.allocation_units b,sys.partitions c                            where  a.allocation_unit_id=b.allocation_unit_id        and b.container_id=c.hobt_id                  and database_id=DB_ID()                            group by OBJECT_NAME(object_id)                         order by 2 desc

 

 

参考:

http://www.cnblogs.com/zhaoguan_wang/p/4602866.html

http://blog.csdn.net/shutao917/article/details/51444424

http://blog.csdn.net/burgess_liu/article/details/52813727

http://blog.csdn.net/burgess_liu/article/details/17739725

http://blog.csdn.net/burgess_liu/article/details/17733149

你可能感兴趣的文章
Android 自定义title样式
查看>>
Bootstrap<基础一> CSS 概览
查看>>
Linux永久修改系统时间和时区方法
查看>>
HDU1257 最小拦截系统 【贪婪】
查看>>
(年代久远的)常用表情符号
查看>>
Android GUI之Window、WindowManager
查看>>
Android 微信分享信息
查看>>
ECMAScript 6 Features 中文版
查看>>
UVA 11149 - Power of Matrix(矩阵乘法)
查看>>
用yo命令创建项目
查看>>
log4j与commons-logging,slf4j的关系(转)
查看>>
Swift - 使用CGBlendMode改变UIImage颜色
查看>>
VB常用字符串操作函数
查看>>
Python 使用pymongo操作mongodb库
查看>>
jQuery DataTables插件分页允许输入页码跳转
查看>>
虚拟路由冗余协议VRRP
查看>>
sql:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询...
查看>>
jQuery判断复选框是否勾选
查看>>
对于jdk jre jvm的简单认识
查看>>
eclipse快捷键
查看>>