当前位置:  数据库>oracle

Oracle 单表流复制 stream

    来源: 互联网  发布时间:2017-04-17

    本文导语: 把Oracle单表流复制搞定,由于oracle stream 操作步骤多,之前遇到许多问题, 没有理清思路或者说自己对此的理解不够,所以失败。对于重要表,流复制类似dataguard应用日志,主服务器 捕获,然后传递,从服务器接受,如此而以...

把Oracle单表流复制搞定,由于oracle stream 操作步骤多,之前遇到许多问题,

没有理清思路或者说自己对此的理解不够,所以失败。对于重要表,流复制类似dataguard应用日志,主服务器

捕获,然后传递,从服务器接受,如此而以。简单记录一下主要步骤。

1 主服务器 os: windows  sid:rman  数据库版本10.2.0.1

  从服务器 os:   windows   sid  format  数据库版本10.2.0.1

2 主、从数据库分别执行如下的语句:
Sqlplus ‘/ as sysdba’
alter system set aq_tm_processes=2 scope=both;
alter system set global_names=true scope=both;
alter system set job_queue_processes=10 scope=both;
alter system set parallel_max_servers=20 scope=both;
alter system set undo_retention=3600 scope=both;
alter system set nls_date_format='YYYY-MM-DD HH24:MI:SS' scope=spfile;
alter system set streams_pool_size=25M scope=spfile;--这个我没执行,理由是oracle自动分配了
alter system set utl_file_dir='*' scope=spfile;
alter system set open_links=4 scope=spfile;









3 主从机设置归档 mout状态下alter database archivelog 另开启alter system set  log_archive_start=true;

  查看归档是否成功select recid, name, first_time from v$archived_log;

4 主从机表空间和用户

  create tablespace stream_tbs datafile 'g:oracleoradatarmanstream01.dbf' size 200m

  autoextend on extent management local uniform size 1m segment space management auto;

表空间已创建。

-- 创建streams管理用户,并授予dba权限

JSSWEB> create user test identified by test default tablespace stream_tbs;

用户已创建。

--将logminer的数据字典从system表空间转移到新建的表空间,防止撑满system表空间
execute dbms_logmnr_d.set_tablespace('tbs_stream');

-- 由于streams用户操作需要较多权限,此处仅用于演示,简便期间直接授予dba权限

 授权test管理用户

JSSWEB> grant dba to test;

begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'test',
grant_privileges => true);
end;




5 主从机表空间和用户

  create tablespace stream_tbs datafile 'd:oracleoradatarmanstream01.dbf' size 200m

  autoextend on extent management local uniform size 1m segment space management auto;

表空间已创建。

-- 创建streams管理用户,并授予dba权限

JSSWEB> create user strmadmin identified by strmadmin default tablespace stream_tbs;

用户已创建。

--将logminer的数据字典从system表空间转移到新建的表空间,防止撑满system表空间
execute dbms_logmnr_d.set_tablespace('tbs_stream');

-- 由于streams用户操作需要较多权限,此处仅用于演示,简便期间直接授予dba权限

 授权test管理用户

JSSWEB> grant dba to strmadmin ;

begin
dbms_streams_auth.grant_admin_privilege(
grantee => 'strmadmin',
grant_privileges => true);
end;




6 配置网络连接

 主数据库(tnsnames.ora)中添加从数据库的配置。
 RMAN =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.103)(PORT = 1521))
)
(CONNECT_DATA =
(SID = rman)
(SERVER = DEDICATED)
)
)
配置从环境tnsnames.ora
从数据库(tnsnames.ora)中添加主数据库的配置。
FORMAT =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.104)(PORT = 1521))
)
(CONNECT_DATA =
(SID = format)
(SERVER = DEDICATED)
)
)






















7 创建database link

  主:create database link format connect to strmadmin identified by strmadmin using 'format';

  从:create database link rman  connect to strmadmin identified by strmadmin using 'rman '; 

 然后相互tnsping 或 select sysdate from dual@format/rman;

8  主库 exec dbms_streams_adm.set_up_queue();

    从库  exec dbms_streams_adm.set_up_queue();

 

9 创建捕获规则 

  begin

   dbms_streams_adm.add_table_rules(

   table_name => 'scott.emp',

   streams_type => 'capture',

   streams_name =>'capture_stream',

   queue_name => 'test.streams_queue',

   include_dml => true,

   include_ddl => true,

   inclusion_rule => true);

   end;
--创建传播规则

begin

   dbms_streams_adm.add_table_propagation_rules(

   table_name =>'scott.emp',

   streams_name => 'sour_to_targ',

   source_queue_name =>'test.streams_queue',

   destination_queue_name => 'strmadmin.streams_queue@format',

   include_dml => true,

   include_ddl => true,

   source_database =>'rman',

   inclusion_rule => true,

   queue_to_queue => true);

 end;

select capture_name,status from dba_capture;

CAPTURE_NAME                   STATUS

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

CAPTURE_STREAM                 DISABLED


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • 编程语言 iis7站长之家
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3