Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1063421
  • 博文数量: 284
  • 博客积分: 8223
  • 博客等级: 中将
  • 技术积分: 3188
  • 用 户 组: 普通用户
  • 注册时间: 2008-12-01 13:26
文章分类

全部博文(284)

文章存档

2012年(18)

2011年(33)

2010年(83)

2009年(147)

2008年(3)

分类: Oracle

2009-05-12 17:01:55

      今天尝试了在两台ultra机器上进行高级复制,并且将相关的命令写成了脚本,附在最后,目前,整个系统正在进行测试,我想使用OCI编程的方式对高级复制涉及的测试表能力进行检验,如果检验过程中出现任何问题,偶将把相关现象续在后面的博客中。

具体过程与上次win机器上的基本类似,只不过增加了修改tnsnames.ora的部分,主机名与IP地址不太一致。

 

检查数据库参数:

要求:     global_names: TRUE

               Open_links:最小数5

修改命令:alter system set global_names=true;

查看参数:show parameter global_names;

2.       修改tnsnames.ora

使双机能够互相使用@访问:

如这里,测试双机环境如下,

主机1 test 域名 orcl  IP:10.144.15.200  

Oracle System用户密码:root

主机2 sun10  域名:sysdb  IP:10.144.15.237

Oracle System 用户密码为:nari

该文件位于$ORACLE_HOME/product/9.2.0/network/admin/,最终tnsnames.ora为:(其中,红色部分为修改部分)

/////////////////////////////////////////////////主机1test///////////////////////////////////////////////////////

ORCL =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = orcl)

    )

  )

 

INST1_HTTP =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = SHARED)

      (SERVICE_NAME = MODOSE)

      (PRESENTATION = )

    )

  )

 

EXTPROC_CONNECTION_DATA =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))

    )

    (CONNECT_DATA =

      (SID = PLSExtProc)

      (PRESENTATION = RO)

    )

  )

 

SYSDB =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = sysdb)

    )

  )

/////////////////////////////////////////////////主机2sun10///////////////////////////////////////////////////////

SYSDB =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = sysdb)

    )

  )

 

INST1_HTTP =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = SHARED)

      (SERVICE_NAME = MODOSE)

      (PRESENTATION = )

    )

  )

 

EXTPROC_CONNECTION_DATA =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))

    )

    (CONNECT_DATA =

      (SID = PLSExtProc)

      (PRESENTATION = RO)

    )

  )

 

ORCL =

  (DESCRIPTION =

    (ADDRESS_LIST =

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

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = orcl)

    )

  )

 

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

使得test主机可以在sqlplus中通过

conn system/root@orcl访问自己,

conn system/nari@sysdb访问对侧。

使得

 

3.       在主机test上执行下面脚本:

a)         system用户登录并建立复制管理员rep

connect system/root@orcl;

create user rep identified by rep

default tablespace users

temporary tablespace temp;

b)        对复制管理员用户rep授予管理员权限;

Begin

dbms_repcat_admin.grant_admin_any_schema(username=>’rep’);

end;

/

grant comment any table to rep;

grant lock any table to rep;

//注册传播函数;

begin

dbms_defer_sys.register_propagator(username=>’rep’);

end;

/

Grant execute any procedure to rep;

c)        增加到sun10节点的公共链路;

Create public database link SYSDB using ‘SYSDB;

d)        登录复制管理员用户,建立私有链路;

connect rep/rep@ORCL

create database link SYSDB connect to rep identified by rep;

e)         每隔1分钟push一次任务将test节点上的事务推到sun10节点上去执行

Begin

dbms_defer_sys.schedule_push(

destination=>’SYSDB’,

       interval=>’sysdate+1/(60*24)’,

       next_date=>sysdate,

       stop_on_error=>FALSE,

       delay_seconds=>0,

       parallelism=>2);

END;

/

f)         注册接收者

Begin dbms_repcat_admin.register_user_repgroup(

Username=>’rep’,

Privilege_type=>’receiver’,

List_of_gnames=>NULL

);

end;

/

 

 

g)        每隔5分钟PURGE一次任务将本节点上已完成的事务退出队列

Begin dbms_defer_sys.schedule_purge(

next_date=>sysdate,

       interval=>’sysdate+5/(60*24)’,

       delay_seconds=>0,

       rollback_segment=>’’);

end;

/

h)        test主机上建立ktest用户

connect system/root@ORCL;

create user ktest identified by ktest default tablespace users temporary tablespace temp;

grant alter session to ktest;

grant create cluster to ktest;

grant create database link to ktest;

grant create sequence to ktest;

grant create session to ktest;

grant create synonym to ktest;

grant create table to ktest;

grant create view to ktest;

grant create procedure to ktest;

grant create trigger to ktest;

grant unlimited tablespace to ktest;

grant create type to ktest;

grant create any snapshot to ktest;

grant alter any snapshot to ktest;

i)          test主机上建立ktest下的dept表;

connect ktest/ktest@ORCL;

create table dept(

  deptno number primary key

);

commit;

 

4.       在主机sun10上执行下面脚本:

a)         system用户登录并建立复制管理员rep

connect system/root@SYSDB;

create user rep identified by rep

default tablespace users

temporary tablespace temp;

b)        对复制管理员用户rep授予管理员权限;

Begin

dbms_repcat_admin.grant_admin_any_schema(username=>’rep’);

end;

/

grant comment any table to rep;

grant lock any table to rep;

begin dbms_defer_sys.register_propagator(username=>’rep’);

end;

/

grant execute any procedure to rep;

c)        TEST节点建立公共链路;

Create public database link ORCL using ‘ORCL;

d)        以复制用户对ORCL节点建立私有链路;

conn rep/rep@SYSDB

create database link ORCL connect to rep identified by rep;

 

e)         每隔1分钟push一次任务将sun10节点上的事务推到test节点上去执行

Begin

dbms_defer_sys.schedule_push(

destination=>’orcl’,

       interval=>’sysdate+1/(60*24)’,

       next_date=>sysdate,

       stop_on_error=>FALSE,

       delay_seconds=>0,

       parallelism=>2);

END;

/

f)         每隔5分钟PURGE一次任务将本节点上已完成的事务退出队列

Begin dbms_defer_sys.schedule_purge(

next_date=>sysdate,

       interval=>’sysdate+5/(60*24)’,

       delay_seconds=>0,

       rollback_segment=>’’);

end;

/

g)        注册接收者

Begin dbms_repcat_admin.register_user_repgroup(

Username=>’rep’,

Privilege_type=>’receiver’,

List_of_gnames=>NULL

);

end;

/

 

h)        sun10主机上建立ktest用户

connect system/nari@SYSDB;

create user ktest identified by ktest default tablespace users temporary tablespace temp;

grant alter session to ktest;

grant create cluster to ktest;

grant create database link to ktest;

grant create sequence to ktest;

grant create session to ktest;

grant create synonym to ktest;

grant create table to ktest;

grant create view to ktest;

grant create procedure to ktest;

grant create trigger to ktest;

grant unlimited tablespace to ktest;

grant create type to ktest;

grant create any snapshot to ktest;

grant alter any snapshot to ktest;

i)          sun10主机上建立ktest下的dept表;

connect ktest/ktest@sysdb;

create table dept(

  deptno number primary key

);

commit;

 

 

5.       在主机shenzhen上执行下面脚本:

a)         rep用户登录;

conn rep/rep@ORCL;

b)        建立对称复制组“SCOTT

Begin dbms_repcat.create_master_repgroup(gname=>’SCOTT’,qualifier=>’’,group_comment=>’’);

End;

/

c)        DEPT表加入到对称复制组“SCOTT”中

Begin

dbms_repcat.create_master_repobject(gname=>’”SCOTT”’, type=>’TABLE’,

oname=>’DEPT’,sname=>’nari’,use_existing_object=>TRUE,

copy_rows=>TRUE);

End;

/

 

d)        把主数据库“SYSDB”加入到对称复制组“SCOTT”中

Begin

Dbms_repcat.add_master_database(gname=>’”SCOTT”’,master=>’sysdb’,use_existing_objects=>TRUE, copy_rows=>TRUE, propagation_mode=>’ASYNCHRONOUS’);

End;

/

(ORA-4052 查找远程对象SYS.SYS.BEIJING出错)

(ORA-23308:对象nari.DEPT不存在或无效 ORA-02055:分布式更新操作失效,要求回退:

遇到该问题后,新建表CC,新建复制组T,所有问题解决;原因在于建表过程,建表时,应使用目前说明的语句,不要使用alter 。。。modify语句,不能有NUMBER(2)这样的描述,先不要insert 数据进入)

e)         生成复制支持表DEPT

Begin dbms_repcat.generate_replication_support(sname=>’ktest’,

Oname=>’DEPT’,type=>’TABLE’,min_communication=>TRUE);

End;

/

f)         启动对称复制组SCOTT

Begin dbms_repcat.resume_master_activity(gname=>’”SCOTT”’);

End;

/

Commit;

执行完后,使用system用户登录系统并查询状态;

Conn system/root@orcl

Select gname,status from sys.dba_repcat ;

如果看到当前复制组的状态为NORMAL表明可以进行DML操作;

同时,如果工作正常的话,应该使用如下命令,看不到log

Select count(*) from sys.dba_repcatlog;

(如果为quiesced

execute dbms_repcat.resume_master_activity(’”SCOTT”’,true);

 

会发现配置主站变成NORMAL,但是另外一个主站仍然为quiesced,该站不能执行启动复制组的操作

可以查询该站的job

select job,this_date,next_date,what from user_jobs;

使用命令exec dbms_job.run(job_number);

Job_number为该主机的最后一个job号,可以启动相应job,发现相应数据就会被同步;而且执行该操作后,该主机也会从quiesced变成NORMAL

)

 

特别:

1.       如果想停止复制对称组运行:

execute  dbms_repcat.suspend_master_activity(gname=>’SCOTT’);注意,需要rep用户;

在执行复制使用,

Begin dbms_repcat.resume_master_activity(gname=>’”SCOTT”’);

End;

 

2.       如果想删除复制组:

execute  dbms_repcat.drop_master_repgroup(gname => 'SCOTT', drop_contents => false, all_sites => false);

 

3.   在复制组scott_mg里删除数据库对象。
execute dbms_repcat.drop_master_repobject ('testuser','dept','table');

 

4.   重新使同步组的状态由停顿(quiesced )改为正常(normal)
execute dbms_repcat.resume_master_activity('scott_mg',false);

 

文件: 高级复制脚本.rar
大小: 1KB
下载: 下载
阅读(838) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~