濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > sql server性能調(diào)優(yōu) I/O開銷的深入解析

sql server性能調(diào)優(yōu) I/O開銷的深入解析

熱門標(biāo)簽:外呼系統(tǒng)電銷專用 千呼電銷機(jī)器人價(jià)格 百度地圖標(biāo)注不同路線 武漢長沙外呼系統(tǒng)方法和技巧 智能語音外呼系統(tǒng)選哪家 優(yōu)質(zhì)地圖標(biāo)注 怎樣在地圖上標(biāo)注路線圖標(biāo) 奧威地圖標(biāo)注多個(gè)地方 京華物流公司地圖標(biāo)注

一.概述

IO 內(nèi)存是sql server最重要的資源,數(shù)據(jù)從磁盤加載到內(nèi)存,再從內(nèi)存中緩存,輸出到應(yīng)用端,在sql server 內(nèi)存初探中有介紹。在明白了sqlserver內(nèi)存原理后,就能更好的分析I/O開銷,從而提升數(shù)據(jù)庫的整體性能。 在生產(chǎn)環(huán)境下數(shù)據(jù)庫的sqlserver服務(wù)啟動(dòng)后一個(gè)星期,就可以通過dmv來分析優(yōu)化。在I/O分析這塊可以從物理I/O和內(nèi)存I/O二方面來分析, 重點(diǎn)分析應(yīng)在內(nèi)存I/O上,可能從多個(gè)維度來分析,比如從sql server服務(wù)啟動(dòng)以來 歷史I/O開銷總量分析,自執(zhí)行計(jì)劃編譯以來執(zhí)行次數(shù)總量分析,平均I/0次數(shù)分析等。

sys.dm_exec_query_stats:返回緩存的查詢計(jì)劃,緩存計(jì)劃中的每個(gè)查詢語句在該視圖中對應(yīng)一行。當(dāng)sql server工作負(fù)載過重時(shí),該dmv也有可以統(tǒng)計(jì)不正確。如果sql server服務(wù)重啟緩存的數(shù)據(jù)將會(huì)清掉。這個(gè)dmv包括了太多的信息像內(nèi)存掃描數(shù),內(nèi)存空間數(shù),cpu耗時(shí)等,具體查看msdn文檔。

sys.dm_exec_sql_text:返回的 SQL 文本批處理,它是由指定sql_handle,其中的text列是查詢的文本。

1.1 按照物理讀的頁面數(shù)排序 前50名

SELECT TOP 50
 qs.total_physical_reads,qs.execution_count,
 qs.total_physical_reads/qs.execution_count AS [avg I/O],
 qs. creation_time,
 qs.max_elapsed_time,
 qs.min_elapsed_time,
 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

如下圖所示:

  total_physical_reads:計(jì)劃自編譯后在執(zhí)行期間所執(zhí)行的物理讀取總次數(shù)。

  execution_count :計(jì)劃自上次編譯以來所執(zhí)行的次數(shù)。

  [avg I/O]:    平均讀取的物理次數(shù)(頁數(shù))。

  creation_time:編譯計(jì)劃的時(shí)間。

        query_text:執(zhí)行計(jì)劃對應(yīng)的sql腳本

       后面來包括所在的數(shù)據(jù)庫ID:dbid,數(shù)據(jù)庫名稱:dbname

1.2 按照邏輯讀的頁面數(shù)排序 前50名

SELECT TOP 50
 qs.total_logical_reads,
 qs.execution_count,
 qs.max_elapsed_time,
 qs.min_elapsed_time,
 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,
 creation_time,
 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

如下圖所示:

通過上面的邏輯內(nèi)存截圖來簡要分析下:

  從內(nèi)存掃描總量上看最多的是8311268次頁掃描,自執(zhí)行編譯后運(yùn)行t-sql腳本358次,這里的耗時(shí)是毫秒為單位包括最大耗時(shí)和最小耗時(shí),平均I/O是232115次(頁),該語句文本是一個(gè)update 修改,該表數(shù)據(jù)量大沒有完全走索引(權(quán)衡后不對該語句做索引覆蓋),但執(zhí)行次數(shù)少,且每次執(zhí)行時(shí)間是非工作時(shí)間,雖然掃描開銷大,但沒有影響白天客戶使用。

  從執(zhí)行次數(shù)是有一個(gè)43188次, 內(nèi)存掃描總量排名39位。該語句雖然只有815條,但執(zhí)行次數(shù)很多,如里服務(wù)器有壓力可以優(yōu)化,一般是該語句沒有走索引。把文本拿出來如下

SELECT Count(*) AS TotalCount FROM [MEM_FlagshipApply]
 WITH(NOLOCK) Where (((([Status] = 2) AND ([IsDeleted] = 1)) AND ([MemType] = 0)) AND ([MEMID] > 6))

下面兩圖一個(gè)是分析該語句的執(zhí)行計(jì)劃,sqlserver提示缺少索引,另一個(gè)是i/o統(tǒng)計(jì)掃描了80次。

新建索引后在來看看

 CREATE NONCLUSTERED INDEX ix_1
ON [dbo].[MEM_FlagshipApply] ([Status],[IsDeleted],[MemType],[MEMID])

  

     

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • SQL Server性能調(diào)優(yōu)之緩存
  • sqlserver性能調(diào)優(yōu)經(jīng)驗(yàn)總結(jié)
  • SQL Server 性能調(diào)優(yōu)之查詢從20秒至2秒的處理方法

標(biāo)簽:來賓 宿州 防疫戰(zhàn)設(shè) 天水 益陽 七臺(tái)河 銅仁 威海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sql server性能調(diào)優(yōu) I/O開銷的深入解析》,本文關(guān)鍵詞  sql,server,性能,調(diào)優(yōu),開銷,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sql server性能調(diào)優(yōu) I/O開銷的深入解析》相關(guān)的同類信息!
  • 本頁收集關(guān)于sql server性能調(diào)優(yōu) I/O開銷的深入解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    崇礼县| 嘉祥县| 朝阳县| 永顺县| 墨脱县| 西和县| 肇庆市| 镇平县| 胶州市| 姚安县| 于都县| 宁德市| 滦平县| 泾源县| 潍坊市| 安图县| 苍溪县| 含山县| 称多县| 漯河市| 太白县| 香河县| 天峨县| 洛隆县| 清流县| 株洲市| 耒阳市| 益阳市| 织金县| 静宁县| 聂拉木县| 连云港市| 卫辉市| 巴东县| 临朐县| 瑞昌市| 邳州市| 乐东| 常德市| 航空| 西峡县|