当前位置:操作系统 > Unix/Linux >>

在Oracle中实现数据库的复制

在Internet上运作数据库经常会有这样的需求:把遍布全国各城市相似的数据库应用统一起来,一个节点的数据改变不仅体现在本地,还反映到远端。复制技术给用户提供了一种快速访问共享数据的办法。

  一、实现数据库复制的前提条件

  1、数据库支持高级复制功能

  您可以用system身份登录数据库,查看v$option视图,如果其中Advanced

  replication为TRUE,则支持高级复制功能;否则不支持。

  2、数据库初始化参数要求

  ①、db_domain

  =

  test.com.cn

  指明数据库的域名(默认的是WORLD),这里可以用您公司的域名。

  ②、global_names

  =

  true

  它要求数据库链接(database

  link)和被连接的数据库名称一致。

  现在全局数据库名:db_name+”.”+db_domain

  ③、有跟数据库job执行有关的参数

  job_queue_processes

  =

  1

  job_queue_interval

  =

  60

  distributed_transactions

  =

  10

  open_links

  =

  4

  第一行定义SNP进程的启动个数为n。系统缺省值为0,正常定义范围为0~36,根据任务的多少,可以配置不同的数值。

  第二行定义系统每隔N秒唤醒该进程一次。系统缺省值为60秒,正常范围为1~3600秒。事实上,该进程执行完当前任务后,就进入睡眠状态,睡眠一段时间后,由系统的总控负责将其唤醒。

  如果修改了以上这几个参数,需要重新启动数据库以使参数生效。

  二、实现数据库同步复制的步骤

  假设在Internet上我们有两个数据库:一个叫深圳(shenzhen),一个叫北京(beijing)。

  具体配置见下表:

  数据库名

  shenzhen

  beijing

  数据库域名

  test.com.cn

  test.com.cn

  数据库sid号

  shenzhen

  beijing

  Listener端口号

  1521

  1521

  服务器ip地址

  10.1.1.100

  10.1.1.200

  1、确认两台数据库之间可以互相访问,在tnsnames.ora里设置数据库连接字符串。

  ①、例如:深圳这边的数据库连接字符串是以下的格式

  beijing

  =(DESCRIPTION

  =(ADDRESS_LIST

  =(ADDRESS

  =

  (PROTOCOL

  =

  TCP)(HOST

  =

  10.1.1.200)(PORT

  =

  1521)))(CONNECT_DATA

  =(SERVICE_NAME

  =

  beijing)))


  运行$tnsping

  beijing

  出现以下提示符:

  Attempting

  to

  contact

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

  OK(n毫秒)

  

  表明深圳数据库可以访问北京数据库。

  ②、在北京那边也同样配置,确认$tnsping

  shenzhen

  是通的。

  2、改数据库全局名称,建公共的数据库链接。

  ①、用system身份登录shenzhen数据库

  SQL>alter

  database

  rename

  global_name

  to

  shenzhen.test.com.cn;

  用system身份登录beijing数据库:

  SQL>alter

  database

  rename

  global_name

  to

  beijing.test.com.cn;

  ②、用system身份登录shenzhen数据库

  SQL>create

  public

  database

  link

  beijing.test.com.cn

  using

  'beijing';

  测试数据库全局名称和公共的数据库链接

  SQL>select

  *

  from

  global_name@beijing.test.com.cn;

  返回结果为beijing.test.com.cn就对了。

  用system身份登录beijing数据库:

  SQL>create

  public

  database

  link

  shenzhen.test.com.cn

  using

  'shenzhen';

  测试数据库全局名称和公共的数据库链接

  SQL>select

  *

  from

  global_name@shenzhen.test.com.cn;

  返回结果为shenzhen.test.com.cn就对了。

  3、建立管理数据库复制的用户repadmin,并赋权。

  ①、用system身份登录shenzhen数据库

  SQL>create

  user

  repadmin

  identified

  by

  repadmin

  default

  tablespace

  users

  temporary

  tablespace

  temp;

  SQL>execute

  dbms_defer_sys.register_propagator('repadmin');

  SQL>grant

  execute

  any

  procedure

  to

  repadmin;

  SQL>execute

  dbms_repcat_admin.grant_admin_any_repgroup('repadmin');

  SQL>grant

  comment

  any

  table

  to

  repadmin;

  SQL>grant

  lock

  any

  table

  to

  repadmin;

  ②、同样用system身份登录beijing数据库,运行以上的命令,管理数据库复制的用户repadmin,并赋权。

  说明:repadmin用户名和密码可以根据用户的需求自由命名。

  4、在数据库复制的用户repadmin下创建私有的数据库链接。

  ①、用repadmin身份登录shenzhen数据库

  SQL>create

  database

  link

  beijing.test.com.cn

  connect

  to

  repadmin

  identified

  by

  repadmin;

  测试这个私有的数据库链接:

  SQL>select

  *

  from

  global_name@beijing.test.com.cn;

  返回结果为beijing.test.com.cn就对了。

  

  ②、用repadmin身份登录beijing数据库

  SQL>create

  database

  link

  shenzhen.test.com.cn

  connect

  to

  repadmin

  identified

  by

  repadmin;

  测试这个私有的数据库链接

  SQL>select

  *

  from

  global_name@shenzhen.test.com.cn;

  返回结果为shenzhen.test.com.cn就对了。

  5、创建或选择实现数据库复制的用户和对象,给用户赋权,数据库对象必须有主关键字。

  假设我们用ORACLE里举例用的scott用户,dept表。

  ①、用internal身份登录shenzhen数据库,创建scott用户并赋权

  SQL>create

  user

  scott

  identified

  by

  tiger

  default

  tablespace

  users

  temporary

  tablespace

  temp;

  SQL>grant

  connect,

  resource

  to

  scott;

  SQL>grant

  execute

  on

  sys.dbms_defer

  to

  scott;

  ②、用scott身份登录shenzhen数据库,创建表dept

  SQL>create

  table

  dept

  (deptno

  number(2)

  primary

  key,

  dname

  varchar2(14),

  loc

  varchar2(13)

  );

  ③、如果数据库对象没有主关键字,可以运行以下SQL命令添加:

  SQL>alter

  table

  dept

  add

  (constraint

  dept_deptno_pk

CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,