oracle 當數(shù)據(jù)庫變慢時

oracle 當數(shù)據(jù)庫變慢時

ID:38982794

大?。?7.00 KB

頁數(shù):3頁

時間:2019-06-22

oracle 當數(shù)據(jù)庫變慢時_第1頁
oracle 當數(shù)據(jù)庫變慢時_第2頁
oracle 當數(shù)據(jù)庫變慢時_第3頁
資源描述:

《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

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現(xiàn)內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。