Oracle 性能優(yōu)化簡介-中行_第1頁
Oracle 性能優(yōu)化簡介-中行_第2頁
Oracle 性能優(yōu)化簡介-中行_第3頁
Oracle 性能優(yōu)化簡介-中行_第4頁
Oracle 性能優(yōu)化簡介-中行_第5頁
已閱讀5頁,還剩169頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

Oracle應(yīng)用系統(tǒng)優(yōu)化向-mail:xiang-xj@139.com目錄性能優(yōu)化誤區(qū)性能優(yōu)化概述線性可擴充性硬件規(guī)劃與軟件規(guī)劃系統(tǒng)架構(gòu)規(guī)劃與設(shè)計應(yīng)用設(shè)計原則性能檢測與優(yōu)化常用優(yōu)化技術(shù)的分析性能優(yōu)化實踐內(nèi)存管理及調(diào)整性能優(yōu)化實踐常用的優(yōu)化檢測腳本數(shù)據(jù)庫性能檢測指南數(shù)據(jù)庫索引的維護性能優(yōu)化的擴展如何收集性能問題優(yōu)化案例簡介Oracle應(yīng)用優(yōu)化誤區(qū)不重視應(yīng)用設(shè)計期的前期規(guī)劃簡單增加/升級計算機硬件只強調(diào)數(shù)據(jù)庫參數(shù)優(yōu)化技術(shù)沒有考慮負載平衡數(shù)據(jù)庫以外的優(yōu)化占優(yōu)化工作60%以上沒有利用數(shù)據(jù)庫已有的資源只注意優(yōu)化數(shù)據(jù)庫本身性能優(yōu)化概述性能問題常常由于對系統(tǒng)資源競爭,使得某些資源被耗盡所產(chǎn)生新的性能調(diào)優(yōu)方法論是基于仔細地規(guī)劃和設(shè)計數(shù)據(jù)庫系統(tǒng),避免系統(tǒng)資源被耗盡而引起系統(tǒng)崩潰。通過消除系統(tǒng)資源競爭,系統(tǒng)可以通過擴展來滿足業(yè)務(wù)發(fā)展的需要。性能優(yōu)化,不是一個一蹴而就的工作,也不是一個一勞永逸的工作,需要定期維護,定期觀察,在發(fā)現(xiàn)性能瓶頸時及時進行調(diào)整。所以在優(yōu)化前,我們需要確定一個優(yōu)化目標,我們的目標是滿足我們的應(yīng)用性能要求就可以了。Oracle優(yōu)化,涉及的范圍太廣泛,包含的有主機性能,內(nèi)存使用性能,網(wǎng)絡(luò)傳輸性能,SQL語句執(zhí)行性能等應(yīng)用實施初期,應(yīng)用使用的用戶數(shù)不多,進入系統(tǒng)的數(shù)據(jù)量也不太大。因此往往會掩蓋性能問題性能優(yōu)化概述Oracle優(yōu)化內(nèi)存等參數(shù)配置的優(yōu)化。內(nèi)存優(yōu)化,是性能受益最快的地方。減少物理讀寫的優(yōu)化。內(nèi)存邏輯I/O操作的時間,遠遠小于物理I/O的操作時間。減少物理讀寫的優(yōu)化,一般所用的方法有:增加內(nèi)存databuffer的大小,盡可能讓數(shù)據(jù)庫操作的數(shù)據(jù)都能在內(nèi)存里找到,不需要進行物理讀寫操作。通過使用索引,避免不必要的全表掃描。大表物理分區(qū),Oracle具有很好的分區(qū)識別功能,減少數(shù)據(jù)掃描范圍。其他的一些減少物理讀寫的優(yōu)化方法,比如使用materializedview,Cluster等方法;還有一些分散I/O的方法,比如Oracle日志文件不與數(shù)據(jù)文件放在一個物理硬盤,數(shù)據(jù)熱點文件物理I/O分開等等方法批量重復(fù)操作的SQL語句及大表操作的優(yōu)化。減少SQL執(zhí)行次數(shù),減少大表操作次數(shù)。性能優(yōu)化概述-可擴充性系統(tǒng)可擴展性是當(dāng)增加新的系統(tǒng)資源時能夠處理更多的業(yè)務(wù)負荷的能力,性能的提高為線形。影響線形可擴充性的因素:當(dāng)用戶數(shù)增加時需要更多的并發(fā)管理等待資源的鎖的增加保證數(shù)據(jù)一致性帶來的負荷操作系統(tǒng)負荷增加數(shù)據(jù)容量增加時交易處理需要訪問更多的數(shù)據(jù)沒有很好設(shè)計的SQL語句和索引會產(chǎn)生大量的邏輯I/O數(shù)據(jù)庫對象維護需要更多的時間,從而減少了系統(tǒng)可用性性能優(yōu)化概述-可擴充性一個應(yīng)用不可擴展時是當(dāng)系統(tǒng)的一個資源被耗盡以至當(dāng)負載增加時不能提供更多的處理能力的那一個點。硬件資源耗盡掃描高容量數(shù)據(jù)表的處理引起磁盤I/O短缺過度的網(wǎng)絡(luò)請求導(dǎo)致網(wǎng)絡(luò)瓶頸內(nèi)存分配引起頁對換過多的進程和線索分配引起操作系統(tǒng)失效性能優(yōu)化概述-線性可擴充性影響線形化可擴充性的因素低劣的應(yīng)用設(shè)計\開發(fā)\系統(tǒng)配置硬件配置不合理軟件組件的限制硬件組件的限制性能優(yōu)化概述-線性可擴充性影響線形化可擴充性的因素低劣的應(yīng)用設(shè)計\開發(fā)\系統(tǒng)配置應(yīng)用本身是影響線性可擴充性的最大因素:低劣的方案設(shè)計造成了nPoorschemadesigncancauseexpensiveSQLthatdoesnotscale.低劣的事務(wù)處理設(shè)計產(chǎn)生了鎖和串行化問題低劣的連接管理–

響應(yīng)速度低/系統(tǒng)不可靠應(yīng)用實施也會成為一個薄弱環(huán)節(jié):nSystemscanmovetoproductionenvironmentswithbadI/Ostrategies.生產(chǎn)環(huán)境使用與測試環(huán)境產(chǎn)生的不同的執(zhí)行計劃給內(nèi)存密集型應(yīng)用分配大量的內(nèi)存卻沒有考慮在運行時釋放內(nèi)存分配不合理以及內(nèi)存不足會產(chǎn)生頁面的對換影響性能和系統(tǒng)可用性硬件配置不合理軟件組件的限制硬件組件的限制性能優(yōu)化概述-線性可擴充性影響線形化可擴充性的因素低劣的應(yīng)用設(shè)計\開發(fā)\配置硬件配置不合理逐漸降低的硬件價格可以彌補硬件能力規(guī)劃的不足過多的硬件配置往往會掩蓋系統(tǒng)可擴充性的問題(本可以花較少的錢)軟件組件的限制硬件組件的限制性能優(yōu)化概述-線性可擴充性影響線形化可擴充性的因素低劣的應(yīng)用設(shè)計\開發(fā)\配置硬件配置不合理軟件組件的限制所有的軟件組件都有可擴充性和資源使用的限制(包括:應(yīng)用服務(wù)器,數(shù)據(jù)庫服務(wù)器和操作系統(tǒng))應(yīng)用設(shè)計者不能指望軟件能夠超過它的處理能力硬件組件的限制性能優(yōu)化概述-線性可擴充性影響線形化可擴充性的因素低劣的應(yīng)用設(shè)計\開發(fā)\系統(tǒng)配置硬件配置不合理軟件組件的限制硬件組件的限制硬件不完全具有可伸縮性的例如:在一定數(shù)量之內(nèi),多CPU系統(tǒng)的性能可以線性提升(<=32),但超過以后性能的提升就是非線性的。甚至?xí)霈F(xiàn)增加CPU會降低性能。這主要是由于系統(tǒng)管理,資源競爭,同步等因素造成的。這種現(xiàn)象與系統(tǒng)負載和操作系統(tǒng)設(shè)置關(guān)系很大。性能優(yōu)化概述-互連網(wǎng)環(huán)境下的可擴充性問題在Internet下運行的應(yīng)用其性能問題和可用性問題更加復(fù)雜,Internet環(huán)境下的應(yīng)用系統(tǒng)特點:需要24X7X365天并發(fā)用戶數(shù)不可預(yù)測和不確定系統(tǒng)容量規(guī)劃方面困難允許任何類型的查詢多層架構(gòu)無狀態(tài)的中間件快速擴充沒有大量的時間測試性能優(yōu)化概述-系統(tǒng)架構(gòu)系統(tǒng)架構(gòu)由兩部分組成:硬件與軟件組件配置適合的系統(tǒng)架構(gòu)以滿足應(yīng)用的要求性能優(yōu)化概述-硬件規(guī)劃硬件資源包括:CPU內(nèi)存I/O子系統(tǒng)網(wǎng)絡(luò)資源目標:規(guī)劃多層環(huán)境下每一層的處理能力平衡的設(shè)計盡可能讓所有的組件同時達到它們的設(shè)計極限優(yōu)化的考慮:通過增加硬件的方法來獲得的性能提高只能是對當(dāng)前性能問題的短期補救措施,如果應(yīng)用的負荷繼續(xù)增加,我們將在不久的將來還要面對同樣的性能問題.一個沒有很好地設(shè)計的系統(tǒng),不論增加多少硬件資源都不能提高其性能.在購買新的硬件前,要確認應(yīng)用中沒有存在串行化問題或單線索問題性能優(yōu)化概述-軟件規(guī)劃大多數(shù)應(yīng)用軟件包括下列組件:管理用戶界面的組件處理業(yè)務(wù)邏輯的組件(執(zhí)行應(yīng)用的核心功能)管理用戶請求和資源分配的組件管理數(shù)據(jù)和事務(wù)處理的組件性能優(yōu)化概述-軟件規(guī)劃大多數(shù)應(yīng)用軟件包括下列組件:管理用戶界面的組件繪制顯示屏幕收集并傳遞用戶數(shù)據(jù)到業(yè)務(wù)邏輯組件校驗數(shù)據(jù)錄入有效性在不同的應(yīng)用級別和狀態(tài)之間導(dǎo)航用戶處理業(yè)務(wù)邏輯的組件(執(zhí)行應(yīng)用的核心功能)管理用戶請求和資源分配的組件管理數(shù)據(jù)和事務(wù)處理的組件性能優(yōu)化概述-軟件規(guī)劃大多數(shù)應(yīng)用軟件包括下列組件:管理用戶界面的組件處理業(yè)務(wù)邏輯的組件(執(zhí)行應(yīng)用的核心功能)轉(zhuǎn)化數(shù)據(jù)模型到一個關(guān)系數(shù)據(jù)表結(jié)構(gòu)定義關(guān)系表結(jié)構(gòu)的約束條件編寫過程邏輯代碼執(zhí)行業(yè)務(wù)規(guī)則管理用戶請求和資源分配的組件管理數(shù)據(jù)和事務(wù)處理的組件性能優(yōu)化概述-軟件規(guī)劃大多數(shù)應(yīng)用軟件包括下列組件:管理用戶界面的組件處理業(yè)務(wù)邏輯的組件(執(zhí)行應(yīng)用的核心功能)管理用戶請求和資源分配的組件負責(zé)數(shù)據(jù)庫連接管理高效地執(zhí)行SQL(通過使用cursors和共享SQL技術(shù))管理客戶端狀態(tài)信息在硬件資源中平衡客戶請求的負載設(shè)置硬件、軟件組件的操作對象不斷建立異步執(zhí)行任務(wù)隊列管理數(shù)據(jù)和事務(wù)處理的組件性能優(yōu)化概述-軟件規(guī)劃大多數(shù)應(yīng)用軟件包括下列組件:管理用戶界面的組件處理業(yè)務(wù)邏輯的組件(執(zhí)行應(yīng)用的核心功能)管理用戶請求和資源分配的組件管理數(shù)據(jù)和事務(wù)處理的組件使用鎖機制和事務(wù)處理規(guī)則提供并發(fā)訪問數(shù)據(jù)的能力使用索引和內(nèi)存緩存技術(shù)提供優(yōu)化的數(shù)據(jù)訪問能力保證數(shù)據(jù)的修改被記錄以防硬件失效對數(shù)據(jù)執(zhí)行已定義的任何規(guī)則如何合理配置系統(tǒng)架構(gòu)配置初始化系統(tǒng)架構(gòu)在很大程度上是個反復(fù)的過程架構(gòu)設(shè)計師必須保證在受到預(yù)算和時間計劃的限制的情況下滿足系統(tǒng)的需求如果系統(tǒng)是需要用戶不斷地與系統(tǒng)進行交互來完成交易處理并根據(jù)數(shù)據(jù)庫內(nèi)容進行決策,那么架構(gòu)是由用戶需求驅(qū)動的(OLTP)如果系統(tǒng)上只有少數(shù)交互用戶,那么系統(tǒng)架構(gòu)是由流程驅(qū)動的(OLAP/DSS)注意:產(chǎn)生一個系統(tǒng)架構(gòu)不是一個確定的過程,它需要仔細考慮業(yè)務(wù)需求,技術(shù)路線的選擇,已有的系統(tǒng)和架構(gòu)以及實際可以使用的物理資源,例如:預(yù)算和人力資源等。性能優(yōu)化概述-常用的應(yīng)用系統(tǒng)交互式應(yīng)用系統(tǒng)帳務(wù)管理系統(tǒng)定單錄入系統(tǒng)郵件服務(wù)器Web-based的零售系統(tǒng)交易系統(tǒng)面向流程的應(yīng)用系統(tǒng)公用事業(yè)帳單系統(tǒng)欺詐偵測系統(tǒng)直遞郵件系統(tǒng)性能優(yōu)化概述-配置系統(tǒng)架構(gòu)-問題一系統(tǒng)支持多少用戶?在負載很輕的系統(tǒng)或?qū)S脵C上只有很少的用戶效率/短的響應(yīng)時間/很少的管理/很少的用戶間交互/無資源沖突在企業(yè)內(nèi)有中等規(guī)模到大量的用戶用戶數(shù)受限/業(yè)務(wù)明確/可靠的系統(tǒng)服務(wù)/響應(yīng)速度/減少資源沖突/提供擴展空間在互聯(lián)網(wǎng)上的無數(shù)用戶群系統(tǒng)組件不超出設(shè)計極限/負載平衡/無狀態(tài)應(yīng)用服務(wù)器(webservices)/高效數(shù)據(jù)庫連接管理/統(tǒng)計/監(jiān)控性能優(yōu)化概述-配置系統(tǒng)架構(gòu)-問題二用戶與系統(tǒng)的交互方法是什么?客戶/服務(wù)器模式(Client/Server)主機/終端模式(Host)Web/Server性能優(yōu)化概述-配置系統(tǒng)架構(gòu)-問題三用戶的分布如何?網(wǎng)絡(luò)布局(LAN/WAN/Internet)網(wǎng)絡(luò)延時使用高峰期批任務(wù)的執(zhí)行系統(tǒng)維護的工作性能優(yōu)化概述-配置系統(tǒng)架構(gòu)-問題四網(wǎng)絡(luò)速度如何?高交互式界面的實現(xiàn)大量數(shù)據(jù)的下載,本地處理用戶訪問的數(shù)據(jù)量有多少,有多少數(shù)據(jù)是只讀的?數(shù)據(jù)表設(shè)計索引的設(shè)計本地數(shù)據(jù)緩沖實現(xiàn)數(shù)據(jù)復(fù)制實現(xiàn)用戶響應(yīng)時間的要求是什么?數(shù)據(jù)查詢報表生成數(shù)據(jù)錄入性能優(yōu)化概述-配置系統(tǒng)架構(gòu)-問題五…是否需要24小時服務(wù)?Internet跨國/地區(qū)企業(yè)是否所有的內(nèi)容都需要實時改變?批命令/隊列數(shù)據(jù)庫規(guī)模多大?業(yè)務(wù)交易的處理能力是多少?系統(tǒng)可用性的要求是什么?已有的經(jīng)驗和能力能否滿足組建和管理該應(yīng)用系統(tǒng)的要求?如果受預(yù)算的限制可以放棄哪些內(nèi)容?…應(yīng)用設(shè)計原則應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之一應(yīng)用設(shè)計簡單化(越簡單越好)如果數(shù)據(jù)表的設(shè)計復(fù)雜得沒有人看得懂,那么該設(shè)計可能有問題如果SQL語句非常長而且復(fù)雜難懂以至于任何優(yōu)化器不能夠?qū)崟r有效地對它優(yōu)化,那么可能存在一個低質(zhì)量的語句或處理或數(shù)據(jù)表設(shè)計.如果一個表上存在針對同一個字段的多個索引,那么索引設(shè)計有問題.如果在線用戶提交的查詢效率很低,那么可能界面設(shè)計或業(yè)務(wù)處理設(shè)計有問題.數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之二應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模關(guān)系型應(yīng)用系統(tǒng)成功的關(guān)鍵數(shù)據(jù)模型盡可能表達業(yè)務(wù)處理活動關(guān)注影響最常用的業(yè)務(wù)處理(核心業(yè)務(wù))的實體使用合適的建模工具數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之三應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計靈活性與核心業(yè)務(wù)處理效率之間的平衡關(guān)注關(guān)鍵業(yè)務(wù)相關(guān)數(shù)據(jù)表的設(shè)計,保證處理速度索引的設(shè)計可能產(chǎn)生的不斷調(diào)整的過程給索引增加所有必要的列/使用索引組織表((IOT)使用不同的索引類型(B-TreeIndexes,BitmapIndexes,Function-basedIndexes,PartitionedIndexes,ReverseKeyIndexes)使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之四應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖簡化應(yīng)用設(shè)計/安全性/數(shù)據(jù)表隔離查詢優(yōu)化問題SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之五應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率好的數(shù)據(jù)庫連接管理合理地使用和管理指針技術(shù)HardParsingSoftParsing應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之六應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇選擇適合軟件組件的開發(fā)環(huán)境用戶界面(HTML/WindowsPRGs)–

響應(yīng)時間/減少網(wǎng)絡(luò)傳輸量(Java)業(yè)務(wù)邏輯(解釋型語言Java,Plsql,編譯型語言;程序所處位置)用戶請求和資源分配(考慮工具的數(shù)據(jù)庫連接管理和指針管理模式)數(shù)據(jù)管理和事務(wù)處理開發(fā)一個軟件模塊時,只考慮該模塊自身的功能不留功能缺陷過程化模塊-C,PL/SQL,Java;數(shù)據(jù)存取模塊-SQL經(jīng)常訪問的,很少修改的數(shù)據(jù)最好放入高速緩存或存到本地優(yōu)化組件間的接口,使得所有組件以最可擴充的配置運行使用外鍵引用(利用Oracle的內(nèi)部機制保證引用完整性)應(yīng)用開發(fā)趨勢應(yīng)用設(shè)計原則之七應(yīng)用設(shè)計簡單化(越簡單越好)數(shù)據(jù)建模數(shù)據(jù)表與索引的設(shè)計使用視圖SQL的執(zhí)行效率應(yīng)用開發(fā)工具/語言的選擇應(yīng)用開發(fā)趨勢Java替代C,C++Java優(yōu)點–

代碼可移植性,對程序員的實用性Java缺點–

執(zhí)行效率低,占用更多的資源面向?qū)ο蟮慕TO(shè)計訪問方法封裝,繼承性數(shù)據(jù)庫訪問效率低Java端數(shù)據(jù)處理,頻繁訪問數(shù)據(jù)庫使用面向?qū)ο髷?shù)據(jù)庫(Oracle8i以上)的設(shè)計方法優(yōu)化概述-負載評估,建模,開發(fā)評估數(shù)據(jù)增長當(dāng)系統(tǒng)開始使用后,數(shù)據(jù)庫的增長變得難以預(yù)測索引的增長更加難以預(yù)測隨著數(shù)據(jù)的不斷增加和刪除,數(shù)據(jù)碎片和浪費的空間也增加利用索引重建技術(shù)監(jiān)控和尋找增長過快的數(shù)據(jù)表是保證系統(tǒng)高效和高可用性的關(guān)鍵之一評估負荷從類似的系統(tǒng)中推斷使用基準評估程序(Benchmarking)應(yīng)用建模優(yōu)化概述-負載評估,建模,開發(fā)對設(shè)計進行測試,調(diào)試,驗證測試過程主要包括功能測試和穩(wěn)定性測試,有時也要進行性能測試。測試規(guī)則包括:使用真實的數(shù)據(jù)量和數(shù)據(jù)分布進行測試使用正確的優(yōu)化模式(推薦采用基于成本的優(yōu)化模式)測試單用戶性能獲得并記錄所有的SQL語句執(zhí)行計劃(找到負荷大的事務(wù)處理)盡可能進行多用戶測試(確保沒有鎖的沖突和串行化問題)使用正確的硬件配置進行測試評估穩(wěn)定狀態(tài)下的性能優(yōu)化概述-發(fā)布新應(yīng)用首次展示策略大爆炸式方式–

所以用戶立刻移植到新系統(tǒng)中優(yōu)點:最小的數(shù)據(jù)轉(zhuǎn)換和需要與舊系統(tǒng)的數(shù)據(jù)同步工作缺點:需要在必要規(guī)模上完成全面的測試逐步進展方式–

用戶慢慢地從舊系統(tǒng)移植到新系統(tǒng)優(yōu)點:可以實現(xiàn)跟蹤系統(tǒng)負載逐漸增加的狀況缺點:數(shù)據(jù)需要在新、舊系統(tǒng)之間來回遷移優(yōu)化概述-發(fā)布新應(yīng)用性能檢查清單下列初始化參數(shù)MAXINSTANCES,MAXDATAFILES,MAXLOGFILES,MAXLOGMEMBERS,MAXLOGHISTORY在生產(chǎn)環(huán)境應(yīng)該比測試環(huán)境設(shè)得大一些設(shè)置與開發(fā)環(huán)境同樣的數(shù)據(jù)塊大小,優(yōu)化模式盡可能使用缺省的初始化參數(shù),只改變影響SGA區(qū)緩沖區(qū)大小的參數(shù)給數(shù)據(jù)庫對象設(shè)置存儲選項來管理塊競爭所有的SQL語句要確認是優(yōu)化的并且它的資源使用是明確的確認連接數(shù)據(jù)庫的中間件和程序在連接管理上效率高并且不重復(fù)執(zhí)行l(wèi)ogon、logoff確認所有的SQL語句有效地使用Cursors確認所有的方案對象都正確地移植到生產(chǎn)環(huán)境只要系統(tǒng)一發(fā)布,建立數(shù)據(jù)庫和操作系統(tǒng)的統(tǒng)計起點預(yù)測第一個瓶頸,并完成對它的優(yōu)化優(yōu)化概述-監(jiān)測和優(yōu)化重要的統(tǒng)計數(shù)據(jù)操作系統(tǒng)統(tǒng)計數(shù)據(jù)CPU使用統(tǒng)計虛擬內(nèi)存使用統(tǒng)計磁盤操作統(tǒng)計最重要的磁盤統(tǒng)計是當(dāng)前的響應(yīng)時間和磁盤隊列長度響應(yīng)時間應(yīng)該<20ms,否則就意味磁盤負載過重,成為瓶頸隊列<=2網(wǎng)絡(luò)流量及狀態(tài)統(tǒng)計網(wǎng)絡(luò)延時可能是響應(yīng)時間過大的重要原因優(yōu)化概述-監(jiān)測和優(yōu)化重要的統(tǒng)計數(shù)據(jù)數(shù)據(jù)庫統(tǒng)計數(shù)據(jù)庫統(tǒng)計提供了數(shù)據(jù)庫負載類型,以及由數(shù)據(jù)庫使用的內(nèi)部及外部資源等信息。當(dāng)數(shù)據(jù)庫資源耗盡時,很可能就成為應(yīng)用的瓶頸。TIMED_STATISTICS=TRUE緩沖區(qū)使用統(tǒng)計 大多數(shù)統(tǒng)計信息可以從虛表V$SYSSTAT中獲得共享池使用統(tǒng)計共享池包含有用戶會話,所有數(shù)據(jù)庫使用者共享的數(shù)據(jù)結(jié)構(gòu),以及數(shù)據(jù)字典緩沖等信息統(tǒng)計信息中除了有SQL本身,還有SQL執(zhí)行的次數(shù)和所占用的CPU,磁盤I/O等統(tǒng)計信息可以從虛表V$SQL中獲得當(dāng)分析師不了解,或沒有應(yīng)用源代碼時,分析共享池最有效,幫助找到有瓶頸的數(shù)據(jù)庫對象優(yōu)化概述-監(jiān)測和優(yōu)化重要的統(tǒng)計數(shù)據(jù)數(shù)據(jù)庫統(tǒng)計等待事件統(tǒng)計進程要共享某個資源或與其它進程同步進程將控制交給外部程序用戶進程等待,該等待作為響應(yīng)時間的一部分如果多個進程同時爭一個資源,數(shù)據(jù)庫變成單線索,可伸縮性受影響從虛表V$SYSTEM_EVENT,V$SESSION_EVENT,andV$SESSION_WAIT可以查詢到等待事件的歷史以及當(dāng)前等待的事件優(yōu)化概述-監(jiān)測和優(yōu)化重要的統(tǒng)計數(shù)據(jù)應(yīng)用系統(tǒng)統(tǒng)計應(yīng)提供每天的事務(wù)處理量都有哪些事務(wù)處理,每個事務(wù)處理所花時間(響應(yīng)時間)等優(yōu)化概述-監(jiān)測和優(yōu)化統(tǒng)計數(shù)據(jù)收集工具操作系統(tǒng)數(shù)據(jù)收集工具UNIXCPUsar,vmstat,mpstat,iostatMemorysar,vmstatDisksar,iostatNetworknetstatWindows

使用性能監(jiān)控工具數(shù)據(jù)庫數(shù)據(jù)收集工具StatspackOracleEnterpriseManager(EM)BSTAT/ESTATscripts優(yōu)化概述-監(jiān)測和優(yōu)化歷史數(shù)據(jù)和起始監(jiān)測時間的重要性告訴系統(tǒng)發(fā)生什么引起性能問題性能直覺把統(tǒng)計結(jié)果與應(yīng)用中的業(yè)務(wù)處理進行關(guān)聯(lián),找到不正常的處理,以及發(fā)生變化的原因優(yōu)化概述-監(jiān)測和優(yōu)化Oracle性能優(yōu)化方法性能優(yōu)化方法簡介性能問題一般是由于系統(tǒng)處理能力不足,用戶、任務(wù)響應(yīng)時間不可接受等問題所造成的。首先要從最終用戶(尤其是為系統(tǒng)付賬的人)那里得到對性能問題的描述:上線性能太低,以至于我們不能做其它事情;開發(fā)票處理太慢響應(yīng)速度太慢,我丟失客戶了現(xiàn)在每天交易量5000,系統(tǒng)已經(jīng)在強撐。下個月要將所有用戶加進來,估計交易量達到四倍。。。從反饋回來的信息中,找到影響性能的最關(guān)鍵的因素確定優(yōu)化目標帳單系統(tǒng)必須在3小時的窗口時間內(nèi)處理100,000個帳戶網(wǎng)站的高峰期,網(wǎng)頁刷新速度不能超過5秒通過優(yōu)化手段消除性能瓶頸-遞歸的過程直至用戶接受優(yōu)化后的性能優(yōu)化概述-監(jiān)測和優(yōu)化Oracle性能優(yōu)化方法優(yōu)化步驟獲得最終用戶反饋。確定性能優(yōu)化范圍和子目標,以及今后的優(yōu)化目標。該過程是今后制定能力計劃的關(guān)鍵獲得完整的操作系統(tǒng),數(shù)據(jù)庫,應(yīng)用本身的統(tǒng)計數(shù)據(jù)(包括性能好的時期和變壞的時期)對影響性能的所有機器進行操作系統(tǒng)完整性檢查,找到負載過大的硬件和操作系統(tǒng)資源。另外,檢查所有硬件是否有診斷錯誤。檢查前10個最常出現(xiàn)的Oracle錯誤,確定是否就是可能的問題所在。建立概念模型表示系統(tǒng)正在發(fā)生的現(xiàn)象,用癥狀提示幫助理解什么引起性能問題。提出一系列補救措施和預(yù)計產(chǎn)生的效果,順序執(zhí)行這些措施。性能優(yōu)化的黃金規(guī)則是:一次進行一項改變?nèi)缓髾z查其效果。如果同時進行多項改變,要保證它們之間沒有互相影響。檢查這些改變是否達到了預(yù)期的效果,看用戶是否能夠接受性能優(yōu)化的結(jié)果。否則,檢查其它瓶頸,并繼續(xù)改進所建立的概念模型直到更準確地理解應(yīng)用系統(tǒng)。重復(fù)步驟5,6,7直到到達性能優(yōu)化目標,或由于其它限制不可能繼續(xù)優(yōu)化了。優(yōu)化概述-監(jiān)測和優(yōu)化如何檢查操作系統(tǒng)檢查整個系統(tǒng)和每個CPU在用戶區(qū)和內(nèi)核區(qū)的使用情況確定沒有發(fā)生頁面對換情況檢查機器間的網(wǎng)絡(luò)延遲是否在可接受的范圍內(nèi)找到響應(yīng)速度慢或隊列長的磁盤子系統(tǒng)確定沒有硬件錯誤優(yōu)化概述-監(jiān)測和優(yōu)化判斷性能問題方法在單用戶或負載低情況下,響應(yīng)速度或批處理運行時間是否可以接受?如果不滿足要求,那么應(yīng)用開發(fā)本身有問題看應(yīng)用內(nèi)部統(tǒng)計資料,SQLTrace,SQL計劃與開發(fā)者一道看索引,事務(wù)處理SQL設(shè)計,以及可能存在的批命令、后臺處理是否存在優(yōu)化問題是否利用了所有的CPU資源?如果內(nèi)核使用率>40%,檢查操作系統(tǒng)在網(wǎng)絡(luò)傳輸,頁面調(diào)度,頁面對換或進程失效的情況否則看用戶區(qū)的使用情況,看是否有非數(shù)據(jù)庫任務(wù)的其它進程消耗CPU資源。例如:備份,文件傳輸,打印隊列等。確定Oracle使用了大部分CPU資源后,檢查占用CPU資源最大的SQL。如果應(yīng)用是優(yōu)化的并且沒有低效率的SQL,考慮將定期執(zhí)行的作業(yè)移到非高峰期運行,或升級到更大一些的機器。系統(tǒng)性能不滿意,但CPU資源沒有充分利用在該服務(wù)器上存在串行化問題查看WAIT_EVENTS統(tǒng)計,確定最大的串行化點如果沒有串行化點,問題可能是數(shù)據(jù)庫外消除WAIT_EVENTS包括調(diào)整SQL和初始化參數(shù)優(yōu)化概述-監(jiān)測和優(yōu)化在Oracle系統(tǒng)中最常犯的10個錯誤低劣的連接管理(兩個數(shù)量級)沒有很好地使用Cursors和共享池(一個數(shù)量級)發(fā)生數(shù)據(jù)庫DatabaseI/O錯誤數(shù)據(jù)庫只按容量分配,沒有按帶寬分配重置日志設(shè)置問題太小的重置日志引起系統(tǒng)檢查點(Checkpoint)不斷給日志緩沖區(qū)和I/O系統(tǒng)帶來很高的壓力日志文件太少,歸檔無法跟上步伐。數(shù)據(jù)庫出現(xiàn)等待現(xiàn)象由于缺少freelists,freelistgroups,transactionslots(INITRANS),或缺少回滾段,在緩沖區(qū)產(chǎn)生串行化數(shù)據(jù)塊在Insert操作頻繁,將塊大小升到8k或16k,或活動用戶數(shù)非常多并且回滾段很少的應(yīng)用中常常發(fā)生優(yōu)化概述-監(jiān)測和優(yōu)化在Oracle系統(tǒng)中最常犯的10個錯誤6.

很長的全表掃描在線交互系統(tǒng)或數(shù)據(jù)量非常大的系統(tǒng)中存在大量的全表掃描操作表明事務(wù)處理設(shè)計有問題,或缺少索引,低劣的SQL優(yōu)化。屬于I/O密集操作,而且不可伸縮7.

在硬盤排序(同上)8.

大量的遞歸(SYS級)SQL空間管理活動發(fā)生,例如:分配擴展數(shù)據(jù)空間9.Schema錯誤或優(yōu)化問題向生產(chǎn)環(huán)境移植時丟失索引等10.

使用非標準初始化參數(shù)優(yōu)化概述-監(jiān)測和優(yōu)化硬件配置的性能特性 硬盤特性:大小512MB-36GB(SCSI)尋址速度5-10msec傳輸速度5-10msec吞吐量20-40I/O秒/每個硬盤磁盤控制器吞吐速度1750I/Os/秒內(nèi)存讀取速度1-10微秒點對點的網(wǎng)絡(luò)延遲1-25msec.負荷很重的系統(tǒng):(最壞情況)操作型系統(tǒng)(OLTP)-60%usr,40%sys決策支持系統(tǒng)(DSS)-90%usr,10%sys優(yōu)化概述-監(jiān)測和優(yōu)化應(yīng)急性能優(yōu)化技術(shù)優(yōu)化步驟檢查性能問題并收集問題出現(xiàn)的征狀用戶反饋系統(tǒng)如何表現(xiàn)不佳,是處理能力問題還是響應(yīng)速度問題?提出問題:出現(xiàn)性能問題之前發(fā)生了什么?全面檢查所有硬件的使用情況確定數(shù)據(jù)庫服務(wù)器CPU處理能力問題,經(jīng)常在等待資源上如果是CPU問題,檢查:在操作系統(tǒng)級消耗大量CPU的對話在數(shù)據(jù)庫級執(zhí)行大量buffergets操作的對話或語句(檢查V$SYSSTAT,V$SQL)造成非優(yōu)化執(zhí)行SQL的執(zhí)行計劃的改變不正確設(shè)置的初始化參數(shù)導(dǎo)致代碼改變的算法問題,或被升級的軟件模塊否則檢查V$SESSION_WAIT中的等待事件列表,找到串行化點如果存在大量的對librarycache的競爭,系統(tǒng)可能就不允許新的登錄或向數(shù)據(jù)庫提交SQL。在這種情況下,使用歷史數(shù)據(jù)來確定為什么突然會對該栓(Latch)產(chǎn)生競爭.如果大多數(shù)等待是對I/O資源的等待,檢查所有執(zhí)行I/O操作的SQL語句.優(yōu)化概述-監(jiān)測和優(yōu)化應(yīng)急性能優(yōu)化技術(shù)優(yōu)化步驟執(zhí)行應(yīng)急措施來穩(wěn)定系統(tǒng)讓某些模塊離線限制負載重啟系統(tǒng)中斷某些任務(wù)確認系統(tǒng)已經(jīng)穩(wěn)定收集數(shù)據(jù)庫統(tǒng)計數(shù)據(jù)集按前面介紹的嚴格步驟完成優(yōu)化使重新上線運行Oracle的Memory管理Oracle的Instance結(jié)構(gòu)

SGA

DataBaseBufferCacheOther(Largepool,Cursors…)SharedPoolRedoLogBufferBackgroundProcessDBWRLGWRPMONCKPT…SMONOracle的Memory管理SGA(SystemGlobalArea):系統(tǒng)全局區(qū)在多人使用的環(huán)境下,SGA的數(shù)據(jù)可由系統(tǒng)中所有使用者共享,所以SGA也稱為

SharedGlobalAreaSGA的設(shè)定參數(shù)

SGA_MAX_SIZE用以設(shè)定SGA的總大小如以數(shù)據(jù)庫執(zhí)行效能考慮,此參數(shù)盡可能設(shè)大參數(shù)值盡可能不要超過實際內(nèi)存大小,否則會用到硬盤上的虛擬內(nèi)存,反而會導(dǎo)致性能下降參數(shù)值大小必須大于

SGA相關(guān)區(qū)域參數(shù)值的總和Oracle的Memory管理SGA包含下列幾個區(qū)域DataBaseBufferCache數(shù)據(jù)高速緩沖區(qū)RedoLogBuffer重做日志緩沖區(qū)SharedPool共享池其他,如LargePool及Cursors等SGA的相關(guān)參數(shù)修改在Oracle8i之前版本,修改后必須重新啟動數(shù)據(jù)庫才會生效Oracle9i提供一新技術(shù)稱動態(tài)SGA,可以動態(tài)配置內(nèi)存的大小Oracle的Memory管理databaseBufferCache數(shù)據(jù)高速緩存區(qū)用來存放讀取自數(shù)據(jù)庫的數(shù)據(jù)塊副本,或是使用者曾經(jīng)處理過的數(shù)據(jù)。其用途在于於有效降低讀取數(shù)據(jù)庫時造成磁盤讀寫動作,以提升數(shù)據(jù)存取速度數(shù)據(jù)高速緩存區(qū)包含兩種緩沖區(qū)隊列WriteList:存放dirtybuffer之副本,會在適當(dāng)時機寫入磁盤Dirtybuffer是用來存放“己修改但尚未寫入磁盤的數(shù)據(jù)”的緩沖區(qū)LRUList:包含freebuffer、dirtybuffer及pinnedbufferFreebuffer:空白(可用)的緩沖區(qū)Pinnedbuffer:已被使用中的緩沖區(qū)Oracle的Memory管理DatabaseBufferCache的工作原理當(dāng)使用者向Oracle送出查詢請求,Oracle會會先在數(shù)據(jù)高速緩沖區(qū)內(nèi)尋找該數(shù)據(jù)。如找到稱之為cachehit,直接從內(nèi)存中讀取數(shù)據(jù),否則稱之為cachemiss,Oracle才會從磁盤上的數(shù)據(jù)庫中讀出數(shù)據(jù)塊放入緩沖區(qū)后,使用者才從緩沖區(qū)讀取數(shù)據(jù)。當(dāng)磁盤上的數(shù)據(jù)塊讀出,要放入數(shù)據(jù)高速緩沖區(qū)內(nèi)時,系統(tǒng)必須確定緩沖區(qū)內(nèi)有freebuffer供存放,此時oracle便會開始掃描LRUList,如能順利找到freebuffer,Oracle就會將數(shù)據(jù)塊放入此freebuffer中,再將其移到LRUList的MRU端。LRU(LeastRecentlyUsed)端:較不常使用的MRU(MostRecentlyUsed)端:最近使用的Oracle的Memory管理LRUList的掃描原則從

LRU端掃到MRU端如發(fā)現(xiàn)dirtybuffer就將它移到WriteList當(dāng)掃到freebuffer或掃描的緩沖區(qū)數(shù)目超過臨界值,就會停止掃描動作當(dāng)LRUList真的沒有freebuffer,Oracle便會通知數(shù)據(jù)庫寫入器(DatabaseWrite,DBWR)后臺處理程序?qū)⒉糠莸膁irtybuffers先寫入磁盤,然后從LRUList的LRU端清除緩沖區(qū),以騰出freebufferOracle的Memory管理LRUList與

LRU的演算規(guī)則當(dāng)內(nèi)存的可用空間不足時,緩沖區(qū)盡可能保留使用者最常用的數(shù)據(jù),優(yōu)先清除“較不常使用的數(shù)據(jù)”,並釋放空間LRUListState0:State1:State2:………A………BA………MRU端LRU端Statem:Staten:MAE………DBCNMA………EDBOracle的Memory管理設(shè)定數(shù)據(jù)高速緩沖區(qū)大小在Oracle8i之前的版本DatabaseBufferCache的大小等于

DB_BLOCK_SIZE*DB_BLOCK_BUFFERSDB_BLOCK_SIZE:數(shù)據(jù)塊(datablock)單位大小,以Bytes計;預(yù)設(shè)為8192(8k)DB_BLOCK_BUFFERS:緩沖區(qū)數(shù)目;預(yù)設(shè)2048(個)Oracle8i的DB_BLOCK_SIZE參數(shù)值在數(shù)據(jù)庫建立后就不可再修改Oracle9i支持多重數(shù)據(jù)塊大小,除了預(yù)設(shè)的DB_BLOCK_SIZE之外,DBA可另外設(shè)定其他大小的數(shù)據(jù)塊Oracle的Memory管理RedoLogBuffer重置日志緩沖區(qū)記錄數(shù)據(jù)庫內(nèi)所有數(shù)據(jù)變動的詳細資料,稱為redoentries。系統(tǒng)會在適當(dāng)?shù)臅r候調(diào)用LGWR后臺處理進程,將redoentries內(nèi)的數(shù)據(jù)寫入磁盤內(nèi)的RedoLogFiles,以便日后執(zhí)行復(fù)原(Recovery)動作LOG_BUFFER參數(shù)可用來設(shè)定RedoLogBuffer的大小,單位為Bytes;預(yù)設(shè)為操作系統(tǒng)數(shù)據(jù)塊的四倍若重置日志緩沖區(qū)設(shè)大一點,可減少RedoLogFiles的讀寫動作,可提升系統(tǒng)性能,但亦不宜太大Oracle的Memory管理SharedPool共享區(qū)當(dāng)使用者把SQL指令發(fā)至Oracle數(shù)據(jù)庫后,系統(tǒng)會先解析語法是否正確。解析時所需的系統(tǒng)信息以及解析后的結(jié)果,就存放在SharedPool共享區(qū)內(nèi)。當(dāng)有其他使用者用到相同的SQL指令,即可共享已解析好的信息,達到提升SQL指令的執(zhí)行速度SHARED_POOL_SIZE參數(shù)可設(shè)定共享區(qū)的大小32-bit操作系統(tǒng)下;預(yù)設(shè)值為8(MB)64-bit操作系統(tǒng)下;預(yù)設(shè)值為64(MB)Oracle的Memory管理SharedPool共享區(qū)的組成;主要分兩類LibraryCache(程序庫高速緩沖區(qū)):包含SharedSQLArea(共享SQL區(qū)

)PrivateSQLArea(私有SQL區(qū)

)PL/SQLProgramArea(PL/SQL程序單元區(qū)

)解析后的結(jié)果及信息即是存放在SharedSQLArea內(nèi)DictionaryCache(數(shù)據(jù)字典緩沖區(qū)):包含Table、View、Column及DataType等使用者的相關(guān)系統(tǒng)管理權(quán)限及對象存取權(quán)限Oracle在解析SQL語句時所需的系統(tǒng)信息即是存放在此Oracle的內(nèi)存管理-數(shù)據(jù)倉庫數(shù)據(jù)倉庫shared_pool_size及shared_pool_reserved_size的配置數(shù)據(jù)加載階段由于有大量的索引要建立,因此shared_pool_reserved_size為shared_pool_size的50%正常訪問階段由于基本上是使用select語句訪問,因此shared_pool_reserved_size為shared_pool_size的10%Shared_pool_size約占Oracle可用內(nèi)存大小的30-40%Oracle的內(nèi)存管理-數(shù)據(jù)倉庫Large_Pool:主要為在并行操作執(zhí)行期間所需的消息緩沖區(qū)和備份所需的磁盤I/O緩沖區(qū)留出的一個內(nèi)存段建議開始為2000000B常用優(yōu)化技術(shù)的分析共享服務(wù)器(MTS)-多線索機制優(yōu)點:占用較少內(nèi)存資源缺點:速度較慢/串行化建議采用缺省的專用服務(wù)器模式集群技術(shù)(RAC)優(yōu)點–

橫向擴展能力、高可用性缺點–

高速緩沖競爭、過多的I/O、文件級鎖分區(qū)分割大的數(shù)據(jù)表或索引提高可用性易于管理提高性能(減少掃描數(shù)據(jù)量,并行查詢)適合于數(shù)據(jù)倉庫應(yīng)用并行處理多處理器、分區(qū)數(shù)據(jù)表設(shè)置Parallel參數(shù)適合數(shù)據(jù)倉庫應(yīng)用性能優(yōu)化實踐-索引優(yōu)化索引調(diào)優(yōu)誤區(qū):誤區(qū)1:索引創(chuàng)建得越多越好? 實際上:創(chuàng)建的索引可能建立后從來未使用。索引的創(chuàng)建也是需要代價的,對于刪除、某些更新、插入操作,對于每個索引都要進行相應(yīng)的刪除、更新、插入操作。從而導(dǎo)致刪除、某些更新、插入操作的效率變低。DML代價×3誤區(qū)2:對于一個單表的查詢,可以索引1進行過濾再使用索引2進行過濾? 實際上:假設(shè)查詢語句如下select*fromt1wherec1=1andc2=2,c1列和c2列上分別建有索引ic1、ic2。先使用ic1(或ic2)進行過濾,產(chǎn)生的結(jié)果集是臨時數(shù)據(jù),不再具有索引,所以不可使用ic2(或ic1)進行再次過濾。性能優(yōu)化實踐-索引優(yōu)化索引優(yōu)化的基本原則:將索引和數(shù)據(jù)存放到不同的文件組

沒有將表數(shù)據(jù)和索引數(shù)據(jù)存儲到不同的文件組,而不加區(qū)別地將它們存儲到同一文件組。這樣,不但會造成I/O競爭,也為數(shù)據(jù)庫的維護工作帶來不變。組合索引的使用

假設(shè)存在組合索引it1c1c2(c1,c2),查詢語句select*fromt1wherec1=1andc2=2能夠使用該索引。查詢語句select*fromt1wherec1=1也能夠使用該索引。但是,查詢語句select*fromt1wherec2=2不能夠使用該索引,因為沒有組合索引的引導(dǎo)列,即,要想使用c2列進行查找,必需出現(xiàn)c1等于某值。

性能優(yōu)化實踐-索引優(yōu)化索引優(yōu)化的基本原則:創(chuàng)建索引的規(guī)則:創(chuàng)建索引首先要考慮的是列的可選擇性。比較一下列中唯一鍵的數(shù)量和表中記錄的行數(shù),就可以判斷該列的可選擇性。如果該列的“唯一鍵的數(shù)量/表中記錄行數(shù)”的比值越接近于1,則該列的可選擇行越高。在可選擇性高的列上進行查詢,返回的數(shù)據(jù)就較少,比較適合索引查詢。相反,比如性別列上只有兩個值,可選擇行就很小,不適合索引查詢。性能優(yōu)化實踐-SGA設(shè)置參考物理內(nèi)存多大操作系統(tǒng)需要多大內(nèi)存--(200MB)數(shù)據(jù)庫使用文件系統(tǒng)還是裸設(shè)備

對于使用文件系統(tǒng),異步I/O使用操作系統(tǒng)緩存占:0.2-0.3倍物理內(nèi)存 裸設(shè)備沒有這樣的限制有多少并發(fā)用戶

關(guān)系到PGA的大小(MTS下還有l(wèi)arge_pool_size),同時還與應(yīng)用類型有關(guān)。OLTP傾向使用MTS;

OLAP使用獨立模式,同時還會有大量的排序操作的查詢,都影響內(nèi)存的使用(sort_area_size)--100個用戶-200MB性能優(yōu)化實踐-SGA設(shè)置參考是什么樣的應(yīng)用:OLTP/OLAP計算公式:

OS使用內(nèi)存+SGA+并發(fā)執(zhí)行進程數(shù)*(sort_area_size+hash_area_size+2M)<0.7*總物理內(nèi)存受32位操作系統(tǒng)尋址限制,SGA大小32位操作系統(tǒng)+32位數(shù)據(jù)庫--不能超過1.7GB64為操作系統(tǒng)+32位數(shù)據(jù)庫--不能超過3.7GB性能優(yōu)化實踐-SGA參數(shù)調(diào)整SGA內(nèi)參數(shù)設(shè)置Log_buffer--1-3MBlarge_pool_size--(非MTS)20-30MB主要用于保存并行查詢時候的一些信息java_pool_size--10-20MB(沒有使用JAVA);但如果使用則可能要更大〉300MBshared_pool_size--在一個充分使用綁定變量的比較大的系統(tǒng)中300MB,但如果系統(tǒng)使用了大量的存儲過程,函數(shù),包的系統(tǒng),可能要到500MB;性能優(yōu)化實踐-SGA參數(shù)調(diào)整data_buffer--在SGA中除了前述內(nèi)存,其它內(nèi)存都給它,為了減少從磁盤中的讀取次數(shù),應(yīng)盡可能增大該內(nèi)存。

8i--db_block_buffers*db_block_size兩個參數(shù)來決定(再加上buffer_pool_keep和buffer_pool_recycle);

9i以后--(參數(shù)設(shè)置得越來越智能化) db_cache_size/db_block_buffers, db_keep_cache_size/buffer_pool_keep, db_recycle_cache_size/buffer_pool_recycle;

參數(shù)設(shè)置為實際大小,而不是塊數(shù)量; 增加db_nk_cache_size-為了支持同一個數(shù)據(jù)庫中使用不同的塊大?。ú煌谋砜臻g可以使用不同的塊大?。﹏=2,4,6,8,16...SGA_MAX_SIZE--若設(shè)置了該參數(shù),則在總和小于等于該大小之內(nèi),可以動態(tài)調(diào)整數(shù)據(jù)緩沖區(qū)和共享池大??;性能優(yōu)化實踐-Lock_sga=true-AIXLock_sga=true

為了減少頁面對換,從而提高性能,最好能夠?qū)GA鎖定在物理內(nèi)存中.

如何實現(xiàn)AIX(AIX4.3.3以上): logonaixasroot cd/usr/samples/kernel ./vmtune看v_pingshm參數(shù)是否為1 ./vmtune-S1(否則改參數(shù)值)

改initSID.ora參數(shù)文件,增加lock_sga=true

重新啟動數(shù)據(jù)庫,即可.性能優(yōu)化實踐-Lock_sga=true–HP/UXLock_sga=true

為了減少頁面對換,從而提高性能,最好能夠?qū)GA鎖定在物理內(nèi)存中.

如何實現(xiàn)HPUNIX: logonHPasroot vi/etc/privgroup addline"dbaMLOCK" /etc/setprivgrp-f/etc/privgroup

修改initSID.ora參數(shù)文件,增加lock_sga=true

重新啟動數(shù)據(jù)庫,即可.性能優(yōu)化實踐-Lock_sga=true-SolarisLock_sga=true

為了減少頁面對換,從而提高性能,最好能夠?qū)GA鎖定在物理內(nèi)存中.

如何實現(xiàn)Solaris(Solaris2.6以上): 8i版本以上數(shù)據(jù)庫默認使用隱藏參數(shù)use_ism=true,自動鎖定SGA.如果設(shè)置lock_sga=true,當(dāng)用非root用戶啟動數(shù)據(jù)庫時將報錯.性能優(yōu)化實踐-Lock_sga=true-WindowsLock_sga=true

為了減少頁面對換,從而提高性能,最好能夠?qū)GA鎖定在物理內(nèi)存中.

如何實現(xiàn)Windows:

不能設(shè)定lock_sga=true鎖定SGA.可以通過設(shè)置pre_page_sga=true使得數(shù)據(jù)庫啟動時就把所有內(nèi)存頁面裝載.性能優(yōu)化實踐-內(nèi)存參數(shù)的調(diào)整如果出現(xiàn)性能問題,首先判斷是否為內(nèi)存分配方面的問題,可以由以下三個方面來判斷:

數(shù)據(jù)緩沖區(qū)命中率:

SQL>selectvaluefromv$sysstatwherename='physicalreads'; SQL>selectvaluefromv$sysstatwherename='physicalreadsdirect'; SQL>selectvaluefromv#sysstatwherename='physicalreadsdirect(lob)'; SQL>selectvaluefromv$sysstatwherename='consistentgets'; SQL>selectvaluefromv$sysstatwhereneme='dbblockgets';

命中率(R)計算: R=100-(physicalreads-X)/(consistentgets+dbblockgets-X)*100

其中: X=physicalreadsdirect+physicalreadsdirect(lob)

如果命中率<90%,可以考慮加大數(shù)據(jù)緩沖區(qū)大小性能優(yōu)化實踐-內(nèi)存參數(shù)的調(diào)整

共享池命中率:

SQL>selectsum(pinhits)/sum(pins)*100"hitradio"fromv$librarycache;

如果命中率低于95%,就可能要考慮調(diào)整應(yīng)用(例如:使用bindvariable)或增加內(nèi)存

性能優(yōu)化實踐-內(nèi)存參數(shù)的調(diào)整排序問題的優(yōu)化:

SQL>selectname,valuefromv$sysstatwherenamelike'%sort%'; NAME VALUE

sorts(memory) 67935 sorts(disk) 1 sorts(rows) 7070

如果發(fā)現(xiàn)sorts(disk)/(sorts(memory)+sorts(disk))的比例過高,則意味參數(shù)sort_area_size過小.需要進行排序的操作:創(chuàng)建索引;涉及到索引維護的并行插入orderby或者groupby(盡可能對索引字段排序)Distinctunion/intersect/minus

sort-mergejoinanalyze命令

性能優(yōu)化實踐-內(nèi)存參數(shù)的調(diào)整Log_buffer: SQL>selectname,valuefromv$sysstatwherenamein('redoentries','redobufferallocationretries'); NAME VALUE

redoentries 2325591 redobufferallocationretries 30

如果redobufferallocationretries/redoentries>1%,增大log_buffer性能優(yōu)化實踐-分區(qū)技術(shù)分區(qū)表:

根據(jù)實際經(jīng)驗,在一個大數(shù)據(jù)庫中,數(shù)據(jù)庫空間的絕大多數(shù)是被少量的表所占有。為了簡化大型數(shù)據(jù)庫的管理,改善應(yīng)用的查詢性能,一般可以使用分區(qū)這種手段。所謂分區(qū)就是動態(tài)地將表中的記錄分離到若干不同的表空間上,使數(shù)據(jù)在物理上被分割開來,便于維護、備份、恢復(fù)、事務(wù)及查詢性能。當(dāng)使用的時候可建立一個連接所有分區(qū)的視圖,使其在邏輯上仍以一個整體出現(xiàn)。分區(qū)索引:

當(dāng)分區(qū)中出現(xiàn)許多事務(wù)并且要保證所有分區(qū)中的數(shù)據(jù)記錄的惟一性時采用全局索引,在建立全局索引時,Global子句允許指定索引的范圍值,這個范圍值可以不同于表分區(qū)的范圍值。只有建立局部索引才會使索引分區(qū)與表分區(qū)間建立起一一對應(yīng)關(guān)系。因此,在大多數(shù)情況下,應(yīng)該使用局部索引分區(qū)。若使用了此索引,分區(qū)就能夠很容易地將索引分區(qū)與表分區(qū)建立關(guān)聯(lián),局部索引比全局索引更易于管理。分區(qū)管理:

根據(jù)實際需要,還可以使用Altertable命令來增加、刪除、交換、移動、修改、重命名、劃分、截短一個已存在分區(qū)的結(jié)構(gòu)。

性能優(yōu)化實踐-段的碎片整理當(dāng)生成一個數(shù)據(jù)庫對象時(一個表或一個索引),通過用戶缺省值或指定值來為它指定表空間。一個在表空間中生成的段,用于存儲對象的相關(guān)數(shù)據(jù)。在段被關(guān)閉、收縮、截斷之前,段所分配的空間將不被釋放。

一個段是由范圍組成,而范圍是由相鄰的Oracle塊組成。一旦存在的范圍不能再存儲新的數(shù)據(jù),這個段就會去獲得新的范圍,但并不要求這些范圍是彼此相鄰的。這樣的擴展會一直繼續(xù)下去,直到表空間中的數(shù)據(jù)文件不能提供更多的自由空間,或者范圍數(shù)量已達到極限。因此,一個碎片太多的數(shù)據(jù)段,不僅會影響運行,也會引發(fā)表空間中的空間管理問題。所以,每個數(shù)據(jù)段只含有一個范圍是十分有益的。借助監(jiān)控系統(tǒng),可以通過檢查DBA_SEGMENTS數(shù)據(jù)字典視圖來了解哪些數(shù)據(jù)庫對象含有10個或更多范圍的段,確定其數(shù)據(jù)段碎片。若一個段的碎片過多,可用兩種方法解決:(1)用正確的存儲參數(shù)建立一個新表,將舊表中的數(shù)據(jù)插入到新表中,再刪除舊表;(2)利用Export/Import工具。性能優(yōu)化實踐-自由范圍的碎片整理表空間中的一個自由范圍是表空間中相連的自由(空間)塊的集合。當(dāng)一個段關(guān)閉時,它的范圍將被釋放,并被標記為自由范圍。然而,這些自由范圍再也不能與相鄰的自由范圍合并,它們之間的界線始終存在。但是:

當(dāng)表空間的缺省值pctincrease設(shè)置不是0時,SMON后臺進程會定期將這些相鄰的自由范圍合并。若pctincrease設(shè)置為0,那么相鄰自由范圍不會被數(shù)據(jù)庫自動合并。但可以使用Altertable命令“coalesce”選項,來強迫進行相鄰自由范圍的合并。

不進行自由范圍合并,在日后的空間請求中,會影響到表空間中的空間分配。當(dāng)需要一個足夠大的范圍時,數(shù)據(jù)庫并不會合并相鄰的自由范圍,除非沒有其他選擇。這樣,當(dāng)表空間中前面較小的自由范圍已被使用時,將使用表空間中后面部分最大的一個自由范圍。結(jié)果,會因為沒有足夠多的使用空間,從而導(dǎo)致表空間需求的矛盾。由于這樣的情況出現(xiàn),使數(shù)據(jù)庫的空間分配距理想越來越遠。自由空間碎片常會出現(xiàn)在那些經(jīng)常關(guān)閉又重新生成的數(shù)據(jù)庫表和索引中。

在理想的Oracle表空間中,每一個數(shù)據(jù)庫對象存儲在一個單獨的范圍中,并且所有有效自由空間集中在一個巨大而連續(xù)的范圍中。這樣,在一個對象需要附加存儲空間時,可以在增加獲取足夠大自由空間的可能性的同時,最小化空間中的循環(huán)調(diào)用,提高自由空間使用率。性能優(yōu)化實踐-數(shù)據(jù)庫連接方案使用直接的OLEDB數(shù)據(jù)庫連接方式通過ADO可以使用兩種方式連接數(shù)據(jù)庫,一種是傳統(tǒng)的ODBC方式,一種是OLEDB方式。ADO是建立在OLEDB技術(shù)上的,為了支持ODBC,必須建立相應(yīng)的OLEDB到ODBC的調(diào)用轉(zhuǎn)換,而使用直接的OLEDB方式則不需轉(zhuǎn)換,從而提高處理速度。使用ConnectionPool機制在數(shù)據(jù)庫處理中,資源花銷最大的是建立數(shù)據(jù)庫連接,而且用戶還會有一個較長的連接等待時間。解決的辦法就是復(fù)用現(xiàn)有的Connection,也就是使用ConnectionPool對象機制。

ConnectionPool的原理是:IIS+ASP體系中維持了一個連接緩沖池,這樣,當(dāng)下一個用戶訪問時,直接在連接緩沖池中取得一個數(shù)據(jù)庫連接,而不需重新連接數(shù)據(jù)庫,因此可以大大地提高系統(tǒng)的響應(yīng)速度。性能優(yōu)化實踐-數(shù)據(jù)庫性能檢查指導(dǎo)方案建議每個月檢查一次產(chǎn)品數(shù)據(jù)庫檢查方式均為以sysdba身份登錄數(shù)據(jù)庫執(zhí)行指定的腳本該指導(dǎo)方案適用于Oracle9i數(shù)據(jù)庫性能優(yōu)化實踐-內(nèi)存性能評估內(nèi)存性能指數(shù)(MPI,MemoryPerformanceIndex),MPI指數(shù)分類所需等級最高分緩沖區(qū)命中率(BufferCache) >98%數(shù)據(jù)字典命中率(DictionaryCache) >98%庫緩存命中率(LibraryCache) >98%內(nèi)存中的排序(SortinMemory) >98%空閑的數(shù)據(jù)緩沖區(qū)比例 10-25%使用最多的前10個SQL占用的內(nèi)存 <5%是否已經(jīng)調(diào)整使用最多的前25個SQL 是是否嘗試固定高速緩存中經(jīng)常使用的對象 是10MPI指數(shù)總分 250

性能優(yōu)化實踐-內(nèi)存性能評估

緩沖區(qū)命中率

顯示了對于數(shù)據(jù)總讀取量而言,非磁盤讀?。ň彌_區(qū)命中)的百分比。當(dāng)然,十分高的命中率并不代表數(shù)據(jù)庫性能一定優(yōu)良,也有可能是糟糕的SQL引起了大量的緩沖區(qū)讀操作,只有在已經(jīng)調(diào)整過首要的查詢之后,這個命中率才能更好地反映數(shù)據(jù)庫性能。

檢查方法:select(1-(sum(decode(name,‘physicalreads’,value,0))/

(sum(decode(name,‘dbblockgets’,value,0))+

sum(decode(name,‘consistentgets’,value,0)))))*100

“HitRatio”

fromv$sysstat;評估準則:等級分數(shù):<90%=0 90-94%=10 95-98%=20 >98%=30

性能優(yōu)化實踐-內(nèi)存性能評估數(shù)據(jù)字典命中率顯示了對數(shù)據(jù)字典和其它對象的內(nèi)存讀操作的百分比。檢查方法:select(1-(sum(getmisses)/sum(gets)))*100“HitRatio”

fromv$rowcache;評估準則:等級分數(shù)<85%=086-92%=1092-98%=20>98%=30

性能優(yōu)化實踐-內(nèi)存性能評估庫緩存命中率顯示了對SQL和PL/SQL對象的內(nèi)存讀操作的百分比。同樣注意,很高的命中率并不總是反映數(shù)據(jù)庫性能優(yōu)秀。檢查方法:select

sum(pins)/(sum(pins)+sum(reloads))*100“HitRatio”

fromv$librarycache;

評估準則:等級分數(shù)

<90%=090-94%=1094-98%=20>98%=30

性能優(yōu)化實踐-內(nèi)存性能評估內(nèi)存中的排序根據(jù)初始化參數(shù)PGA_AGGREGATE_TARGET或者SORT_AREA_SIZE的值,用戶的排序操作可能在內(nèi)存中執(zhí)行,也可能在臨時表空間中執(zhí)行。這個檢查用以顯示在內(nèi)存中排序占總排序的百分比。檢查方法:selecta.value

“DiskSorts”,

b.value

“MemorySorts”,

round((100*b.value)/

decode((a.value+b.value),0,1,(a.value+b.value)),

2)“PctMemorySorts”

fromv$sysstata,v$sysstatb

wherea.name=‘sorts(disk)’

andb.name=‘sorts(memory)’;評估準則:等級分數(shù)

<90%=090-94%=1094-98%=20>98%=30

性能優(yōu)化實踐-內(nèi)存性能評估空閑的數(shù)據(jù)緩沖區(qū)比例空閑的記錄數(shù)除以X$BH表中的記錄總數(shù)(即所分配的數(shù)據(jù)塊緩沖區(qū)的總數(shù))得到的空閑緩沖區(qū)百分比。同樣注意,擁有眾多空閑緩沖區(qū)的數(shù)據(jù)庫不一定是最佳環(huán)境,因為可能是緩沖區(qū)設(shè)置過大,浪費內(nèi)存。

檢查方法:selectdecode(state,0,‘FREE’,1,

decode(lrba_seq,0,‘AVAILABLE’,‘BEINGUSED’),

3,‘BEINGUSED’,state)“BlockStatus”,count(*)

fromx$bh

group

bydecode(state,0,‘FREE’,1,

decode(lrba_seq,0,‘AVAILABLE’,‘BEINGUSED’),

3,‘BEINGUSED’,state);評估準則:等級分數(shù)

<5%=05-19%=3020-25%=20>25%=0

性能優(yōu)化實踐-內(nèi)存性能評估最浪費內(nèi)存的前10個語句占全部內(nèi)存讀取量的比例通常一個沒有優(yōu)化系統(tǒng)中,10個最常用的SQL語句的訪問量會占到整個系統(tǒng)中內(nèi)存讀操作的50%以上。這些SQL是最需要進行優(yōu)化的部分,也是優(yōu)化工作中優(yōu)先級很高的部分。

檢查方法:select

sum(pct_bufgets)

from(selectrank()over(order

bybuffer_getsdesc)asrank_bufgets,

to_char(100*ratio_to_report(buffer_gets)over(),‘999.99’)pct_bufgets

fromv$sqlarea)

whererank_bufgets<11;評估準則:等級分數(shù)

<5%=605-19%=5020-25%=30>25%=0

性能優(yōu)化實踐-內(nèi)存性能評估調(diào)整前25個最浪費內(nèi)存的語句在沒有調(diào)整的情況下,絕大多數(shù)系統(tǒng)中,訪問量占前25位的語句的內(nèi)存讀操作將占用整個系統(tǒng)所有內(nèi)存讀操作的75%,對這部分語句進行調(diào)整是至關(guān)重要的。這部分腳本用于獲得訪問量占前25位的SQL語句。檢查方法:set

serveroutput

on

size1000000

declare

top25number;

text1varchar2(4000);

xnumber;

len1number;

cursorc1is

selectbuffer_gets,substr(sql_text,1,4000)

fromv$sqlarea

order

bybuffer_getsdesc;

begin

dbms_output.put_line('Gets'||''||'Text');

dbms_output.put_line(''||''||'');

openc1;

foriin1..25loop

fetchc1

intotop25,text1;

dbms_output.put_line(rpad(to_char(top25),9)||''||

substr(text1,1,66));

len1:=length(text1);

x:=66;

whilelen1>x-1loop

dbms_output.put_line('"'||substr(text1,x,66));

x:=x+66;

end

loop;

end

loop;

end;

/評估準則:本部分沒有評估準則,需要開發(fā)人員或者DBA去確認在這25個SQL中屬于應(yīng)用系統(tǒng)的語句是否都已經(jīng)作過調(diào)優(yōu)。性能優(yōu)化實踐-內(nèi)存性能評估固定緩存對象嘗試在內(nèi)存中固定(pin)經(jīng)常使用的對象,包括表,存儲過程等。檢索需要在共享池中要求大于100K連續(xù)空間的對象:select*

fromv$db_object_cache

wheresharable_mem>100000

and

type

in(‘PACKAGE’,‘PACKAGEBODY’,‘PROCEDURE’,‘FUNCTION’);考察返回的結(jié)果,確認是否需要pin到共享池中。返回結(jié)果中的KEPT字段:

如果是YES,那么表示該對象已經(jīng)固定在了共享池中,

為NO,則表示還沒有固定。性能優(yōu)化實踐-內(nèi)存性能評估固定緩存對象-續(xù)如果需要固定,使用下面的語句:execdbms_shared_pool.keep(‘SYS.STANDARD’);如果我們要固定表,那么可以在創(chuàng)建表的時候或者修改表屬性時使用CACHE關(guān)鍵字,將表放置到BufferCache的LRU列表的MRU端。通常我們需要對于較小的但是頻繁使用的表進行這種操作:

altertabletable_namecache;我們也可以將需要頻繁使用的表放置到另外一個獨立的BufferCache中,比如KEEP池。這種操作可以使這些表的數(shù)據(jù)不至于很快被清除出DefaultBufferCache:

altertabletable_namestorage(bufferpoolkeep);評估準則:本部分沒有評估準則,需要開發(fā)人員或者DBA在系統(tǒng)分析以后謹慎執(zhí)行。性能優(yōu)化實踐-存儲性能評估概述:在存儲性能評估的時候,我們使用磁盤性能指數(shù)(DPI,DiskPerformanceIndex),下表列出了DPI中的各項指數(shù),這個評分系統(tǒng)并不意味著對磁盤的使用和分配的全方位評估,而只是代表一個晴雨表,反映當(dāng)前磁盤的使用和分配上是否存在需要改進或注意的地方。

條目 需要等級 最高分調(diào)整表和索引

30表的行連接問題 無 30分隔離關(guān)鍵的oracle文檔 是 30回滾段的平衡 30臨時段的平衡 30使用最多的前10個sql的磁盤使用率 <5% 60是否已調(diào)整使用磁盤最多的前25個sql 是 40 DPI指數(shù)總分

250數(shù)據(jù)庫性能檢查-存儲性能評估調(diào)整表和索引

由于表和索引的數(shù)據(jù)塊通常是被同時讀取的,所以應(yīng)該盡量將表和其相關(guān)聯(lián)的索引放置在不同的磁盤上,以便減少文檔的I/O沖突。檢查方法:

selecti.index_name,t.table_name,t.tablespace_name

fromuser_tablest,user_indexesi

wheret.table_name=i.table_name

andt.tablespace_name=i.tablespace_name;

返回結(jié)果是創(chuàng)建在相同表空間中的表和相關(guān)聯(lián)的索引。 建議創(chuàng)建新的表空間用于專門存放索引,并將當(dāng)前的索引rebuild到新創(chuàng)建的表空間中:

alterindexidx_namerebuildtablespacets_name;

評估準則:

表和索引放在同一磁盤上=0

存儲使用了磁盤陣列,沒有進一步調(diào)整=20

存儲使用了磁盤陣列,對于raid類型已作過調(diào)整=30

表和索引已規(guī)劃在不同磁盤上30數(shù)據(jù)庫性能檢查-存儲性能評估表的行鏈接問題

當(dāng)更新一張表,而數(shù)據(jù)塊中又沒有足夠的剩余空間來容納所作的修改時,就會發(fā)生“行鏈接”現(xiàn)象,該記錄被鏈接到另外一個有足夠空間的數(shù)據(jù)塊中,也就是一條記錄跨越了多個數(shù)據(jù)塊,這樣在讀取該記錄的時候就會消耗更多的i/o,當(dāng)數(shù)據(jù)庫中有大量的“行鏈接”現(xiàn)象存在時,數(shù)據(jù)庫的整體性能就會下降。檢查方法:

sqlplus/nolog

co

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論