通用_11gr2 STREAMS部署(单向)

环境信息

source

target

数据库

11gr2

11gr2

操作系统

Red Hat Enterprise Linux Server release 7.4 (Maipo)

Red Hat Enterprise Linux Server release 7.4 (Maipo)

dbname

orcl

orcl

global_name

orcl_soure

orcl_target

步骤

源库和目标库均修改为归档模式

1、检查

SQL> archive log list;

2、设置

SQL> alter database archivelog;

修改源库和目标库的参数

源库:

SQL> alter system set aq_tm_processes=2 scope=both;
SQL> alter system set global_names=true scope=both;
SQL> alter system set job_queue_processes=10 scope=both; 
SQL> alter system set streams_pool_size=200M scope=both;
SQL> alter system set open_links=4 scope=spfile;
SQL> alter database rename GLOBAL_NAME to "orcl_source";

目标库:

SQL> alter system set aq_tm_processes=2 scope=both;
SQL> alter system set global_names=true scope=both;
SQL> alter system set job_queue_processes=10 scope=both; 
SQL> alter system set streams_pool_size=200M scope=both;
SQL> alter system set open_links=4 scope=spfile;
SQL> alter database rename GLOBAL_NAME to "orcl_target";

【参数注释】

job_queue_processes   决定了job作业能够使用的总进程数

aq_tm_processes         该参数决定了数据库启动时Qnnn进程的数量,负责监视高级队列和负责队列传播(propagation)

streams_pool_size      手动指定srteams池的大小

open_links              每个session最多允许的dblink数量

global_names            streams必须要设置该参数为true,当GLOBAL_NAMES参数设置为TRUE时,创建DBLINK的名称必须与被连接库的GLOBAL_NAME一致

源库目标库创建表空间和用户

SQL> create tablespace TBS_CRM datafile '/u01/app/oracle/oradata/orcl/data/crm.dbf' size 512M reuse autoextend on maxsize 1G;

SQL> create user crmuser identified by crmuser default tablespace TBS_CRM quota unlimited on TBS_CRM;

SQL> grant dba to crmuser;

SQL> exec DBMS_STREAMS_AUTH.GRANT_ADMIN_PRIVILEGE('crmuser');

源库目标库TNS修改

orcl_source=

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.111)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = orcl)

    )

  )

orcl_target=

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.112)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = orcl)

    )

  )

在源库和目标库创建db link

源库:

SQL> sqlplus /nolog

SQL> conn crmuser/crmuser

SQL> create database link orcl_target connect to crmuser identified by crmuser using ‘orcl_target’;

Select * from global_name@orcl_target;

目标库:

SQL> sqlplus /nolog

SQL> conn crmuser/crmuser

SQL> create database link orcl_source connect to crmuser identified by crmuser using ‘orcl_source’;

Select * from global_name@orcl_source;

注意:database link名称必须是目标库的global_name名称

在源库和目标库启动追加日志

SQL> sqlplus / as sysdba

SQL> alter database add supplemental log data;

源库上创建发送队列

SQL> sqlplus /nolog
SQL> conn crmuser/crmuser
SQL> BEGIN
   DBMS_STREAMS_ADM.SET_UP_QUEUE(
   queue_table => 'SOURCE_QUEUE_TABLE',
   queue_name => 'SOURCE_QUEUE',
   queue_user => 'crmuser');
   END;
   /
验证是否创建成功:
SQL> select OWNER,QUEUE_TABLE,OBJECT_TYPE from dba_queue_tables where owner='CRMUSER';
删除命令:exec dbms_streams_adm.remove_queue(queue_name=>'SOURCE_QUEUE');

在目标库上创建接收队列

SQL> sqlplus /nolog
SQL> conn crmuser/crmuser

SQL> BEGIN

   DBMS_STREAMS_ADM.SET_UP_QUEUE(

   queue_table => 'TARGET_QUEUE_TABLE',

   queue_name => 'TARGET_QUEUE',

   queue_user => ' crmuser ');

   END;

   /

验证是否创建成功:
SQL> select OWNER,QUEUE_TABLE,OBJECT_TYPE from dba_queue_tables where owner='CRMUSER';

删除命令:exec dbms_streams_adm.remove_queue(queue_name=>'SOURCE_QUEUE');

在源库上创建capture 进程

SQL> BEGIN

   DBMS_STREAMS_ADM.ADD_SCHEMA_RULES(

   schema_name => 'cyd',

   streams_type => 'capture',

   streams_name => 'capture_stream',

   queue_name => 'crmuser.SOURCE_QUEUE',

   include_dml => true,

   include_ddl => true,

   source_database => 'orcl_source',

   include_tagged_lcr => false,

   inclusion_rule => true);

   END;

   /

验证是否创建成功:

select CAPTURE_NAME,QUEUE_NAME,QUEUE_OWNER,CAPTURE_USER,START_SCN,STATUS,SOURCE_DATABASE,
CAPTURE_TYPE,START_TIME from dba_capture;

select * from dba_capture_prepared_schemas;

源库上创建传播进程(Propagation Process)

-- Propagation [ˌprɒpə'ɡeɪʃ(ə)n]

SQL> BEGIN

   DBMS_STREAMS_ADM.ADD_SCHEMA_PROPAGATION_RULES(

   schema_name => 'cyd',

   streams_name => 'source_to_target',

   source_queue_name => 'crmuser.SOURCE_QUEUE',

   destination_queue_name => 'crmuser.TARGET_QUEUE@orcl_target',

   include_dml => true,

   include_ddl => true,

   source_database => 'orcl_source',

   inclusion_rule => true,

   queue_to_queue => true);

   END;

   /

修改propagation休眠时间为0,表示实时传播LCR

SQL> BEGIN

   dbms_aqadm.alter_propagation_schedule(

   queue_name => 'SOURCE_QUEUE',

   destination => 'orcl_target',

   destination_queue => 'TARGET_QUEUE',

   latency => 0);

   END;

   /

在目标库创建Apply进程

SQL> BEGIN

   DBMS_STREAMS_ADM.ADD_SCHEMA_RULES(

   schema_name => 'cyd',

   streams_type => 'apply',

   streams_name => 'target_apply_stream',

   queue_name => 'crmuser.TARGET_QUEUE',

   include_dml => true,

   include_ddl => true,

   include_tagged_lcr => false,

   source_database => 'orcl_source',

   inclusion_rule => true);

   END;

   /

验证是否创建成功:

select APPLY_NAME,QUEUE_NAME,QUEUE_OWNER,APPLY_CAPTURED,RULE_SET_OWNER,APPLY_USER,APPLY_DATABASE_LINK,STATUS from dba_apply;

目标库数据初始化

SQL> exp cyd/cyd1234@orcl_source file=/u01/app/oracle/cyd.dmp object_consistent=y rows=y;

SQL> imp crmuser/crmuser@orcl_target file='/u01/app/oracle/cyd.dmp' ignore=y commit=y log='/u01/app/oracle/cyd.log' streams_instantiation=y fromuser=cyd touser=cyd;

目标库上启动apply进程

SQL> BEGIN

   DBMS_APPLY_ADM.START_APPLY(

   apply_name => 'target_apply_stream');

   END;

/

验证是否创建成功:

SQL>select APPLY_NAME,QUEUE_NAME,QUEUE_OWNER,APPLY_CAPTURED,RULE_SET_OWNER,APPLY_USER

,APPLY_DATABASE_LINK,STATUS from dba_apply;

在源库上启动capture进程

SQL> BEGIN

   DBMS_CAPTURE_ADM.START_CAPTURE(

   capture_name => 'capture_stream');

   END;

   /

验证是否创建成功:

SQL>select CAPTURE_NAME,QUEUE_NAME,QUEUE_OWNER,CAPTURE_USER,START_SCN,STATUS,

SOURCE_DATABASE,CAPTURE_TYPE,START_TIME from dba_capture;

验证

在源库上创建表或增、删、改数据,验证目标库是否完全准确同步。

上一篇:Oracle 重做日志调整 SQL语句


下一篇:oracle建库初始化指南