接前面"oracle 11g streams 邏輯修改記錄(LCR)示例"
想要搭建一個完整的streams環境請看"oracle 11g streams搭建"
1、數據庫級別streams複製
--完整參數示例
connect strmadmin/[email protected]
Connected.
begin
dbms_streams_adm.maintain_global (
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
capture_name => 'DBXA_CAP',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_table => 'DBXA_CAP_Q_T',
capture_queue_user => 'STRMADMIN',
propagation_name => 'DBXA_TO_DBXB_PROP',
apply_name => 'DBXA_APP',
apply_queue_name => 'DBXA_APP_Q',
apply_queue_table => 'DBXA_APP_Q_T',
apply_queue_user => 'STRMADMIN',
script_name => 'cr_streams_global.sql',
script_directory_object => 'STREAMS_DP_DIR',
dump_file_name => NULL,
log_file => NULL,
bi_directional => FALSE,
include_ddl => TRUE,
perform_actions => TRUE,
instantiation => DBMS_STREAMS_ADM.INSTANTIATION_FULL
);
end;
/
job finished
PL/SQL procedure successfully completed.
--如果不需要用戶爲streams組件定義有意義的名稱
connect strmadmin/[email protected]
Connected.
begin
dbms_streams_adm.maintain_global (
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
include_ddl => TRUE
);
end;
/
job finished
PL/SQL procedure successfully completed.
2、模式級別streams複製--完整參數
connect strmadmin/[email protected]
Connected.
declare
schemas dbms_utility.uncl_array;
begin
schemas(1) := 'SCOTT';
schemas(2) := 'HR';
dbms_streams_adm.maintain_schemas (
schema_names => schemas,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
capture_name => 'DBXA_CAP',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_table => 'DBXA_CAP_Q_T',
propagation_name => 'DBXA_TO_DBXB_PROP',
apply_name => 'DBXA_APP',
apply_queue_name => 'DBXA_APP_Q',
apply_queue_table => 'DBXA_APP_Q_T',
dump_file_name => 'schemas_expimp.dmp',
log_file => 'schemas_expimp.log',
bi_directional => FALSE,
include_ddl => TRUE,
perform_actions => TRUE
);
end;
/
job finished
PL/SQL procedure successfully completed.
--如果不需要用戶爲streams組件定義有意義的名稱
connect strmadmin/[email protected]
Connected.
declare
schemas dbms_utility.uncl_array;
begin
schemas(1) := 'SCOTT';
schemas(2) := 'HR';
dbms_streams_adm.maintain_schemas (
schema_names => schemas,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
include_ddl => TRUE,
instantiation => DBMS_STREAMS_ADM.INSTANTIATION_SCHEMA_NETWORK
);
end;
/
PL/SQL procedure successfully completed.
3、表級別streams複製--完整參數
connect strmadmin/[email protected]
Connected.
declare
tables dbms_utility.uncl_array;
begin
tables(1) := 'SCOTT.DEPT';
tables(2) := 'SCOTT.EMP';
tables(3) := 'HR.SALGRADE';
tables(4) := 'HR.BONUS';
dbms_streams_adm.maintain_tables (
table_names => tables,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
capture_name => 'DBXA_CAP',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_table => 'DBXA_CAP_Q_T',
propagation_name => 'DBXA_TO_DBXB_PROP',
apply_name => 'DBXA_APP',
apply_queue_name => 'DBXA_APP_Q',
apply_queue_table => 'DBXA_APP_Q_T',
dump_file_name => NULL,
log_file => NULL,
bi_directional => FALSE,
include_ddl => TRUE,
perform_actions => TRUE,
instantiation => DBMS_STREAMS_ADM.INSTANTIATION_TABLE
);
end;
/
job finished
PL/SQL procedure successfully completed.
4、表空間級別streams複製
--在源數據庫中創建 目錄對象
create directory example_ts_dir as '/u01/oradata/DBXA';
Directory created.
grant read on directory example_ts_dir to strmadmin;
Grant succeeded
--在目標數據庫中創建目錄對象
create directory example_ts_dir as '/u02/app/oradata/DBXB';
Directory created.
--使用maintain_simple_tts過程創建表空間streams複製
connect strmadmin/[email protected]
Connected.
begin
dbms_streams_adm.maintain_simple_tts(
tablespace_name => 'EXAMPLE_TS',
source_directory_object => 'STREAMS_DP_DIR',
source_database => 'DBXA.WORLD',
destination_directory_object => 'EXAMPLE_TS_DIR',
destination_database => 'DBXB.WORLD',
perform_actions => TRUE,
script_name => 'cr_maintain_simple_tts_uni.sql',
script_directory_object => 'STREAMS_DP_DIR',
bi_directional => FALSE
);
end;
/
PL/SQL procedure successfully completed.
--使用MAINTAIN_TTS過程創建表空間streams複製
connect strmadmin/[email protected]
Connected.
declare
ts_names dbms_streams_tablespace_adm.tablespace_set;
begin
ts_names(1) := 'DATA_TS';
ts_names(2) := 'INDEX_TS';
ts_names(3) := 'EXAMPLE_TS';
dbms_streams_adm.maintain_tts(
tablespace_names => ts_names,
source_directory_object => 'STREAMS_DP_DIR',
destination_directory_object => 'EXAMPLE_TS_DIR',
source_database => 'DBXA.WORLD',
destination_database => 'DBXB.WORLD',
perform_actions => TRUE,
script_name => 'cr_streams_maintain_tts_uni.sql',
script_directory_object => 'STREAMS_DP_DIR',
dump_file_name => 'maint_tts.dmp',
capture_name => 'DBXA_CAP',
capture_queue_table => 'DBXA_CAP_Q_T',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_user => 'STRMADMIN',
propagation_name => 'DBXA_TO_DBXB_PROP',
apply_name => 'DBXA_APP',
apply_queue_table => 'DBXA_APP_Q_T',
apply_queue_name => 'DBXA_APP_Q',
apply_queue_user => 'STRMADMIN',
log_file => 'maintain_tts.log',
bi_directional => FALSE,
include_ddl => TRUE
);
end;
/
PL/SQL procedure successfully completed
5、使用MAINTAIN存儲過程配置下游捕獲進程--存儲過程運行在目標數據庫DBXB.WORKD中
--不需要傳播進程,如果指定了傳播進程也不會創建
--捕獲進程和應用進程的隊列名和隊列表名一樣
connect strmadmin/[email protected]
Connected.
declare
schemas dbms_utility.uncl_array;
begin
schemas(1) := 'SCOTT';
schemas(2) := 'HR';
dbms_streams_adm.maintain_schemas (
schema_names => schemas,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
capture_name => 'DBXA_CAP',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_table => 'DBXA_CAP_Q_T',
propagation_name => 'DBXA_TO_DBXB_PROP',
apply_name => 'DBXA_APP',
apply_queue_name => 'DBXA_CAP_Q',
apply_queue_table => 'DBXA_CAP_Q_T',
dump_file_name => NULL,
log_file => NULL,
bi_directional => FALSE,
include_ddl => TRUE,
perform_actions => TRUE
);
end;
/
job finished
PL/SQL procedure successfully completed.
--配置從數據庫DBXA.WORLD到DBXB.WORLD的streams複製的方法
--存儲過程運行在DBXB.WORLD數據庫中
--傳播定義從DBXB.WORLD到DBXC.WORLD
--捕獲進程和應用進程的隊列名和隊列表名不同
connect strmadmin/[email protected]
Connected.
declare
schemas dbms_utility.uncl_array;
begin
schemas(1) := 'SCOTT';
schemas(2) := 'HR';
dbms_streams_adm.maintain_schemas (
schema_names => schemas,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXC.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
capture_name => 'DBXA_CAP',
capture_queue_name => 'DBXA_CAP_Q',
capture_queue_table => 'DBXA_CAP_Q_T',
propagation_name => 'DBXB_TO_DBXC_PROP',
apply_name => 'DBXA_APP',
apply_queue_name => 'DBXA_APP_Q',
apply_queue_table => 'DBXA_APP_Q_T',
dump_file_name => NULL,
log_file => NULL,
bi_directional => FALSE,
include_ddl => TRUE,
perform_actions => TRUE
);
end;
/
PL/SQL procedure successfully completed.
6、創建視圖來查看streams
存儲過程的狀態和進度--主要是基於DBA_RECOVERABLE_SCRIPT視圖和DBA_RECOVERABLE_SCRIPT_BLOCKS視圖創建
connect sys as sysdba
set long 100000000
create or replace view streams_build_status
as
select to_char(rs.creation_time,'HH24:Mi:SS MM/DD/YY') CREATE_DATE,
rs.status,
rs.done_block_num||' of ' ||rs.total_blocks ||' Steps Completed' PROGRESS,
to_char(to_number(sysdate-rs.creation_time)*86400,9999.99) ELAPSED_SECONDS,
substr(rsb.forward_block,1,5000) CURRENT_STEP,
rs.invoking_package||'.'||rs.invoking_procedure PROCEDURE,
rs.script_id
from dba_recoverable_script rs,
dba_recoverable_script_blocks rsb
where rs.script_id = rsb.script_id
and rsb.block_num = rs.done_block_num + 1;
create public synonym streams_build_status for streams_build_status;
grant select on streams_build_status to public;
--查詢進度信息(存儲過程當前正在執行、一共有14個過程塊已經完成13個、已經運行了276秒)
select status,
progress,
elapsed_seconds elapsed,
script_id
from streams_build_status;
STATUS PROGRESS ELAPSED SCRIPT_ID
--------- ------------------------- ------- --------------------------------
EXECUTING 13 of 14 Steps Completed 276.00 7CC97F3B9169704BE040A8C014006E63
--查看正在執行的過程塊
SQL> select current_step
2 from streams_build_status;
CURRENT_STEP
-----------------------------------------------------------------------
-- Start capture process DBXA$CAP
--
BEGIN
dbms_capture_adm.start_capture(
capture_name => '"DBXA$CAP"'
);
EXCEPTION WHEN OTHERS THEN
IF sqlcode = -26666 THEN NULL; -- CAPTURE process already running
ELSE RAISE;
END IF;
END;
--提取腳本及過程塊
set long 10000000
set pages 1000
spool maintain_script.sql
select '-- Block: ' || block_num,
forward_block
from dba_recoverable_script_blocks
where script_id = '7CC97F3B9169704BE040A8C014006E63'
order by block_num;
spool off
7、從MAINTAIN存儲過程的錯誤中恢復--下面展示配置模式級別的複製時,對於一個造成MAINTAIN存儲過程失敗的簡單錯誤處理
connect strmadmin/[email protected]
Connected.
declare
schemas dbms_utility.uncl_array;
begin
schemas(1) := 'SCOTT';
schemas(2) := 'HR';
dbms_streams_adm.maintain_schemas (
schema_names => schemas,
source_database => 'DBXA.WORLD',
source_directory_object => 'STREAMS_DP_DIR',
destination_database => 'DBXB.WORLD',
destination_directory_object => 'STREAMS_DP_DIR',
include_ddl => TRUE,
instantiation => DBMS_STREAMS_ADM.INSTANTIATION_SCHEMA_NETWORK
);
end;
/
declare
*
ERROR at line 1:
ORA-23616: Failure in executing block 7 for script
7CD4E8B08BD40E08E040A8C014007723 with
ORA-39001: invalid argument value
ORA-06512: at "SYS.DBMS_RECO_SCRIPT_INVOK", line 139
ORA-06512: at "SYS.DBMS_STREAMS_RPC", line 465
ORA-06512: at "SYS.DBMS_RECOVERABLE_SCRIPT", line 659
ORA-06512: at "SYS.DBMS_RECOVERABLE_SCRIPT", line 682
ORA-06512: at "SYS.DBMS_STREAMS_MT", line 7972
ORA-06512: at "SYS.DBMS_STREAMS_ADM", line 2674
ORA-06512: at line 7
--通過錯誤提示的script_id查看錯誤的具體信息
select forward_block
from dba_recoverable_script_blocks
where script_id = '7CD4E8B08BD40E08E040A8C014007723'
and block_num = 7;
FORWARD_BLOCK
-----------------------------------------------------------
--
-- Datapump SCHEMA MODE IMPORT (NETWORK)
--
DECLARE
h1 NUM
......
......
--由上可以看出是數據庫連接丟失造成的錯誤
--在創建數據庫連接時候作業在恢復之後便可以成功完成
begin
dbms_streams_adm.recover_operation(
script_id => '7CD4E8B08BD40E08E040A8C014007723',
operation_mode => 'FORWARD'
);
end;
/
PL/SQL procedure successfully completed.
8、含有本地進程的單向複製--配置schema級別的streams,source:DBXA.WORLD、target:DBXB.WORLD
--連接到目標數據庫並且創建streams隊列和表
conn strmadmin/[email protected]
Connected.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_APP_Q',
queue_table => 'DBXA_APP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
--在target數據庫中創建應用進程和規則
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'APPLY',
streams_name => 'DBXA_APP',
queue_name => 'DBXA_APP_Q',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
source_database => 'DBXA.WORLD',
and_condition => ' :lcr.get_compatible() < dbms_streams.max_compatible()'
);
end;
/
PL/SQL procedure successfully completed.
--連接source數據庫並創建Streams隊列
conn strmadmin/[email protected]
Connected.
set serveroutput on size unlimited
set echo on
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_CAP_Q',
queue_table => 'DBXA_CAP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
--在source數據庫創建傳播進程和傳播規則
begin
dbms_streams_adm.add_schema_propagation_rules (
schema_name => 'SCOTT',
streams_name => 'DBXA_TO_DBXB_PROP',
source_queue_name => 'DBXA_CAP_Q',
destination_queue_name => '[email protected]',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
queue_to_queue => true,
source_database => 'DBXA.WORLD',
and_condition => ' :lcr.get_compatible() < dbms_streams.max_compatible()'
);
end;
/
PL/SQL procedure successfully completed.
--在source數據庫中創建捕獲進程和捕獲規則
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'CAPTURE',
streams_name => 'DBXA_CAP',
queue_name => 'DBXA_CAP_Q',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
inclusion_rule => true,
source_database => 'DBXA.WORLD',
and_condition => ' :lcr.get_compatible() < dbms_streams.max_compatible()'
);
end;
/
PL/SQL procedure successfully completed.
--在target數據庫中實例化對象
--使用data pump導出,參數文件內容示例
directory=data_pump_dir
schemas=SCOTT
parallel=4
dumpfile=schemas_%u.dmp
logfile=schemas_expdp.log
--使用data pump導入,參數文件內容示例
directory=data_pump_dir
full=y
parallel=4
table_exists_action=truncate
dumpfile=schemas_%u.dmp
logfile=schemas_expdp.log
--在target數據庫中啓動APPLY進程
conn strmadmin/[email protected]
Connected.
begin
dbms_apply_adm.start_apply('DBXA_APP');
end;
/
PL/SQL procedure successfully completed.
--在source數據庫中啓動CAPTURE進程
conn strmadmin/[email protected]
Connected.
begin
dbms_capture_adm.start_capture('DBXA_CAP');
end;
/
PL/SQL procedure successfully completed.
--檢查 alter 警告日誌文件
--看見如下消息就說明capture進程正在挖掘日誌
LOGMINER: Begin mining logfile for session 23 thread 1 sequence 230,
/u01/oradata/DBXA/redo01.log
LOGMINER: End mining logfile for session 23 thread 1 sequence 230,
/u01/oradata/DBXA/redo01.log
LOGMINER: Begin mining logfile for session 23 thread 1 sequence 231,
/u01/oradata/DBXA/redo01.log
9、包含下游捕獲進程的單向複製(歸檔日誌下游捕獲)
--DBXB.WORLD作爲下游數據庫和目標數據庫使用
--通過log_archive_dest_2來建立重做傳輸
connect sys/[email protected] as sysdba
Connected.
alter system set log_archive_dest_2=
'service=DBXB.WORLD ASYNC NOREGISTER VALID_FOR=(online_logfiles, all_roles)
3 TEMPLATE=DBXA_arch_%t_%s_%r.arc' scope=both;
System altered.
alter system set log_archive_dest_state_2=ENABLE scope=both;
System altered.
connect sys/[email protected] as sysdba
Connected.
alter system set log_archive_dest_2=
'location=/u01/oradata/DBXA_logs VALID_FOR=(standby_logfiles, primary_role)'
scope=both;
System altered.
alter system set log_archive_dest_state_2=ENABLE scope=both;
System altered.
--由於目標數據庫也是下游數據庫,因此不需要配置傳播進程。捕獲進程和應用進程將共享streams隊列和隊列表
connect strmadmin/[email protected]
Connected.
-- Create Streams Queue.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_CAP_APP_Q',
queue_table => 'DBXA_CAP_APP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create apply process and rules.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'APPLY',
streams_name => 'DBXA_APP',
queue_name => 'DBXA_CAP_APP_Q',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- No need to create propagation, since apply
-- and capture run in the same database.
-- Explicitly create the capture process.
-- Note that use_database_link is set to TRUE.
begin
dbms_capture_adm.create_capture(
capture_name => 'DBXA_CAP',
queue_name => 'DBXA_CAP_APP_Q',
use_database_link => TRUE,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Add capture rules.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'CAPTURE',
streams_name => 'DBXA_CAP',
queue_name => 'DBXA_CAP_APP_Q',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
inclusion_rule => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
--之後就和前面一樣實例化對象和啓動應用進程和捕獲進程
9、包含下游捕獲進程的單向複製(實時下游捕獲)--source數據庫DBXA.WORLD、target數據庫DBXB.WORLD
--在source數據庫中找到重做日誌文件大小和重做日誌文件數目
conn sys/[email protected] as sysdba
Connected.
select group#,
bytes/1048576 MB
from v$log;
GROUP# MB
---------- ----------
1 50
2 50
3 50
--在下游數據庫中創建備份重做日誌,並且比source數據庫的重做日誌多一組(和配置dataguard一樣)
conn sys/[email protected] as sysdba
Connected.
alter database add standby logfile group 4
('/u01/oradata/DBXA/standby_logs/standby_redo04.log') size 50M;
Database altered.
alter database add standby logfile group 5
('/u01/oradata/DBXA/standby_logs/standby_redo05.log') size 50M;
Database altered.
alter database add standby logfile group 6
('/u01/oradata/DBXA/standby_logs/standby_redo06.log') size 50M;
Database altered.
alter database add standby logfile group 7
('/u01/oradata/DBXA/standby_logs/standby_redo07.log') size 50M;
Database altered.
-- Check created Standby logs
select thread#,
group#,
sequence#,
status,
archived
from v$standby_log;
THREAD# GROUP# SEQUENCE# STATUS ARC
---------- ---------- ---------- ---------- ---
0 4 0 UNASSIGNED YES
0 5 0 UNASSIGNED YES
0 6 0 UNASSIGNED YES
0 7 0 UNASSIGNED YES
--這步和使用歸檔日誌一樣,爲source和target數據庫配置傳輸初始化參數
--和使用歸檔日誌一樣,創建捕獲進程和應用進程
--注意:需要修改捕獲進程參數
conn strmadmin/[email protected]
Connected.
-- Modify capture Parameter
begin
dbms_capture_adm.set_parameter(
capture_name => 'DBXA_CAP',
parameter => 'downstream_real_time_mine',
value => 'Y'
);
end;
/
PL/SQL procedure successfully completed.
conn sys/[email protected] as sysdba
Connected.
alter system archive log current;
System altered.
conn sys/[email protected] as sysdba
Connected.
select thread#,
group#,
sequence#,
archived,
status
from v$standby_log;
THREAD# GROUP# SEQUENCE# ARC STATUS
---------- ---------- ---------- --- ----------
1 4 289 YES ACTIVE
0 5 0 YES UNASSIGNED
0 6 0 YES UNASSIGNED
0 7 0 YES UNASSIGNED
--之後就和前面一樣實例化對象和啓動應用進程和捕獲進程
10、雙向複製-- Connect to DBXB Database.
conn strmadmin/[email protected]
Connected.
-- Create Queue for apply in DBXB.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_APP_Q',
queue_table => 'DBXA_APP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create Queue for capture in DBXB.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXB_CAP_Q',
queue_table => 'DBXB_CAP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create apply process and rules in DBXB.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'APPLY',
streams_name => 'DBXA_APP',
queue_name => 'DBXA_APP_Q',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Create capture process and rules in DBXB.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'CAPTURE',
streams_name => 'DBXB_CAP',
queue_name => 'DBXB_CAP_Q',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
inclusion_rule => true,
source_database => 'DBXB.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Create propagation in DBXB to send changes to DBXA.
begin
dbms_streams_adm.add_schema_propagation_rules (
schema_name => 'SCOTT',
streams_name => 'DBXB_TO_DBXB_PROP',
source_queue_name => 'DBXB_CAP_Q',
destination_queue_name => '[email protected]',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
queue_to_queue => true,
source_database => 'DBXB.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Connect to DBXA Database
conn strmadmin/[email protected]
Connected.
-- Create Queue for apply in DBXA.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXB_APP_Q',
queue_table => 'DBXB_APP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create Queue for capture in DBXA.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_CAP_Q',
queue_table => 'DBXA_CAP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create apply Process and Rules in DBXA.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'APPLY',
streams_name => 'DBXB_APP',
queue_name => 'DBXB_APP_Q',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
source_database => 'DBXB.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Create capture process and rules in DBXA.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'CAPTURE',
streams_name => 'DBXA_CAP',
queue_name => 'DBXA_CAP_Q',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
inclusion_rule => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Create propagation in DBXA to send changes to DBXB.
begin
dbms_streams_adm.add_schema_propagation_rules (
schema_name => 'SCOTT',
streams_name => 'DBXA_TO_DBXB_PROP',
source_queue_name => 'DBXA_CAP_Q',
destination_queue_name => '[email protected]',
include_dml => true,
include_ddl => true,
inclusion_rule => true,
include_tagged_lcr => false,
queue_to_queue => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
--接下來將source數據庫的對象導入到target數據庫中,並設立實例化scn(data pump導入就不演示了)
--在source數據庫中也實例化scn(對需要的表)。如下手動設置
-- Connect to DBXB database.
conn strmadmin/[email protected]
Connected.
declare
v_scn number;
begin
v_scn := dbms_flashback.get_system_change_number();
[email protected](
source_schema_name => 'SCOTT',
source_database_name => 'DBXB.WORLD',
instantiation_scn => v_scn,
recursive => true
);
end;
/
PL/SQL procedure successfully completed.
--以上都操作完之後可以在兩個數據庫都啓動capture和apply進程(每個數據庫都要啓動這兩個進程)
11、使用同步捕獲進程的複製-- Connect to Destination Database.
conn strmadmin/[email protected]
Connected.
-- Create Streams Queue.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_APP_Q',
queue_table => 'DBXA_APP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create the Apply Process.
-- The APPLY_CAPTURED is set to FALSE by default.
-- But, it is included for documentation purpose.
--
begin
dbms_apply_adm.create_apply(
apply_name => 'DBXA_APP',
queue_name => 'DBXA_APP_Q',
apply_captured => FALSE
);
end;
/
PL/SQL procedure successfully completed.
begin
dbms_streams_adm.add_schema_rules (
schema_name => 'SCOTT',
streams_type => 'APPLY',
streams_name => 'DBXA_APP',
queue_name => 'DBXA_APP_Q',
include_dml => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Connect to the Source Database.
conn strmadmin/[email protected]
Connected.
-- Create Streams Queue for synchronous capture.
begin
dbms_streams_adm.set_up_queue(
queue_name => 'DBXA_SYNC_CAP_Q',
queue_table => 'DBXA_SYNC_CAP_Q_T',
queue_user => 'STRMADMIN'
);
end;
/
PL/SQL procedure successfully completed.
-- Create Synchronous capture process
-- and add capture rules for replicated tables.
begin
dbms_streams_adm.add_table_rules (
table_name => 'SCOTT.DEPT',
streams_type => 'SYNC_CAPTURE',
streams_name => 'DBXA_SYNC_CAP',
queue_name => 'DBXA_SYNC_CAP_Q',
include_dml => true,
inclusion_rule => true,
source_database => 'DBXA.WORLD'
);
dbms_streams_adm.add_table_rules (
table_name => 'SCOTT.EMP',
streams_type => 'SYNC_CAPTURE',
streams_name => 'DBXA_SYNC_CAP',
queue_name => 'DBXA_SYNC_CAP_Q',
include_dml => true,
inclusion_rule => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Create propagation Process and add rules.
-- We can add rules at Schema or Global level.
begin
dbms_streams_adm.add_schema_propagation_rules (
schema_name => 'SCOTT',
streams_name => 'DBXA_TO_DBXB_PROP',
source_queue_name => 'DBXA_SYNC_CAP_Q',
destination_queue_name => '[email protected]',
include_dml => true,
queue_to_queue => true,
source_database => 'DBXA.WORLD'
);
end;
/
PL/SQL procedure successfully completed.
-- Since the Source and Destination tables are
-- already in sync, no need to export/import data.
-- We perform the instantiation manually.
declare
v_scn number;
begin
v_scn := dbms_flashback.get_system_change_number();
[email protected](
source_object_name => 'SCOTT.DEPT',
source_database_name => 'DBXA.WORLD',
instantiation_scn => v_scn);
[email protected](
source_object_name => 'SCOTT.EMP',
source_database_name => 'DBXA.WORLD',
instantiation_scn => v_scn
);
end;
/
PL/SQL procedure successfully completed.
12、還有以下幾種配置策略(P228)
1)從單個源到多個目標數據庫
2)使用隊列轉發的複製
3)使用應用轉發的複製
4)輻射類型複製
5)點對點複製