zoukankan      html  css  js  c++  java
  • 查看SqlServer的内存使用情况

    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、2008
    from    sys.dm_os_memory_clerks
    group by type
    order 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_count
    from    sys.dm_exec_cached_plans
    group by cacheobjtype, objtype
    order by cacheobjtype, objtype
    
    
    -- 查询缓存中具体的执行计划,及对应的SQL
    -- 将此结果按照数据表或SQL进行统计,可以作为基线,调整索引时考虑
    -- 查询结果会很大,注意将结果集输出到表或文件中
    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

    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

    sql server 各种等待类型-转

  • 相关阅读:
    ウェブプロジャクトがジャワープロジャクトに参照する方法
    web.xml 中的listener、 filter、servlet 加载顺序及其详解
    财富定律
    jsp文件下载完整方法
    使用Axis开发Web Service程序
    CDH安装指南——酒仙网技术
    linux下 putty 的痛苦编译之路
    博客园
    windows 下 cannal & otter 配置
    Go 1.8 正式发布,编译时间比 Go 1.7 提高约 15%
  • 原文地址:https://www.cnblogs.com/xcsn/p/7766843.html
Copyright © 2011-2022 走看看