动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.判断Oracle的两个Undo日志之间的.
.bfile的使用.
.Oracle数据库无法加载_OraMTS_的.
.案例学习Oracle错误:ORA-00235.
.sql load的一点小总结.
.如何实现自动友情链接.
.如何彻底删除一个数据库?.
.如何配置逻辑备用数据库.
.Oracle8i 中生成创建对象的 SQL.
.如何在Oracle中用PL/SQL产生随机.
.数据库崩溃灾难记实.
.ORACLE中常用的SQL语法和数据对象.
.创建访问非Oracle文件的外部表格.
.(原创)oracle数据库备份与恢复 a.
.Oracle SQL内置函数大全(一).
.oracle9.2在redhad2.1安装.
.带你轻松接触Oracle DBLink的简单.
.关于谁需要Web服务事务处理的具体.
.如何在Linux/390中添加新卷.
.ORACLE 乱码问题的解决.

Oracle的同步复制研究

发表日期:2008-2-9 |



  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 定义SNP进程的启动个数为n。系统缺省值为0,正常定义范围为0~36,根据任务的多少,可以配置不同的数值。
  job_queue_interval = 60 定义系统每隔N秒唤醒该进程一次。系统缺省值为60秒,正常范围为1~3600秒。事实上,该进程执行完当前任务后,就进入睡眠状态,睡眠一段时间后,由系统的总控负责将其唤醒。
  distributed_transactions = 10
  open_links = 4
  
  假如修改了以上这几个参数,需要重新启动数据库以使参数生效。
  
  数据库名 ying    orcl
  数据库域名   test.com.cn  test.com.cn
  数据库sid号   ying orcl
  Listener端口号 1521 1521
  服务器ip地址 10.10.3.76 10.10.3.74
  
  2、改数据库全局名称,建公共的数据库链接。
  ①、用system身份登录ying数据库
  alter database rename global_name to ying.test.com.cn
  用system身份登录orcl数据库:
  alter database rename global_name to orcl.test.com.cn
  
  ②、用system身份登录ying数据库
  create public database link ying.test.com.cn using 'ying';
  select * from global_name@ying.test.com.cn
  用system身份登录orcl数据库:
  create public database link orcl.test.com.cn using 'orcl'
  select * from global_name@orcl.test.com.cn
  
  3、建立治理数据库复制的用户repadmin,并赋权。
  ①、用system身份登录ying数据库
  create user repadmin identified by repadmin default tablespace users temporary tablespace temp
  begin
  dbms_defer_sys.register_propagator('repadmin');
  end;
  grant execute any procedure to repadmin;
  begin
  dbms_repcat_admin.grant_admin_any_repgroup('repadmin');
  end;
  grant comment any table to repadmin;
  grant lock any table to repadmin;
  
  ②、同样用system身份登录orcl数据库,运行以上的命令,治理数据库复制的用户repadmin,并赋权。
  create user repadmin identified by repadmin default tablespace users temporary tablespace temp
  begin
  dbms_defer_sys.register_propagator('repadmin');
  end;
  grant execute any procedure to repadmin;
  begin
  dbms_repcat_admin.grant_admin_any_repgroup('repadmin');
  end;
  grant comment any table to repadmin;
  grant lock any table to repadmin;
  
  *********************************************************************
  说明:repadmin用户名和密码可以根据用户的需求自由命名。
  *********************************************************************
  
  4、在数据库复制的用户repadmin下创建私有的数据库链接。
  ①、用repadmin身份登录ying数据库
  create database link orcl.test.com.cn connect to repadmin identified by repadmin;
  select * from global_name@orcl.test.com.cn; --测试
  ②、用repadmin身份登录orcl数据库
  create database link ying.test.com.cn connect to repadmin identified by repadmin;
  select * from global_name@ying.test.com.cn; --测试
  
  5、创建或选择实现数据库复制的用户和对象,给用户赋权,数据库对象必须有主要害字。

  假设我们用Oracle里举例用的water用户,t_file_all表。
  ①、用internal身份登录ying数据库,创建water用户并赋权
  SQL>create user water identified by water default tablespace water temporary tablespace water;
  SQL>grant connect, resource to water;
  SQL>grant execute on sys.dbms_defer to water;
  ②、用water身份登录ying数据库,创建表t_file_all
  ③、假如数据库对象没有主要害字,可以运行以下SQL命令添加:
  alter table t_file_all add (constraint t_file_all_key primary key (t_file_all_id));
  ④、在ying数据库water用户下创建主要害字的序列号,范围避免和orcl的冲突。
  ⑤、在ying数据库water用户下插入初始化数据
  ⑥、在orcl数据库那边同样运行以上①,②,③
  ⑦、在orcl数据库water用户下创建主要害字的序列号,范围避免和water的冲突。
  ⑧、在beijing数据库scott用户下插入初始化数据
  
  6、创建要复制的组water_t_file_all,加入数据库对象,产生对象的复制支持
  ①、用repadmin身份登录ying数据库,创建主复制组water_t_file_all
  begin
  dbms_repcat.create_master_repgroup('water_t_file_all');
  end;
  ②、在复制组scott_mg里加入数据库对象
  begin
  dbms_repcat.create_master_repobject
  (sname=>'water',oname=>'t_file_all',
  type=>'table',use_existing_object=>true,
  gname=>'water_t_file_all'
  );
  end;
  *******************************
  参数说明:
  sname 实现数据库复制的用户名称
  oname 实现数据库复制的数据库对象名称
  (表名长度在27个字节内,程序包名长度在24个字节内)
  type 实现数据库复制的数据库对象类别
  (支持的类别:表,索引,同义词,触发器,视图,过程,函数,程序包,程序包体)
  use_existing_object true表示用主复制节点已经存在的数据库对象
  gname 主复制组名
  *******************************
  ③、对数据库对象产生复制支持
  begin
  dbms_repcat.generate_replication_support('water','t_file_all','table');
  end;
  (说明:产生支持water用户下t_file_all表复制的数据库触发器和程序包)
  ④、确认复制的组和对象已经加入数据库的数据字典
  select gname, master, status from dba_repgroup --测试
  select * from dba_repobject --测试
  
  7、创建主复制节点
  ①、用repadmin身份登录ying数据库,创建主复制节点
  begin
  dbms_repcat.add_master_database
  (gname=>'water_t_file_all',
  master=>'orcl.test.com.cn',
  use_existing_objects=>true,
  copy_rows=>false,
  propagation_mode => 'asynchronous');
  end;
  **********************************************
  参数说明:
  gname 主复制组名
  master 加入主复制节点的另一个数据库
  use_existing_object true表示用主复制节点已经存在的数据库对象
  copy_rows false表示第一次开始复制时不用和主复制节点保持一致
  propagation_mode 异步地执行
  ***********************************************
  select * from user_jobs; --测试是否在复制任务中
  
  8、使同步组的状态由停顿(quiesced )改为正常(normal)
  ①、用repadmin身份登录ying数据库,运行以下命令
  begin
  dbms_repcat.resume_master_activity('water_t_file_all',false);
  end;
  --不行用该命令
  begin
  dbms_repcat.resume_master_activity('water_t_file_all',true);
  end;
  --测试同步是否正常(status为normal)
  select gname, master, status from dba_repgroup
  
  9、创建复制数据库的时间表,我们假设用固定的时间表:1分钟复制一次。
  ①、用repadmin身份登录ying数据库,运行以下命令
  begin
  dbms_defer_sys.schedule_push (
  destination => 'orcl.test.com.cn',
  interval => 'sysdate + 1/(60*24)', --每隔1分钟
  next_date => sysdate);

  end;
  /
  begin
  dbms_defer_sys.schedule_purge (
  next_date => sysdate,
  interval => 'sysdate + 1/(60*24)',
  delay_seconds => 0,
  rollback_segment => '');
  end;
  
  ②、用repadmin身份登录orcl数据库,运行以下命令
  begin
  dbms_defer_sys.schedule_push (
  destination => 'ying.test.com.cn',
  interval => 'sysdate + 1/(60*24)', --每隔1分钟
  next_date => sysdate);
  end;
  /
  begin
  dbms_defer_sys.schedule_purge (
  next_date => sysdate,
  interval => 'sysdate + 1/(60*24)', --每隔1分钟
  delay_seconds => 0,
  rollback_segment => '');
  end;
  
  10、添加或修改两边数据库的记录,跟
上一篇:Oracle客户端编程 人气:480
下一篇:关于oracle中大对象处理的一些方法和实例 人气:505
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-8-28 LDV个人相册系统 v1.6.1
2008-8-28 讯时网站管理系统CMS v3.5
2008-8-28 迅易评选管理系统 v9.3
2008-8-28 OpenX(广告管理系统) v2.6.1 多国
2008-8-28 雨点单用户免费留言板 v2.0 Buil
2008-8-28 APJE私服发布系统 v2.1 ASP版
2008-8-28 酷维CMS企业网站程序 v1.0
2008-8-27 风讯dotNETCMS v1.0 SP3 SQL/ACC
2008-8-27 风讯dotNETCMS v1.0 SP3 源码
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵