原文:
SQL SERVER 內存分配及常見內存問題(2)——DMV查詢
內存中的數據頁由哪些表格組成,各占多少?
可以查看各種對象各占多少內存:
--使用DMV分析SQL SERVER 啟動以來做read最多的語句
內存動態管理視圖(DMV):
從sys.dm_os_memory_clerks開始。
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]
其中type為Memory Clerk的名稱,可以知道內存的用途。
對于得出的數據:
Memoryclerk_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參數,如果參數過長,這部分內存的使用量會比較大。
sys.dm_os_buffer_descriptors
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
會緩存執行計劃的對象:
proc:存儲過程
prepared:預定義語句
Adhoc:動態查詢
ReplProc:復制篩選過程
Trigger:觸發器
View:視圖
Default:默認值
UsrTab:用戶表
SysTab:系統表
Check:Check約束
Rule:規則
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
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
