1. 程式人生 > >效能優化:監控索引的使用情況

效能優化:監控索引的使用情況

監控索引

黃瑋(Fuyuncat),資深 Oracle DBA,從事 Oracle 資料庫管理、維護與開發工作十餘年,有豐富的大型資料庫設計、開發與維護方面的經驗,部落格www.HelloDBA.com

編輯手記:索引的合理使用能夠提高SQL的執行效率,但索引並不是萬能的,也不是所有的索引都會被Oracle使用,今天揀選這篇文章,帶大家一起給資料庫減肥。

一個系統,經過長期的執行、維護和版本更新後,可能會產生大量的索引,甚至索引所佔空間遠遠大於資料所佔的空間。很多索引,在初期設計時,對於系統來說是有用的。但是,經過系統的升級、資料表結構的調整、應用的改變,很多索引逐漸不被使用,成為了垃圾索引。這些索引佔據了大量資料空間,增加了系統的維護量,甚至會降低系統性能。因此,DBA應該根據系統的變化,找出垃圾索引,為系統減肥。

Oracle 9i後,可以通過設定對索引進行監控,來監視索引在系統中是否被使用到。語法如下:

alter index <INDEX_NAME> monitoring usage;

如果需要取消監控,可以使用以下語句:

alter index <INDEX_NAME> nomonitoring usage;

設定監控後,就可以查詢檢視v$object_usage來確認該索引是否被使用。

以下是一個DEMO演示:

DEMO演示

但是,這個方法可能存在一個問題:對於一個複雜系統來說,索引的數量可能是龐大的,那麼我們如何來鑑定那些索引是值得懷疑的,應該被監控的呢?換句話說,我們如何減少監控範圍呢?這裡介紹幾個方法。

 1、利用library cache資料

在library cache中,儲存了系統中游標的查詢計劃(並非全部,受library cache大小的限制),通過檢視v$sql_plan,我們可以查詢到這些資料。利用這些資料,我們可以排除那些出現在查詢計劃中的索引:

library cache資料

2、利用statspack表

Statspack建立以後,為了記錄快照的統計資料,會建立一系列的以stats$開頭的表。其中stats$sql_plan表記錄了每個快照中超過其閾值的語句的查詢計劃。因此我們可以將出現在該表中索引物件排除在監控範圍之外:

statspack表

但是,這張表在預設情況下(snapshot level=5)是不會記錄資料的,只有snapshot>=6才會有記錄。另外,該表在8i中是沒有的。

 3、利用AWR資料

10g以後,oracle出現了比statspack更加強大的效能分析工具AWR,它也同樣記錄了系統中的統計資料以供分析。我們也同樣可以從其中分析出那些索引是被使用到的。

AWR資料

利用上述方法,過濾掉大部分肯定被使用的index後,再綜合應用,選擇可疑索引進行監控,找出並刪除無用索引,為資料庫減肥。

文章來源:Oracle