日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
如何調(diào)整Oracle性能

調(diào)整Oracle性能:

 1.數(shù)據(jù)訪問(wèn)機(jī)制,如table full scan,index range scan,index full scan,fast index scan等,這些內(nèi)容讓我明白SQL語(yǔ)句與Oracle的交互方式,數(shù)據(jù)是如何從物理的數(shù)據(jù)文件返回給界面的,是調(diào)整SQL語(yǔ)句必須的知識(shí)。

  2.表之間的連接方式,主要是nested loog,hash join,merge sort,明白各個(gè)連接方式的運(yùn)作機(jī)制,對(duì)于調(diào)整多表查詢的SQL是必須的

  3.索引結(jié)構(gòu),理解索引B樹(shù)的數(shù)據(jù)分布,和物理表之間是怎樣的對(duì)應(yīng)關(guān)系,各個(gè)DML對(duì)索引空間有什么樣的影響,在Oracle中還包括了位圖索引,函數(shù)索引,反向索引

  4.Oracle的空間存儲(chǔ)機(jī)制,本地表空間管理與字典管理的區(qū)別,ASSM特性,表中 freelist,pctfree,pctused,HWM(高水位線)之間有什么樣的聯(lián)系,他們對(duì)DML操作的性能影響

  5.Oracle的內(nèi)存結(jié)構(gòu),SGA區(qū),包括db_cache,shared_pool,larger_pool,java_pool,PGA 區(qū),對(duì)于各個(gè)區(qū)內(nèi)部大小的設(shè)定,調(diào)整,監(jiān)控等,其中db_cache學(xué)習(xí)了LRU數(shù)據(jù)緩沖機(jī)制,劃分不同塊大小的緩沖塊,及keep,recycle池的使用,shared_pool包括其內(nèi)部結(jié)構(gòu),Bucket劃分,綁定變量,SQL查詢計(jì)劃,執(zhí)行樹(shù),硬解析,軟解析等,PGA的調(diào)整包括大小設(shè)定,連接會(huì)話的PGA使用情況,磁盤排序等

  6.各種等待事件的調(diào)整(OWI),磁盤IO方面的主要是db file sequential read , db file scattered read,direct path read等,這些事件的調(diào)整要看其等待的時(shí)間長(zhǎng)短來(lái)進(jìn)行,因?yàn)榈却遣豢赡芟У?,根?jù)P1,P2,P3參數(shù)可以獲取具體等待的數(shù)據(jù)庫(kù)對(duì)象,結(jié)合話話的 SQL,用SQL_TRACE或EXPLAIN做具體調(diào)整

  鎖定方面(enqueue)主要是判斷會(huì)話為什么會(huì)阻塞,引起阻塞的會(huì)話正在執(zhí)行什么語(yǔ)句,鎖定的對(duì)象是什么,鎖的類型是什么,出現(xiàn)非常頻繁的 enqueue等待估計(jì)系統(tǒng)的設(shè)計(jì)存在很大的問(wèn)題

  鎖存器(latch),這個(gè)是關(guān)于內(nèi)存的鎖定,調(diào)整起來(lái)比較棘手,需要理解內(nèi)存的訪問(wèn),修改,掃描機(jī)制,比如偌大一個(gè)db_cache區(qū)域,他里面的數(shù)據(jù)是怎樣定位的,修改,訪問(wèn)時(shí)又是怎樣一種互斥的機(jī)制來(lái)保障內(nèi)存塊的一致性,等等,在9I中,這種機(jī)制大致如下,cache中有一定數(shù)量的 hash latch,每一個(gè)hash latch下面掛載若干個(gè)hash bucket,每一個(gè)hash bucket下面連接一條hash chain,hash chain的內(nèi)容就是鏈接起來(lái)的數(shù)據(jù)塊緩存頭,這樣一個(gè)hash latch對(duì)應(yīng)多個(gè)hash bucket,每個(gè)hash bucket對(duì)應(yīng)一條hash chain,當(dāng)Oracle要訪問(wèn)某一個(gè)塊時(shí),他要知道這個(gè)塊是屬于哪個(gè)數(shù)據(jù)文件,他是第幾個(gè)塊,根據(jù)這些信息對(duì)塊做Hash運(yùn)算,會(huì)得到相應(yīng)的hash bucket內(nèi)存地址,然后定位到內(nèi)存中的bucket,再掃描跟著的hash chain,如果找到,則直接使用,如果不能找到,這在hash chain上鏈接新塊,這整個(gè)過(guò)程的前提是進(jìn)程必須獲取控制這個(gè)bucket的latch,如果有多個(gè)進(jìn)程,他們?cè)L問(wèn)的數(shù)據(jù)塊正好hash到相同的 Latch管轄區(qū),將出現(xiàn)針對(duì)這個(gè)管轄Latch的爭(zhēng)用,體現(xiàn)的latch等待就是cache buffer chains.

  再比如buffer busy wait事件,A會(huì)話讀取數(shù)據(jù)塊C,C不在內(nèi)存中,將進(jìn)行磁盤IO,此時(shí)B會(huì)話也進(jìn)行C塊的讀取,那這時(shí)會(huì)產(chǎn)生C數(shù)據(jù)塊的兩次物理IO嗎?答安是NO,A 會(huì)話會(huì)在內(nèi)存中預(yù)留出以容納C數(shù)據(jù)塊的內(nèi)存空間,并將他暫時(shí)鎖定,以便進(jìn)行隨后的磁盤IO,B會(huì)話會(huì)等待鎖定的結(jié)束,直到C塊被讀進(jìn)內(nèi)存空間,此時(shí)一個(gè) BUFFER BUSY的等待事件就會(huì)被記錄,當(dāng)然以后對(duì)C塊的訪問(wèn)就不會(huì)有什么障礙了,因?yàn)樗呀?jīng)被緩存了

  其他主要的latch等待包括library cache,shared pool等,關(guān)于這部分的學(xué)習(xí)我推薦Steve Adams編寫的Oracle8i Internal Service for Waits,Latches,Locks and Memory,世界頂尖級(jí)高手的杰作,不看可惜,英文不行的請(qǐng)自備金山詞霸

  7.SQL_TRACE/TKPROF,這個(gè)是調(diào)整的極佳工具,特別是調(diào)整不是自己寫的程序,他可以對(duì)任何你認(rèn)為可以的會(huì)話進(jìn)行跟蹤,捕獲會(huì)話的SQL語(yǔ)句,查詢計(jì)劃,CPU使用,消耗時(shí)間,一致性讀次數(shù),具體的等待事件等,這些信息是極有價(jià)值的,想充分利用的話最好能讀懂原始的trace文件,而不是通過(guò)tkprof翻譯的

  8.statspack,這是一個(gè)很好數(shù)據(jù)庫(kù)調(diào)整工具,他采集數(shù)據(jù)庫(kù)的系統(tǒng)信息,生成快照,通過(guò)對(duì)比兩個(gè)快照之間的差異生成報(bào)表,反映系統(tǒng)在這段時(shí)間內(nèi)的運(yùn)作情況,包括磁盤IO,CPU,內(nèi)存,鎖定,等待事件,buffer gets最大的10條SQL,執(zhí)行次數(shù)最多的SQL,表空間,數(shù)據(jù)文件IO分布等等等等,在調(diào)整時(shí),如果實(shí)在沒(méi)辦法找出問(wèn)題了我會(huì)使用他,他也是個(gè)很好的系統(tǒng)信息采集工具

  9.UNIX虛擬分頁(yè)的運(yùn)作機(jī)制,及些亂七八糟的OS性能調(diào)整的工具,這部分學(xué)的很差,很無(wú)味,不知道為什么。


本文名稱:如何調(diào)整Oracle性能
文章轉(zhuǎn)載:http://www.dlmjj.cn/article/dpcgcoi.html