婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 優化SQL Server的內存占用之執行緩存

優化SQL Server的內存占用之執行緩存

熱門標簽:山西語音外呼系統價格 威海智能語音外呼系統 溫州語音外呼系統代理 西安青牛防封電銷卡 智能語音外呼系統哪個牌子好 南京電銷外呼系統運營商 重慶防封電銷機器人供應商 400電話申請需要開戶費嗎 北京辦理400電話多少
首先說明一下SQL Server內存占用由哪幾部分組成。SQL Server占用的內存主要由三部分組成:數據緩存(Data Buffer)、執行緩存(Procedure Cache)、以及SQL Server引擎程序。SQL Server引擎程序所占用緩存一般相對變化不大,則我們進行內存調優的主要著眼點在數據緩存和執行緩存的控制上。本文主要介紹一下執行緩存的調優。數據緩存的調優將在另外的文章中介紹。

對于減少執行緩存的占用,主要可以通過使用參數化查詢減少內存占用。
1、使用參數化查詢減少執行緩存占用
我們通過如下例子來說明一下使用參數化查詢對緩存占用的影響。為方便試驗,我們使用了一臺沒有其它負載的SQL Server進行如下實驗。
下面的腳本循環執行一個簡單的查詢,共執行10000次。

首先,我們清空一下SQL Server已經占用的緩存:
dbcc freeproccache

然后,執行腳本:
復制代碼 代碼如下:

DECLARE @t datetime
SET @t = getdate()
SET NOCOUNT ON
DECLARE @i INT, @count INT, @sql nvarchar(4000)

SET @i = 20000
WHILE @i = 30000
BEGIN
SET @sql = 'SELECT @count=count(*) FROM P_Order WHERE MobileNo = ' + cast( @i as varchar(10) )
EXEC sp_executesql @sql ,N'@count INT OUTPUT', @count OUTPUT
SET @i = @i + 1
END
PRINT DATEDIFF( second, @t, current_timestamp )

輸出:
DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。
11

使用了11秒完成10000次查詢。
我們看一下SQL Server緩存中所占用的查詢計劃:
Select Count(*) CNT,sum(size_in_bytes) TotalSize
From sys.dm_exec_cached_plans

查詢結果:共有2628條執行計劃緩存在SQL Server中。它們所占用的緩存達到:
92172288字節 = 90012KB = 87 MB。

我們也可以使用dbcc memorystatus 命令來檢查SQL Server的執行緩存和數據緩存占用。
執行結果如下:

 

 

執行緩存占用了90088KB,有2629個查詢計劃在緩存里,有1489頁空閑內存(每頁8KB)可以被數據緩存和其他請求所使用。

我們現在修改一下前面的腳本,然后重新執行一下dbcc freeproccache。再執行一遍修改后的腳本:
復制代碼 代碼如下:

DECLARE @t datetime
SET @t = getdate()
SET NOCOUNT ON
DECLARE @i INT, @count INT, @sql nvarchar(4000)

SET @i = 20000
WHILE @i = 30000
BEGIN
SET @sql = 'select @count=count(*) FROM P_Order WHERE MobileNo = @i'
EXEC sp_executesql @sql, N'@count int output, @i int', @count OUTPUT, @i
SET @i = @i + 1
END
PRINT DATEDIFF( second, @t, current_timestamp )

輸出:
DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。
1
即這次只用1秒鐘即完成了10000次查詢。
我們再看一下sys.dm_exec_cached_plans中的查詢計劃:
Select Count(*) CNT,sum(size_in_bytes) TotalSize From sys.dm_exec_cached_plans

查詢結果:共有4條執行計劃被緩存。它們共占用內存: 172032字節 = 168KB。
如果執行dbcc memorystatus,則得到結果:

 

有12875頁空閑內存(每頁8KB)可以被數據緩存所使用。

到這里,我們已經看到了一個反差相當明顯的結果。在現實中,這個例子中的前者,正是經常被使用的一種執行SQL腳本的方式(例如:在程序中通過合并字符串方式拼成一條SQL語句,然后通過ADO.NET或者ADO方式傳入SQL Server執行)。

解釋一下原因:
我們知道,SQL語句在執行前首先將被編譯并通過查詢優化引擎進行優化,從而得到優化后的執行計劃,然后按照執行計劃被執行。對于整體相似、僅僅是參數不同的SQL語句,SQL Server可以重用執行計劃。但對于不同的SQL語句,SQL Server并不能重復使用以前的執行計劃,而是需要重新編譯出一個新的執行計劃。同時,SQL Server在內存足夠使用的情況下,此時并不主動清除以前保存的查詢計劃(注:對于長時間不再使用的查詢計劃,SQL Server也會定期清理)。這樣,不同的SQL語句執行方式,就將會大大影響SQL Server中存儲的查詢計劃數目。如果限定了SQL Server最大可用內存,則過多無用的執行計劃占用,將導致SQL Server可用內存減少,從而在執行查詢時尤其是大的查詢時與磁盤發生更多的內存頁交換。如果沒有限定最大可用內存,則SQL Server由于可用內存減少,從而會占用更多內存。

對此,我們一般可以通過兩種方式實現參數化查詢:一是盡可能使用存儲過程執行SQL語句(這在現實中已經成為SQL Server DBA的一條原則),二是使用sp_executesql 方式執行單個SQL語句(注意不要像上面的第一個例子那樣使用sp_executesql)。

在現實的同一個軟件系統中,大量的負載類型往往是類似的,所區別的也只是每次傳入的具體參數值的不同。所以使用參數化查詢是必要和可能的。另外,通過這個例子我們也看到,由于使用了參數化查詢,不僅僅是優化了SQL Server內存占用,而且由于能夠重復使用前面被編譯的執行計劃,使后面的執行不需要再次編譯,最終執行10000次查詢總共只使用了1秒鐘時間。

2、檢查并分析SQL Server執行緩存中的執行計劃
通過上面的介紹,我們可以看到SQL緩存所占用的內存大小。也知道了SQL Server執行緩存中的內容主要是各種SQL語句的執行計劃。則要對緩存進行優化,就可以通過具體分析緩存中的執行計劃,看看哪些是有用的、哪些是無用的執行計劃來分析和定位問題。

通過查詢DMV: sys.dm_exec_cached_plans,可以了解數據庫中的緩存情況,包括被使用的次數、緩存類型、占用的內存大小等。
SELECT usecounts, cacheobjtype, objtype,size_in_bytes, plan_handle
FROM sys.dm_exec_cached_plans

 

通過緩存計劃的plan_handle可以查詢到該執行計劃詳細信息,包括所對應的SQL語句:

SELECT  TOP 100 usecounts,

    objtype,

    p.size_in_bytes,

    [sql].[text]

FROM sys.dm_exec_cached_plans p

OUTER APPLY sys.dm_exec_sql_text (p.plan_handle) sql

ORDER BY usecounts

 

我們可以選擇針對那些執行計劃占用較大內存、而被重用次數較少的SQL語句進行重點分析。看其調用方式是否合理。另外,也可以對執行計劃被重復使用次數較多的SQL語句進行分析,看其執行計劃是否已經經過優化。進一步,通過對查詢計劃的分析,還可以根據需要找到系統中最占用IO、CPU時間、執行次數最多的一些SQL語句,然后進行相應的調優分析。篇幅所限,這里不對此進行過多介紹。讀者可以查閱聯機叢書中的:sys.dm_exec_query_plan內容得到相關幫助。

附:

1:關于DBCC MEMORY,可以查看微軟的知識庫: http://support.microsoft.com/kb/907877/EN-US

2:關于sys.dm_exec_cached_planssys.dm_exec_sql_text,請參閱聯機叢書。

您可能感興趣的文章:
  • SQL語句實現查詢SQL Server內存使用狀況
  • SQL Server 數據頁緩沖區的內存瓶頸分析
  • SqlServer如何通過SQL語句獲取處理器(CPU)、內存(Memory)、磁盤(Disk)以及操作系統相關信息
  • SQL Server 2008 R2占用cpu、內存越來越大的兩種解決方法
  • 解決SQL Server虛擬內存不足情況
  • 揭秘SQL Server 2014有哪些新特性(1)-內存數據庫
  • 淺談SQL Server 對于內存的管理[圖文]
  • SQL Server內存遭遇操作系統進程壓榨案例分析
  • SQL Server在AlwaysOn中使用內存表的“踩坑”記錄
  • sql server學習基礎之內存初探

標簽:河源 宜春 濟寧 金昌 貸款群呼 新余 黃山 中衛

巨人網絡通訊聲明:本文標題《優化SQL Server的內存占用之執行緩存》,本文關鍵詞  優化,SQL,Server,的,內存,占,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《優化SQL Server的內存占用之執行緩存》相關的同類信息!
  • 本頁收集關于優化SQL Server的內存占用之執行緩存的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩中文精品| 亚洲乱码精品一二三四区日韩在线| 在线日韩国产精品| 韩国精品主播一区二区在线观看| 精品视频免费看| 国产精品久久久久久久久免费丝袜| 日韩av中文字幕一区二区| 成人黄色片在线观看| 51久久夜色精品国产麻豆| 国产精品久久久久久亚洲毛片| 国产一区二区福利| 日韩免费看网站| 国产一区二区美女诱惑| 日韩一区日韩二区| 欧美色综合网站| 奇米影视一区二区三区| 欧美激情在线一区二区三区| 91一区一区三区| 一区二区三区四区蜜桃| 欧美日韩第一区日日骚| 狠狠色狠狠色合久久伊人| 国产精品成人免费精品自在线观看 | 亚洲成人7777| 国产欧美一区二区三区鸳鸯浴 | av资源网一区| 99麻豆久久久国产精品免费 | 色一情一伦一子一伦一区| 色婷婷综合五月| 5566中文字幕一区二区电影| 日韩精品最新网址| 国产亚洲婷婷免费| 亚洲欧美日韩国产综合| 亚洲综合色噜噜狠狠| 亚洲成年人网站在线观看| 丝袜美腿亚洲一区二区图片| 久久99精品久久久| 不卡一二三区首页| 欧美绝品在线观看成人午夜影视| 欧美电影免费观看高清完整版在线 | 不卡的av中国片| 99国产精品久久| 在线成人av网站| 日韩一区二区三区免费看| 久久亚洲捆绑美女| 亚洲精品成人在线| 奇米四色…亚洲| 成人黄色在线网站| 欧美精品久久天天躁| 国产日产欧美精品一区二区三区| 亚洲天堂2014| 精品一区二区久久| 在线视频国内自拍亚洲视频| 久久综合一区二区| 亚洲香蕉伊在人在线观| 国产成人午夜精品影院观看视频| 在线视频一区二区三| 精品乱码亚洲一区二区不卡| 综合分类小说区另类春色亚洲小说欧美| 三级影片在线观看欧美日韩一区二区| 激情五月婷婷综合网| 日本高清不卡视频| 国产视频亚洲色图| 日韩不卡在线观看日韩不卡视频| yourporn久久国产精品| 精品久久久久久久久久久久久久久久久| 欧美一区二区在线免费观看| 美女视频黄免费的久久| 精品福利二区三区| 亚洲成人www| 中文字幕亚洲精品在线观看| 老司机精品视频在线| 精品国产凹凸成av人网站| 国产伦精品一区二区三区在线观看 | 蜜臀av在线播放一区二区三区| 国产精品国产三级国产普通话99 | 精品一二线国产| 亚洲免费观看高清完整版在线观看 | 激情综合五月婷婷| 久久久精品黄色| 精品动漫一区二区三区在线观看| 国产欧美一区二区精品仙草咪| 国产日韩欧美在线一区| 成人白浆超碰人人人人| 九色综合国产一区二区三区| 国产精品夫妻自拍| 91蜜桃免费观看视频| 日韩在线一二三区| 欧美国产成人在线| 欧美一区二区视频在线观看2020| 成人激情黄色小说| 欧美日高清视频| 欧美一区在线视频| 日韩欧美www| 久久精品人人做| 久久久激情视频| 亚洲成a人片在线观看中文| 精品日韩一区二区| 国产午夜精品一区二区三区嫩草 | 九九在线精品视频| **网站欧美大片在线观看| 日本一区二区三区电影| 国产精品乱子久久久久| 欧美一区二区三区日韩| 欧美日本在线看| 日韩欧美在线影院| 亚洲成人7777| 国产在线观看一区二区| 亚洲免费观看高清完整版在线观看| 欧美精品99久久久**| 国产精品毛片久久久久久| 曰韩精品一区二区| 美国三级日本三级久久99| 视频一区二区三区中文字幕| 国产精品久久看| 成人av电影在线观看| 91啪亚洲精品| 91福利视频在线| 日韩欧美精品在线视频| 日韩精品一区在线| 美女网站视频久久| 在线视频一区二区三区| 337p日本欧洲亚洲大胆精品| 菠萝蜜视频在线观看一区| 香蕉成人伊视频在线观看| 91精品午夜视频| 青青青伊人色综合久久| 青青草国产精品亚洲专区无| 欧美tickling网站挠脚心| 97国产一区二区| 91国模大尺度私拍在线视频| av一二三不卡影片| 亚洲一区二区三区四区在线免费观看 | 欧美一区二区三区在线电影| 日韩电影在线免费观看| 国产一区 二区| 国产成人自拍网| 欧美丝袜自拍制服另类| 51精品秘密在线观看| 国产精品乱码妇女bbbb| 综合久久综合久久| 国产一区二区三区在线看麻豆| 成人午夜大片免费观看| 国产色产综合产在线视频| 日韩激情在线观看| 精品三级在线观看| 成人激情午夜影院| 亚洲精品高清在线观看| 欧美一区2区视频在线观看| 青青草原综合久久大伊人精品 | 国产精品国产a级| 九九久久精品视频| 中文字幕一区二区三区在线不卡 | 91亚洲精品久久久蜜桃网站| 欧美一区二区三区免费在线看| 国产精品卡一卡二卡三| 国产精品一区二区无线| 久久综合久久综合久久综合| 日韩精品乱码av一区二区| 欧美精品高清视频| 激情综合网av| 国产精品久久久久久妇女6080| av一二三不卡影片| 亚洲免费伊人电影| 欧美中文字幕一二三区视频| 国产精品久久久久影院| 日本电影欧美片| 麻豆成人久久精品二区三区红| 2020国产成人综合网| 99国产精品视频免费观看| 亚洲精品视频在线观看免费| 在线电影院国产精品| 高清不卡一区二区| 三级欧美在线一区| 欧美经典一区二区三区| 色偷偷久久一区二区三区| 奇米精品一区二区三区在线观看| 久久一区二区三区四区| 欧美中文字幕一区二区三区亚洲| 日韩制服丝袜av| 亚洲愉拍自拍另类高清精品| 日韩欧美激情在线| 色狠狠综合天天综合综合| 国产精品综合视频| 蜜臀精品久久久久久蜜臀| 亚洲欧美乱综合| 亚洲欧美精品午睡沙发| 国产精品久久久久影院老司| www精品美女久久久tv| 日韩一区二区三区视频在线观看| 91影院在线免费观看| 懂色av一区二区三区免费观看| 精品一区二区av| 国产精品资源在线看| 国产盗摄一区二区| 成人免费观看av| 成人av资源在线| av高清不卡在线| 91久久免费观看| 欧美一区二区视频在线观看2020| 7777精品伊人久久久大香线蕉最新版|