DataGuard实战1
DataGuard实战1
-------------------------------------------2013/10/27
一.Primary数据库的配置及操作
1. 确定主库处于归档日志模式。
SQL> archive log list;
2. 将主库设置成force logging模式。
SQL> alter database force logging;
3. 创建standby数据库控制文件。
SQL> alter database create standby controlfile as ‘/u01/august01.ctl’;
--一定要生成standby的控制文件,不能直接用主库的控制文件。不然会抱错,提示该控制文件不是一个standby控制文件。
4. 修改primary数据库的参数文件。
例如:[Oracle@localhost dbs]$ cat initaugust.ora
august.__db_cache_size=92274688
august.__java_pool_size=4194304
august.__large_pool_size=4194304
august.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment
august.__pga_aggregate_target=146800640
august.__sga_target=276824064
august.__shared_io_pool_size=0
august.__shared_pool_size=163577856
august.__streams_pool_size=4194304
*.audit_file_dest='/u01/app/oracle/admin/august/adump'
*.audit_trail='db'
*.compatible='11.2.0.0.0'
*.control_files='/u01/app/oracle/oradata/august/august/control01.ctl','/u01/app/oracle/flash_recovery_area/august/august/control02.ctl'#Restore Controlfile
*.db_block_size=8192
*.db_domain=''
*.db_name='august'
*.db_unique_name=augustpri
*.log_archive_config='dg_config=(augustpri,augustdg)'
*.log_archive_dest_1='location=/u01/app/oracle/flash_recovery_area/august/arch valid_for=(all_logfiles,all_roles) db_unique_name=augustpri'
--这里是本地存放日志的地方
*.log_archive_dest_2='service=augustdg lgwr async valid_for=(online_logfiles,primary_role) db_unique_name=augustdg' --这是设置将日志传给standby数据库,service和db_unique_name设置为备库的。
*.log_archive_dest_state_1=enable
*.log_archive_dest_state_2=enable
*.remote_login_passwordfile=exclusive
*.fal_server=augustdg
*.fal_client=augustpri
*.standby_file_management=auto
*.db_recovery_file_dest='/u01/app/oracle/flash_recovery_area/august'
*.db_recovery_file_dest_size=4039114752
*.diagnostic_dest='/u01/app/oracle'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=augustXDB)'
*.log_archive_format='%t_%s_%r.dbf'
*.memory_target=420478976
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.undo_tablespace='UNDOTBS1'
5. 关闭数据库,重新由pfile生成新的spfile
SQL> shutdown immediate;
SQL> create spfile from pfile; / SQL> create spfile from pfile=’/**/**/init_name.ora’;
6. 使用rman备份数据库,并传输到目标数据库。
RMAN> backup database include current controlfile for standby plus archivelog;
*7. 创建standby log文件。
SQL> shutdown immediate;
SQL> startup mount;
SQL> alter database add standby logfile
group 4 ('/opt/oracle/oradata/fost/std_redo04.log') size 50m,
group 5 ('/opt/oracle/oradata/fost/std_redo05.log') size 50m,
group 6 ('/opt/oracle/oradata/fost/std_redo06.log') size 50m,
group 7 ('/opt/oracle/oradata/fost/std_redo07.log') size 50m;
SQL> alter database open;
8. 将数据库密码文件传输到standby数据库,如果之前有,而且密码一致就可以不传输。
二. Standby数据库的配置及操作。
1. 将primary数据库的参数文件拷贝到standby数据库,或者直接手动修改。
例如:[Oracle@localhost dbs]$ cat initaugust.ora
august.__db_cache_size=79691776
august.__java_pool_size=4194304
august.__large_pool_size=4194304
august.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment
august.__pga_aggregate_target=159383552
august.__sga_target=264241152
august.__shared_io_pool_size=0
august.__shared_pool_size=163577856
august.__streams_pool_size=4194304
*.audit_file_dest='/u01/app/oracle/admin/august/adump'
*.audit_trail='db'
*.compatible='11.2.0.0.0'
*.control_files='/u01/app/oracle/oradata/august/august/control01.ctl','/u01/app/oracle/flash_recovery_area/august/august/control02.ctl'#Restore Controlfile
*.db_block_size=8192
*.db_domain=''
*.db_name='august'
*.db_unique_name=augustdg
*.log_archive_config='dg_config=(augustpri,augustdg)'
*.log_archive_dest_1='location=/u01/app/oracle/flash_recovery_area/august/arch valid_for=(all_logfiles,all_roles) db_unique_name=augustdg' --这里应该是接受到主库传输的日志归档后的地方。
*.log_archive_dest_2='service=augustpri lgwr async valid_for=(online_logfiles,primary_role) db_unique_name=augustpri' --这里设置为将日志传给Primary库的配置,其中service和db_unique_name都应该设置Primary数据对应的值。
*.log_archive_dest_state_1=enable
*.log_archive_dest_state_2=enable
*.remote_login_passwordfile=exclusive
*.fal_server=augustpri
*.fal_client=augustdg
*.standby_file_management=auto
*.db_recovery_file_dest='/u01/app/oracle/flash_recovery_area/august'
*.db_recovery_file_dest_size=4039114752
*.db_unique_name='AUGUSTDG'
*.diagnostic_dest='/u01/app/oracle'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=augustXDB)'
*.log_archive_format='%t_%s_%r.dbf'
*.memory_target=420478976
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.undo_tablespace='UNDOTBS1'
2. 利用此参数文件启动实例到nomount下,并生成spfile文件。
RMAN> startup nomount;
RMAN> sql 'create spfile from pfile';
3. 将Primary生成的standby控制文件,复制到standby数据库中对应的目录中。
4. 根据参数文件,创建相应的目录,然后利用rman备份数据restore并恢复数据库。
5. 在数据库mount状态下,打开recover模式。
SQL> alter database recover managend standby database disconnect from session;
*5。在standby数据库中创建standby log文件。
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
SQL> alter database add standby logfile
group 4 ('/opt/oracle/oradata/fost/std_redo04.log') size 50m,
group 5 ('/opt/oracle/oradata/fost/std_redo05.log') size 50m,
group 6 ('/opt/oracle/oradata/fost/std_redo06.log') size 50m,
group 7 ('/opt/oracle/oradata/fost/std_redo07.log') size 50m;
SQL> shutdown immediate;
SQL> startup mount;
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;
至此DataGuard搭建成功!
三. 相关设置
1. 查看Primary数据库角色及保护模式。
SQL> select database_role,protection_mode,protection_level from v$database;
DATABASE_ROLE PROTECTION_MODE PROTECTION_LEVEL
‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐ ‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐ ‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐
PRIMARY MAXIMUM PERFORMANCE MAXIMUM PERFORMANCE
2. 修改为最大可用性模式并验证。
SQL> alter database set standby database to maximize availability;
Database altered.
SQL> select database_role,protection_mode,protection_level from v$database;
DATABASE_ROLE PROTECTION_MODE PROTECTION_LEVEL
‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐ ‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐ ‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐
PRIMARY MAXIMUM AVAILABILITY RESYNCHRONIZATION
注意:如果发现dataguard 搭建后,日志并没有传输到备机,没有同步。那么通过视图v$arch_dest查看错误信息 select dest_id,error from v$arch_dest; 也可以通过trace file查看详细错误信息。
相关链接:
http://www.5ienet.com/note/html/dg/physical-standby-created-step.shtml
http://www.5ienet.com/note/html/dg/physical-standby-created-script.shtml
http://www.5ienet.com/note/html/dg/physical-standby-role-switch.shtml
DataGuard实战1的更多相关文章
- 实战dataguard主从切换
前言: 众所周知DataGuard一般的切换分成两种,一种是系统正常的情况下的切换这种方式为:switchover是无损切换,不会丢失数据:另外一种方式属于灾难情况下的切换,这种情况下一般主库已经启动 ...
- Oracle dataguard failover 实战
Oracle dataguard failover 实战 操作步骤 备库: SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE FINIS ...
- Oracle DBA从小白到入职实战应用
现如今Oracle依然是RDBMS的王者,在技术上和战略上,Oracle仍然一路高歌猛进,并且全面引领行业迈入了云时代,伴随着12cR2即将在2016年正式发布,学习Oracle之路依旧任重道远,目前 ...
- 【DG】[三思笔记]一步一步学DataGuard
[DG][三思笔记]一步一步学DataGuard 它有无数个名字,有人叫它dg,有人叫它数据卫士,有人叫它data guard,在oracle的各项特性中它有着举足轻理的地位,它就是(掌声)..... ...
- oracle dataguard主从切换
前言: 众所周知DataGuard一般的切换分成两种,一种是系统正常的情况下的切换这种方式为:switchover是无损切换,不会丢失数据:另外一种方式属于灾难情况下的切换,这种情况下一般主库已经启动 ...
- OCP培训 Oracle 12c/18c/19c OCP认证实战培训【送OCP优惠名额】
一.OCP培训 Oracle 12c/18c/19c OCP认证全套实战培训[送OCP优惠名额],本课程内容 课程目标: 为满足想参加Oracle OCP考证的学员,风哥设计的一套比较全面OCP实战培 ...
- SSH实战 · 唯唯乐购项目(上)
前台需求分析 一:用户模块 注册 前台JS校验 使用AJAX完成对用户名(邮箱)的异步校验 后台Struts2校验 验证码 发送激活邮件 将用户信息存入到数据库 激活 点击激活邮件中的链接完成激活 根 ...
- GitHub实战系列汇总篇
基础: 1.GitHub实战系列~1.环境部署+创建第一个文件 2015-12-9 http://www.cnblogs.com/dunitian/p/5034624.html 2.GitHub实战系 ...
- MySQL 系列(四)主从复制、备份恢复方案生产环境实战
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
随机推荐
- 静态变量和Session
静态变量: Application级别的,不同客户端访问同一个变量. Session:对于每个访问的客户端是独立的,都有一个唯一的SessionID.也就是说,不同客户端下,都可以有一个Session ...
- 总结两种动态代理jdk代理和cglib代理
动态代理 上篇文章讲了什么是代理模式,为什么用代理模式,从静态代理过渡到动态代理. 这里再简单总结一下 什么是代理模式,给某个对象提供一个代理对象,并由代理对象控制对于原对象的访问,即客户不直接操控原 ...
- Java之分支和循环
Java中的分支语句: if语句: if语句的四种写法: (1) if(表达式_布尔值) { ... } (2) if(表达式_布尔值) { ... } else { ... } (3) if(表达式 ...
- kali切换字符界面模式和切换图形界面模式
我也是走了很多弯路,下面把正确的命令写出来,网上的不是说不正确,是linux命令做出了更改 Systemd是一种新的linux系统服务管理器 它替代了init, 直接上命令吧! 切换至字符界面 sud ...
- KMP算法(研究总结,字符串)
KMP算法(研究总结,字符串) 前段时间学习KMP算法,感觉有些复杂,不过好歹是弄懂啦,简单地记录一下,方便以后自己回忆. 引入 首先我们来看一个例子,现在有两个字符串A和B,问你在A中是否有B,有几 ...
- CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划)
CJOJ 1131 机器分配 / Luogu 2066 机器分配 (动态规划) Description Luogu: 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国 ...
- C++学习(三)入门篇——函数
C++函数分两种:有返回值的和没返回值的 1.有返回值的函数 调用函数流程 如图,sqrt(6.25)为函数调用,被调用的函数叫做被调用函数,包含函数调用的函数叫做调用函数. 参数是发送给函数的信息, ...
- css动画属性--轮播图效果
通过css的动画属性实现轮播图的显示效果 代码如下: 主体部分: <div id="move"> <ul> <li><img src=&q ...
- hdu_5868:Different Circle Permutation
似乎是比较基础的一道用到polya定理的题,为了这道题扣了半天组合数学和数论. 等价的题意:可以当成是给正n边形的顶点染色,旋转同构,两种颜色,假设是红蓝,相邻顶点不能同时为蓝. 大概思路:在不考虑旋 ...
- Python面向对象编程(四)
1.多态 多态的概念虽然现在才说,但是我们一直在用.多态就是多种形态的意思,动物都猫,狗,猪等等,这些都是动物的多种形态. 反映在Python中,多态就意味着就算不知道变量所引用的对象类型是什么,也能 ...