相信不少的朋友,無(wú)論是做開(kāi)發(fā)、架構(gòu)的,還是DBA等,都經(jīng)常聽(tīng)說(shuō)“調(diào)優(yōu)”這個(gè)詞。說(shuō)起“調(diào)優(yōu)”,可能會(huì)讓很多技術(shù)人員心頭激情澎湃,也可能會(huì)讓很多人感覺(jué)苦惱。當(dāng)然,也有很多人對(duì)此不屑一顧,因?yàn)椴⒉皇敲總€(gè)人接觸到的項(xiàng)目都很大,也不是每個(gè)人做的項(xiàng)目都對(duì)性能要求很高。
在主流的企業(yè)級(jí)開(kāi)發(fā)和互聯(lián)網(wǎng)應(yīng)用中,數(shù)據(jù)庫(kù)的重要性是不言而喻的,而數(shù)據(jù)庫(kù)的性能對(duì)于整個(gè)系統(tǒng)的性能而言也是至關(guān)重要的,這里無(wú)庸贅述。
sqlserver的性能調(diào)優(yōu),其實(shí)是個(gè)很寬廣的話題。坦白講,想從概念到實(shí)踐的完全講清楚并掌握透徹,可能至少需要幾本書的內(nèi)容。本文只是一個(gè)概念級(jí)的總結(jié),希望讀者能對(duì)此有新的認(rèn)識(shí),在調(diào)優(yōu)路上有所幫助。如果感興趣的朋友很多,后續(xù)可能會(huì)分享一些實(shí)戰(zhàn)經(jīng)驗(yàn)。
首先搞清楚,性能調(diào)優(yōu)的目標(biāo)
從最直觀,最常見(jiàn)的角度來(lái)講,主要包含如下兩點(diǎn):
優(yōu)化響應(yīng)時(shí)間
何為“優(yōu)化響應(yīng)時(shí)間” 呢?說(shuō)的通俗點(diǎn),就是經(jīng)過(guò)調(diào)優(yōu)后,執(zhí)行查詢、更新等操作的時(shí)候,數(shù)據(jù)庫(kù)的反應(yīng)速度更快,花費(fèi)的時(shí)間更少。
比較常見(jiàn)的,以前執(zhí)行某條sql查詢語(yǔ)句,可能需要3秒鐘,加了索引后,1秒鐘不到就搞定了。加索引,這也是最典型最"廉價(jià)"的優(yōu)化手段。
在做“優(yōu)化響應(yīng)時(shí)間”時(shí),需要了解:用戶環(huán)境,程序,環(huán)境,用戶和數(shù)據(jù)等方面的知識(shí)。
優(yōu)化吞吐量
說(shuō)起“吞吐量”,那就要想到“并發(fā)”了。其實(shí)就是“同時(shí)處理請(qǐng)求”的能力。如何提高數(shù)據(jù)庫(kù)"抗并發(fā)"的能力呢?首先要了解sqlserver是如何訪問(wèn)數(shù)據(jù)的,如何控制并發(fā)訪問(wèn)的(事務(wù)隔離級(jí)別,鎖等),如何與底層操作系統(tǒng)進(jìn)行交互的,還要了解“多線程、進(jìn)程”等方面的知識(shí)。
比較常見(jiàn)的手段,通過(guò)降低事務(wù)隔離級(jí)別(一定程度地犧牲數(shù)據(jù)一致性等),這種“軟手段”通常會(huì)起到很好的效果。其次,單臺(tái)DB Server達(dá)到一定瓶頸后,可以通過(guò)“集群”等方式,實(shí)現(xiàn)請(qǐng)求的“負(fù)載均衡”的,來(lái)達(dá)到“抗并發(fā)”的目的,效果也是立竿見(jiàn)影的。
性能調(diào)優(yōu)的方法論--迭代
基線
通俗點(diǎn)講,就是用來(lái)計(jì)算或者比較的標(biāo)準(zhǔn)。通常以當(dāng)前系統(tǒng)性能為基準(zhǔn),或者以匹配系統(tǒng)性能為基準(zhǔn)。指各個(gè)組件發(fā)揮到最大。
成本
用來(lái)升級(jí),更換等提升組件性能時(shí)的時(shí)間,金錢,勞力等等。
基線的定義,以用戶期望值為基礎(chǔ),可能會(huì)涉及以下因素
以往的經(jīng)驗(yàn),應(yīng)用程序的基準(zhǔn),業(yè)界的標(biāo)準(zhǔn),以前版本的情況
基線的表示方式,包括:每秒完成的批處理(作業(yè)),每秒傳輸量,每秒數(shù)據(jù)量,磁盤掃描時(shí)間等等
分析影響性能的因素:
數(shù)據(jù)庫(kù)設(shè)計(jì)(是否復(fù)合范式,是否合理歸檔、分區(qū)、分表等)
軟件系統(tǒng) (操作系統(tǒng)優(yōu)化,數(shù)據(jù)庫(kù)系統(tǒng)的配置,資源的規(guī)劃和監(jiān)控等)
硬件基礎(chǔ)架構(gòu) (設(shè)備規(guī)格,硬件性能,負(fù)載均衡,容災(zāi)等)
Sql語(yǔ)句的寫法、索引和統(tǒng)計(jì)信息,事務(wù)和鎖,應(yīng)用程序訪問(wèn)代碼(連接過(guò)多、頻繁開(kāi)關(guān)等)
性能調(diào)優(yōu)的順序:
從左往右,從技術(shù)難度、成本、實(shí)效去考慮
DETECT 方法
發(fā)現(xiàn)問(wèn)題、探究原因、提供可能的解決方法、執(zhí)行最有可能的解決方案、確認(rèn)是否成功解決(如果沒(méi)有,重復(fù)前面的步驟)、完成其余的工作
DETECT方法論中的這些工作細(xì)分起來(lái),會(huì)有很多,這里暫時(shí)不做過(guò)多描述。具體調(diào)優(yōu)的步驟、性能調(diào)優(yōu)工具的使用,下篇文章繼續(xù)。
您可能感興趣的文章:- SQL Server性能調(diào)優(yōu)之緩存
- SQL Server 性能調(diào)優(yōu)之查詢從20秒至2秒的處理方法
- sql server性能調(diào)優(yōu) I/O開(kāi)銷的深入解析