資源描述:
《oracle 當數(shù)據(jù)庫變慢時》由會員上傳分享,免費在線閱讀,更多相關內容在行業(yè)資料-天天文庫。
1、當數(shù)據(jù)庫變慢時,我們應如何入手當應用管理員通告現(xiàn)在應用很慢、數(shù)據(jù)庫很慢時,當OracleDBA在數(shù)據(jù)庫上做幾個示例的Select也發(fā)現(xiàn)同樣的問題時,有些時侯就會無從下手,因為DBA認為數(shù)據(jù)庫的各種命種率都是滿足Oracle文檔的建議。實際上如今的優(yōu)化己經(jīng)向優(yōu)化等待(waits)轉型了,實際中性能優(yōu)化最根本的出現(xiàn)點也都集中在I/O,這是影響性能最主要的方面,由系統(tǒng)中的等待去發(fā)現(xiàn)Oracle庫中的不足、操作系統(tǒng)某些資源利用的不合理是一個比較好的辦法。下面把一些實踐經(jīng)驗與大家分享,本文測重于Unix環(huán)境。
2、第一章檢查系統(tǒng)的狀態(tài)通過操作系統(tǒng)的一些工具檢查系統(tǒng)的狀態(tài),比如CPU、內存、交換、磁盤的利用率,根據(jù)經(jīng)驗或與系統(tǒng)正常時的狀態(tài)相比對,有時系統(tǒng)表面上看起來看空閑,這也可能不是一個正常的狀態(tài),因為cpu可能正等待IO的完成。除此之外,還應觀注那些占用系統(tǒng)資源(cpu、內存)的進程。1.1使用sar來檢查操作系統(tǒng)是否存在IO問題#sar-u210--即每隔2秒檢察一次,共執(zhí)行20次。結果示例:注:在redhat下,%system就是所謂的%wio。Linux2.4.21-20.ELsmp(YY075)05
3、/19/200510:36:07AMCPU%user%nice%system%idle10:36:09AMall0.000.000.1399.8710:36:11AMall0.000.000.00100.0010:36:13AMall0.250.000.2599.4910:36:15AMall0.130.000.1399.7510:36:17AMall0.000.000.00100.00其中:?%usr指的是用戶進程使用的cpu資源的百分比;?%sys指的是系統(tǒng)資源使用cpu資源的百分比;?%wio
4、指的是等待io完成的百分比,這是值得觀注的一項;?%idle即空閑的百分比。如果wio列的值很大,如在35%以上,說明系統(tǒng)的IO存在瓶頸,CPU花費了很大的時間去等待I/O的完成。Idle很小說明系統(tǒng)CPU很忙。像以上的示例,可以看到wio平均值為11,說明I/O沒什么特別的問題,而idle值為零,說明cpu已經(jīng)滿負荷運行了。當系統(tǒng)存在IO問題時,可以從以下幾個方面解決:?聯(lián)系相應的操作系統(tǒng)的技術支持對這方面進行優(yōu)化,比如hp-ux在劃定卷組時的條帶化等方面。?查找Oracle中不合理的sql語句,
5、對其進行優(yōu)化;?對Oracle中訪問量頻繁的表除合理建索引外,再就是把這些表分表空間存放以免訪問上產生熱點,再有就是對表合理分區(qū)。1.2關注內存常用的工具便是vmstat,對于hp-unix來說,可以用glance。Aix來說可以用topas。當發(fā)現(xiàn)vmstat中pi列非零,memory中的free列的值很小,glance、topas中內存的利用率多于80%時,這時說明內存方面應該調節(jié)一下。方法大體有以下幾項:?劃給Oracle使用的內存不要超過系統(tǒng)內存的1/2,一般保在系統(tǒng)內存的40%為益。?為系
6、統(tǒng)增加內存;?如果你的連接特別多,可以使用MTS的方式;?打全補丁,防止內存漏洞。1.3找到使用資源特別大的Oracle的session及其執(zhí)行的語句Hp-unix可以用glance或top。IBMAIX可以用topas。此外可以使用ps的命令。通過這些程序可以找到點用系統(tǒng)資源特別大的這些進程的進程號,就可以通過以下的sql語句發(fā)現(xiàn)這個pid正在執(zhí)行哪個sql,這個sql最好在pl/sqldeveloper、toad等軟件中執(zhí)行:SELECTa.username,a.machine,a.progra
7、m,a.sid,a.serial#,a.status,c.piece,c.sql_textFROMv$sessiona,v$processb,v$sqltextcWHEREb.spid='ORCL'ANDb.addr=a.paddrANDa.sql_address=c.address(+)ORDERBYc.piece;可以把得到的這個sql分析一下,看一下它的執(zhí)行計劃是否走索引。對其優(yōu)化避免全表掃描,以減少IO等待,從而加快語句的執(zhí)行速度。提示:在做優(yōu)化sql時,經(jīng)常碰到使用in的語句,這時一定要用
8、exists把它給換掉,因為Oracle在處理In時是按Or的方式做的,即使使用了索引也會很慢。比如:SELECTcol1,col2,col3FROMtable1aWHEREa.col1NOTIN(SELECTcol1FROMtable2)可以換成:SELECTcol1,col2,col3FROMtable1aWHERENOTEXISTS(SELECT'x'FROMtable2bWHEREa.col1=b.col1)1.4查找前十條性能差的sql語句SELECT*FR