Oracle資料庫 Exp/Imp工具效能調優
Oracle Exp/Imp工具是一個操作簡單、方便靈活的備份恢復和資料遷移工具,它可以實施全庫級、使用者級、表級的資料備份和恢復。對於資料量在G級或G級以內,強調高可用性,可以容忍少量資料丟失的資料庫系統,Exp/Imp是普遍使用的邏輯備份方式。目前現網很多生產系統均使用Exp/Imp進行備份恢復。資料量達到G級以後,備份恢復的時間明顯拉長了,有沒有方法能夠有效提高Exp/Imp的速度呢?答案是肯定的,某些方法還可以成倍的提高速度,本文就從Exp、Imp兩個工具分別探討優化備份恢復效能的方法。
一、Exp調優
1.使用DIRECT和RECORDLENGTH選項
DIRECT引數定義了匯出是使用直接路徑方式(DIRECT=Y),還是常規路徑方式(DIRECT=N)。常規路徑匯出使用SQL SELECT語句從表中抽取資料,直接路徑匯出則是將資料直接從磁碟讀到PGA再原樣寫入匯出檔案,從而避免了SQL命令處理層的資料轉換過程,大大提高了匯出效率。在資料量大的情況下,直接路徑匯出的效率優勢更為明顯,可比常規方法速度提高三倍之多。
和DIRECT=Y配合使用的是RECORDLENGTH引數,它定義了Export I/O緩衝的大小,作用類似於常規路徑匯出使用的BUFFER引數。建議設定RECORDLENGTH引數為最大I/O緩衝,即65535(64kb)。其用法如下:
exp userid=system/manager full=y direct=y recordlength=65535 file= |
直接路徑匯出根據Oracle版本不同,有一些使用限制。比較重要的限制有,8i及以下版本不支援匯出客戶端和資料庫的字符集轉換,因此匯出前必須保證NLS_LANG設定正確;8.1.5及以下版本不支援匯出含LOBs物件的表;不能使用QUERY引數等。
2.使用管道技術
管道是從一個程式程式向另一個程式程式單向傳送資訊的技術。通常,管道把一個程式的輸出傳給另一程式作為輸入。如果匯出的資料量很大,可以利用管道直接生成最終的壓縮檔案,所耗費的時間和不壓縮直接匯出的時間相當。這樣一來,不僅能夠解決磁碟空間不足的問題,而且省去了單獨壓縮檔案的時間;如果需要傳輸匯出檔案,還可以減少網路傳輸的時間。比如,一個10G的檔案單獨壓縮可能需要半小時以上的時間。雖然管道技術不能夠直接縮短Exp/Imp本身的時間,但節省出來的壓縮時間非常可觀。管道和Exp結合的具體使用方法如下:
匯出資料示例:
% mknod /tmp/exp_pipe p # Make the pipe % compress < /tmp/exp_pipe > export.dmp.Z & # Background compress % exp file=/tmp/exp_pipe # Export to the pipe |
二、Imp調優
Oracle Import程式需要花比Export程式數倍的時間將資料匯入資料庫。某些關鍵時刻,匯入是為了應對資料庫的緊急故障恢復。為了減少當機時間,加快匯入速度顯得至關重要。沒有特效辦法加速一個大資料量的匯入,但我們可以做一些適當的設定以減少整個匯入時間。
1.使用管道技術
前面已經說明了Exp時如何使用管道,在匯入時管道的作用是相同,不僅能夠解決磁碟空間不足的問題,而且省去了單獨解壓縮檔案的時間。在大資料量匯入匯出的時候,推薦一定要使用管道。
匯入資料示例:
% mknod /tmp/imp_pipe p # Make the pipe % uncompress < export.dmp.Z > /tmp/imp_pipe & # Background uncompress % imp file=/tmp/imp_pipe # Import from the pipe |
2.避免I/O競爭
Import是一個I/O密集的操作,避免I/O競爭可以加快匯入速度。如果可能,不要在系統高峰的時間匯入資料,不要在匯入資料時執行job等可能競爭系統資源的操作。
3.增加排序區
Oracle Import程式先匯入資料再建立索引,不論INDEXES值設為YES或者NO,主鍵的索引是一定會建立的。建立索引的時候需要用到排序區,在記憶體大小不足的時候,使用臨時表空間進行磁碟排序,由於磁碟排序效率和記憶體排序效率相差好幾個數量級。增加排序區可以大大提高建立索引的效率,從而加快匯入速度。
8i及其以下版本:匯入資料前增加資料庫的sort_area_size大小,可設為正常值的5-10倍。但這個值設定會影響到所有會話,設的過高有可能導致記憶體不足出現paging, swapping現象。更為穩妥的方法是,對於大表和索引特別多的表,只導資料不導索引。導完資料後,建立一個會話,設定當前會話的sort_area_size一個足夠大的值,再手工建立索引。
9i:在workarea_size_policy=AUTO的情況下,所有會話的UGA共用pga_aggregate_target定義的記憶體,不必單獨設定sort_area_size。匯入資料前增加pga_aggregate_target大小,如果機器記憶體夠大,可從通常設定的500M提高到1-2G。pga_aggregate_target大小可以動態調整,匯入完成後可線上調回原值。
4.調整BUFFER選項
Imp引數BUFFER定義了每一次讀取匯出檔案的資料量,設的越大,就越減少Import程式讀取資料的次數,從而提高匯入效率。BUFFER的大小取決於系統應用、資料庫規模,通常來說,設為百兆就足夠了。其用法如下:
imp user2/pwd fromuser=user1 touser=user2 file=/tmp/imp_db_pipe1 commi |
5.使用COMMIT=Y選項
COMMIT=Y表示每個資料緩衝滿了之後提交一次,而不是導完一張表提交一次。這樣會大大減少對系統回滾段等資源的消耗,對順利完成匯入是有益的。
6.使用INDEXES=N選項
前面談到增加排序區時,說明Imp程式會先匯入資料再建立索引。匯入過程中建立使用者定義的索引,特別是表上有多個索引或者資料表特別龐大時,需要耗費大量時間。某些情況下,需要以最快的時間匯入資料,而索引允許後建,我們就可以使用INDEXES=N 只匯入資料不建立索引,從而加快匯入速度。
我們可以用INDEXFILE選項生成建立索引的DLL指令碼,再手工建立索引。我們也可以用如下的方法匯入兩次,第一次匯入資料,第二次匯入索引。其用法如下:
imp user2/pwd fromuser=user1 touser=user2 file=/tmp/imp_db_pipe1 commit=y feed |
7.增加LARGE_POOL_SIZE
如果在init.ora中配置了MTS_SERVICE,MTS_DISPATCHERS等引數,tnsnames.ora中又沒有(SERVER=DEDICATED)的配置,那麼資料庫就使用了共享伺服器模式。在MTS模式下,Exp/Imp操作會用到LARGE_POOL,建議調整LARGE_POOL_SIZE到150M。
檢查資料庫是否在MTS模式下:
SQL>select distinct server from v$session;
如果返回值出現none或shared,說明啟用了MTS。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/119501/viewspace-620953/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle exp和impOracle
- oracle資料匯出匯入(exp/imp)Oracle
- 掌握Oracle資料庫效能調優方法Oracle資料庫
- 【exp/imp不同版本】Oracle不同版本的exp/imp使用注意事項Oracle
- Oracle資料庫匯入匯出。imp匯入命令和exp匯出命令Oracle資料庫
- oracle資料庫調優描述Oracle資料庫
- Oracle 效能調優工具:SQL MonitorOracleSQL
- HBase資料庫效能調優OW資料庫
- exp和imp詳解
- oracle資料庫備份之exp增量備份Oracle資料庫
- 資料庫效能調優之始: analyze統計資訊資料庫
- 資料庫例項效能調優利器:Performance Insights資料庫ORM
- 用exp、imp遷移包含物化檢視日誌的資料
- [20190520]exp imp on th fly.txt
- exp匯出遭遇IMP-00020
- exp&imp的使用方法
- 資料庫調優資料庫
- Oracle效能優化-資料庫CPU使用率100%Oracle優化資料庫
- 使用imp/exp遇到兩個問題
- 不同版本exp/imp使用注意事項
- 資料庫週刊47丨11月國產資料庫排行;MySQL基本知識點;Oracle效能調優筆記…資料庫MySqlOracle筆記
- 十分鐘初步掌握Oracle資料庫效能調優的常見場景與方法Oracle資料庫
- 一文帶你搞懂GaussDB資料庫效能調優資料庫
- 資料庫的效能調優:如何正確的使用索引?資料庫索引
- Spark 效能調優--資源調優Spark
- 如何對分散式 NewSQL 資料庫 TiDB 進行效能調優分散式SQL資料庫TiDB
- 資料庫效能優化2資料庫優化
- 為資料庫效能調優插上 AI 的翅膀 | 調優測試框架 Matrix 團隊訪談資料庫AI框架
- Oracle OCP(54):IMPOracle
- golang 效能調優分析工具 pprof(下)Golang
- golang 效能調優分析工具 pprof (上)Golang
- EXP、IMP、SQLLOADER、EXPDP、IMPDP、DBMS_METADATA、SQLPLUS等方面SQL
- Oracle - 資料庫的記憶體調整Oracle資料庫記憶體
- 【SQL】Oracle資料庫資料量及效能資訊收集SQLOracle資料庫
- JVM效能調優,記憶體分析工具JVM記憶體
- 資料庫效能優化有哪些方式資料庫優化
- mysql 資料庫效能分析工具簡介MySql資料庫
- 【效能調優】Oracle AWR報告指標全解析Oracle指標
- MySQL-12.資料庫其他調優策略MySql資料庫