分享
 
 
 

Oracle數據庫10gR2中stream多源復制方法

王朝oracle·作者佚名  2008-08-06
窄屏简体版  字體: |||超大  

在10gR2中,oracle簡化了stream的配置的全過程,在9iR2及10gR1中,需要針對stream的捕獲、傳播、應用進程進行配置的步驟

已經被dbms_streams_adm新提供的過程(pre_instantiation_setup/post_instantiation_setup)給封裝起來啦,

配置stream只需要調用兩個存儲過程就可以搞定啦,真是太激動人心啦,下面簡單地介紹一下dbms_streams_adm的新過程的用法。

1.在stream進行配置前,需要做些準備工作

a 源庫與目標庫初始化參數的設置

alter system set aq_tm_processes=4 scope=spfile;

alter system set job_queue_processes=5 scope=spfile;

alter system set global_names=true scope=spfile;

alter system set streams_pool_size=51m scope=spfile;

說明streams_pool_size在生產環境中最好>200m

b 源庫與目標庫tnsnames.ora配置

確保正確,可用tnsping通

c 源庫與目標庫復制管理員的創建

create user strmadmin identified by strmadminpw

default tablespace &tbs_name quota unlimited on &tbs_name;

grant connect, resource, dba to strmadmin;

d 源庫與目標庫創建互連的數據鏈

connect strmadmin/strmadminpw@test96;

create database link test99.net connect to strmadmin

identified by strmadminpw using 'test99';

connect strmadmin/strmadminpw@test99;

create database link test96.net connect to strmadmin

identified by strmadminpw using 'test96';

說明:必須確保雙方的數據庫鏈是可以連通.

用pre_instantiation_setup/post_instantiation_setup過程時

db link必須用db_name.domain的格式

e 源庫與目標庫必須處於歸檔模式

shutdown immediate;

startup mount;

alter database archivelog;

alter database open;

2.執行pre_instantiation_setup過程

在調用dbms_streams_adm的pre_instantiation_setup/post_instantiation_setup過程時, 它們必須成對出現,pre_instantiation_setup過程中,maintain_mode參數可取GLOBAL與 TRANSPORTABLE TABLESPACES,如果取GLOBAL時,表示全庫復制,否則可以定義需要復制的表空間; perform_actions參數為TRUE,進行配置產生的源腳本將記錄在dba_recoverable_*字典表, 如果pre_instantiation_setup執行時遇到錯誤,可以通過執行dbms_steams_adm的

recover_operation過程 在更正錯誤後繼續執行復制配置; source_database/destination_database是我們已經創建好的dblink,必須確保正確啊, 否則pre_instantiation_setup過程將會失敗,報ORA-23621錯誤,解決辦法在後面會介紹; bi_directional參數設置為true時,表示是多源復制,即目標與源庫雙向同步, 否則即只從源庫向目標庫同步數據; exclude_schemas參數指需要排除在全庫同步的表空間,多個表空間的話用逗號分開,

*表示排除配置stream時庫中已經存在的表空間;

start_processes參數指配置完成後啟動捕獲及應用進程。

SQL>connect strmadmin/strmadminpw@test96;

declare

empty_tbs dbms_streams_tablespace_adm.tablespace_set;

begin

dbms_streams_adm.pre_instantiation_setup(

maintain_mode => 'GLOBAL',

tablespace_names => empty_tbs,

source_database => 'test96.net',

destination_database => 'test99.net',

perform_actions => true,

bi_directional => true,

include_ddl => true,

start_processes => true,

exclude_schemas => 'WMSYS,STRMADMIN,DBSNMP,TSMSYS,',

exclude_flags => dbms_streams_adm.exclude_flags_unsupported +

dbms_streams_adm.exclude_flags_dml + dbms_streams_adm.exclude_flags_ddl);

end;

/

如果參與復制的源庫與目標庫的db link等配置的正確,該過程將成功結束,

並且在strmadmin模式創建一系統用於復制的隊列與字典表,如果db link配置出錯,

執行pre_instantiation_setup過程時,將會報如下錯誤:

ORA-23621: Operation corresponding

3.用rman復制源庫到目標庫

a 對源庫用rman進行備份,拷貝備份集與產生的歸檔到目標庫,

並將目標庫down下來,啟動nomount狀態。

rman nocatalog target /

rman>backup database;

rman>sql'alter system archive log current';

b 求得源庫的scn

SQL>connect strmadmin/strmadminpw@test96;

SQL>set serveroutput on size 1000000

SQL>declare

until_scn number;

begin

until_scn:= dbms_flashback.get_system_change_number;

dbms_output.put_line('until scn: '||until_scn);

end;

/

until scn: 429596

c 用rman將源庫復制到目標庫

rman nocatalog target /

rman> connect auxiliary sys/sys@test99;

rman> run

{

set until scn 429596;

duplicate target database to 'TEST'

nofilenamecheck

open restricted;

}

d 重新命名目標庫的global_name

alter database rename global_name to test99.net;

e 重新創建目標庫的db link

connect strmadmin/strmadminpw@test99;

create database link test96.net connect to strmadmin

identified by strmadminpw using 'test96';

4.執行post_instantiation_setup過程

post_instantiation_setup也在源庫執行,需要註意的參數是instantiation_scn

它的取值是我們從源庫上獲的scn的值-1=429595.

SQL>connect strmadmin/strmadminpw@test96;

SQL>declare

empty_tbs dbms_streams_tablespace_adm.tablespace_set;

begin

dbms_streams_adm.post_instantiation_setup(

maintain_mode => 'GLOBAL',

tablespace_names => empty_tbs,

source_database => 'test96.net',

destination_database => 'test99.net',

perform_actions => true,

bi_directional => true,

include_ddl => true,

start_processes => true,

instantiation_scn => 429595,

exclude_schemas => '*',

exclude_flags => dbms_streams_adm.exclude_flags_unsupported +

dbms_streams_adm.exclude_flags_dml + dbms_streams_adm.exclude_flags_ddl);

end;

/

在目標庫禁止restricted session

SQL>connect sys/sys@test99.net as sysdba

SQL>alter system disable restricted session;

5.測試stream的配置結果

a 在test96上創建一個schema,並在該schema下創建一些對象,可以在test99上看到

b 在test99上創建一個schema,並在該schema下創建一些對象,可以在test96上看到

6 關於雙向復制中avoid change cycling

查看目標庫apply進程的tag:

COLUMN APPLY_NAME HEADING 'Apply Process Name' FORMAT A30

COLUMN APPLY_TAG HEADING 'Tag Value' FORMAT A30

SQL>connect sys/sys@test99 as sysdba;

SELECT APPLY_NAME, APPLY_TAG FROM DBA_APPLY;

Apply Process Name Tag Value

------------------------------ -----------

APPLY$_TEST96_42 010781

查看源庫apply進程的tag:

COLUMN APPLY_NAME HEADING 'Apply Process Name' FORMAT A30

COLUMN APPLY_TAG HEADING 'Tag Value' FORMAT A30

SQL>connect sys/sys@test99 as sysdba;

SELECT APPLY_NAME, APPLY_TAG FROM DBA_APPLY;

Apply Process Name Tag Value

------------------------------ ------------------------------

APPLY$_TEST99_15 010498

說明:消除多源復制中的遞歸問題,stream中已經有很好的消除機制,

源端正常作業寫入的redo entry的tag是NULL的,如果是由於源端的apply進程

產生的redo entry,在redo entry中將帶有tag標誌,這樣在源端捕獲進程在

捕獲的redo entry中,過慮掉tag是NULL的,然後就可以消除change cycling.

10gR2stream全庫復制

以上主要為大家介紹了pre_instantiation_setup/post_instantiation_setup過程在配置全庫復制的方法,以下介紹dbms_streams_adm的maintain_global過程如何配置stream全庫復制方法,適用於10gR2及以後版本。

1l.在stream進行配置前,需要做些準備工作

a 源庫與目標庫初始化參數的設置

alter system set aq_tm_processes=4 scope=spfile;

alter system set job_queue_processes=5 scope=spfile;

alter system set global_names=true scope=spfile;

alter system set streams_pool_size=51m scope=spfile;

說明streams_pool_size在生產環境中最好>200m

b 源庫與目標庫tnsnames.ora配置

確保正確,可用tnsping通

c 源庫與目標庫復制管理員的創建

create user strmadmin identified by strmadminpw

default tablespace &tbs_name quota unlimited on &tbs_name;

grant connect, resource, dba to strmadmin;

d 源庫與目標庫創建互連的數據鏈

connect strmadmin/strmadminpw@test96;

create database link test99.net connect to strmadmin

identified by strmadminpw using 'test99';

connect strmadmin/strmadminpw@test99;

create database link test96.net connect to strmadmin

identified by strmadminpw using 'test96';

說明:必須確保雙方的數據庫鏈是可以連通.

用pre_instantiation_setup/post_instantiation_setup過程時

db link必須用db_name.domain的格式

e 源庫與目標庫必須處於歸檔模式

shutdown immediate;

startup mount;

alter database archivelog;

alter database open;

f 源庫與目標庫必須創建directory

create directory dir_test96 as '/home/oracle/worksh';

create directory dir_test99 as '/home/oracle/worksh';

2.在源庫執行MAINTAIN_GLOBAL過程

SQL>connect strmadmin/strmadminpw@test96;

begin

dbms_streams_adm.maintain_global(

source_directory_object => 'dir_test96',

destination_directory_object => 'dir_test99',

source_database => 'test96.net',

destination_database => 'test99.net',

perform_actions => true,

include_ddl => true,

instantiation => DBMS_STREAMS_ADM.INSTANTIATION_FULL_NETWORK);

end;

說明:在執行maintain_global時,源庫與目標庫必須創建directory,然後在源庫執行, 目標庫幾乎什麽都不用做,stream環境已經配置完畢。

 
 
 
免責聲明:本文為網絡用戶發布,其觀點僅代表作者個人觀點,與本站無關,本站僅提供信息存儲服務。文中陳述內容未經本站證實,其真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
2023年上半年GDP全球前十五強
 百态   2023-10-24
美眾議院議長啟動對拜登的彈劾調查
 百态   2023-09-13
上海、濟南、武漢等多地出現不明墜落物
 探索   2023-09-06
印度或要將國名改為「巴拉特」
 百态   2023-09-06
男子為女友送行,買票不登機被捕
 百态   2023-08-20
手機地震預警功能怎麽開?
 干货   2023-08-06
女子4年賣2套房花700多萬做美容:不但沒變美臉,面部還出現變形
 百态   2023-08-04
住戶一樓被水淹 還衝來8頭豬
 百态   2023-07-31
女子體內爬出大量瓜子狀活蟲
 百态   2023-07-25
地球連續35年收到神秘規律性信號,網友:不要回答!
 探索   2023-07-21
全球鎵價格本周大漲27%
 探索   2023-07-09
錢都流向了那些不缺錢的人,苦都留給了能吃苦的人
 探索   2023-07-02
倩女手遊刀客魅者強控制(強混亂強眩暈強睡眠)和對應控制抗性的關系
 百态   2020-08-20
美國5月9日最新疫情:美國確診人數突破131萬
 百态   2020-05-09
荷蘭政府宣布將集體辭職
 干货   2020-04-30
倩女幽魂手遊師徒任務情義春秋猜成語答案逍遙觀:鵬程萬裏
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案神機營:射石飲羽
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案昆侖山:拔刀相助
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案天工閣:鬼斧神工
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案絲路古道:單槍匹馬
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:與虎謀皮
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:指鹿為馬
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案金陵:小鳥依人
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案金陵:千金買鄰
 干货   2019-11-12
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有