DataGuard是甲骨文推出的一种高可用性数据库方案,在Oracle 8i之前被称为Standby Database。从Oracle 9i开始,正式更名为Data Guard。它是在主节点与备用节点间通过日志同步来保证数据的同步,可以实现数据库快速切换与灾难性恢复。Data Guard只是在软件上对数据库进行设置,并不需要额外购买任何组件。用户能够在对主数据库影响很小的情况下,实现主备数据库的同步。而主备机之间的数据差异只限于在线日志部分,因此被不少企业用作数据容灾解决方案。(以上是度娘解释,本人理解 dataguard设计之初为异地容灾,他的应急切换能提供很好的高可用,但同时对外服务还是只有一台pridb,所以性能未有所提高)此次配置为dataguard物理备库最大性能模式。
 
1)linux操作系统安装并安装oracle10g软件
ps:主库安装数据库软件并建库,备库只需要安装oracle软件不需要建库
         以下主库简称pridb备库stydb
 
 
本次环境:
pridb 172.25.56.149
stydb 172.25.56.150
 
2)pridb配置
 
1.查看是否开启归档模式(由于dataguard高性能需要运用到archivelog恢复stydb,所以必须开启)
archive log list
如果没有开启 需将数据库打至mount模式后开启
alter database archivelog;
alter database force logging;(开启强制归档,有时候由于语句not logging 可能未生成redolog)
生成standby controlfile
alter database create standby controlfile as '/u01/temp/standbycontrolfile.ctl';
 
 
2.查询pridb如下文件位置
 
datafile (select name from v$datafile;)
redologfile (select member from v$logfile;
controlfile (show parameter control_files)
spfile (show parameter spfile)
 
 
3.关闭主库shutdown immediate
 
4.把datafile standbycontrolfile redologfile spfile listener.ora tnsnames.ora passwdfile拷贝至备库相应位置(如果没有相应文件夹,新建同名文件夹)
scp/u01/oradata/WILLSON/ oracle@172.25.56.150:/u01/oradata/
scp standbycontrolfile.ctl oracle@172.25.56.150:/u01/oradata/
scp listener.ora tnsnames.ora oracle@172.25.56.150:/u01/product/10.2.0/db_1/network/admin/
scp orapwWILLSON spfileWILLSON.ora oracle@172.25.56.150:/u01/product/10.2.0/db_1/dbs/
scp -r WILLSON/ oracle@172.25.56.150:/u01/admin/
 
5.配置pridb角色,配置归档日志地址,配置切换模式
 
alter system set log_archive_config='DG_CONFIG=(pridb,stydb)';
 
alter system set db_unique_name='pridb' scope=spfile;
 
shutdown immediate;
 
startup mount;
 
alter system set log_archive_dest_1='LOCATION=/u01/oradata/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=pridb';
 
alter system set log_archive_dest_2='SERVICE=stydb VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLES) DB_UNIQUE_NAME=stydb';
 
alter system set log_archive_dest_state_1='enable';
 
alter system set log_archive_dest_state_2='enable';
 
 
alter system set FAL_CLIENT='pridb';
 
 
alter system set FAL_SERVER='stydb';
 
 
alter system set standby_archive_dest='/u01/oradata/archivelog';
 
 
alter system set standby_file_management='auto';
 
 
6.配置监听
 
[oracle@localhost admin]$ more listener.ora  # listener.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/listener.ora # Generated by Oracle configuration tools.
SID_LIST_LISTENER =   (SID_LIST =     (SID_DESC =       (SID_NAME = PLSExtProc)       (ORACLE_HOME = /u01/product/10.2.0/db_1)       (PROGRAM = extproc)     )     (SID_DESC =            (SID_NAME = WILLSON)            (ORACLE_HOME = /u01/product/10.2.0/db_1)     )
  )

LISTENER =   (DESCRIPTION_LIST =     (DESCRIPTION =       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))       (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))     )   )

 
 
 
[oracle@localhost admin]$ moretnsnames.ora  # tnsnames.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/tnsnames.ora # Generated by Oracle configuration tools.
WILLSON =   (DESCRIPTION =     (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))     (CONNECT_DATA =       (SERVER = DEDICATED)       (SERVICE_NAME = WILLSON)     )   )
pridb =        (DESCRIPTION =          (ADDRESS_LIST =            (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))          )          (CONNECT_DATA =            (SERVER = DEDICATED)            (SERVICE_NAME = WILLSON)          )        )       stydb =        (DESCRIPTION =          (ADDRESS_LIST =            (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))          )          (CONNECT_DATA =            (SERVER = DEDICATED)            (SERVICE_NAME = WILLSON)          )        )

EXTPROC_CONNECTION_DATA =   (DESCRIPTION =     (ADDRESS_LIST =       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))     )     (CONNECT_DATA =       (SID = PLSExtProc)       (PRESENTATION = RO)     )   )

 
 
 
3)stydb配置

1.启动备库至mount状态(如果失败查看初始化参数文件和控制文件是否更新)

startup mount;

2.配置备库参数

alter system set log_archive_config='DG_CONFIG=(pridb,stydb)';

alter system set db_unique_name='stydb'scope=spfile;

shutdown immediate

startup mount

alter system set log_archive_dest_1='LOCATION=/u01/oradata/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=stydb';

alter system set log_archive_dest_2='SERVICE=pridb VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLES) DB_UNIQUE_NAME=pridb';

 
alter system set log_archive_dest_state_1='enable';
 
 
alter system set log_archive_dest_state_2='enable';
 
 
alter system set FAL_CLIENT='stydb';
 
alter system set FAL_SERVER='pridb';
 
alter system set standby_archive_dest='/u01/oradata/archivelog';
 
alter system set standby_file_management='auto';
 
 
alter database force logging;
 
shutdown immediate
 
3.配置监听
[oracle@localhost admin]$ morelistener.ora  # listener.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/listener.ora # Generated by Oracle configuration tools.
SID_LIST_LISTENER =   (SID_LIST =     (SID_DESC =       (SID_NAME = PLSExtProc)       (ORACLE_HOME = /u01/product/10.2.0/db_1)       (PROGRAM = extproc)     )     (SID_DESC =            (SID_NAME = WILLSON)            (ORACLE_HOME = /u01/product/10.2.0/db_1)     )
  )

LISTENER =   (DESCRIPTION_LIST =     (DESCRIPTION =       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))       (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))     )   )
[oracle@localhost admin]$ more tnsnames.ora  # tnsnames.ora Network Configuration File: /u01/product/10.2.0/db_1/network/admin/tnsnames.ora # Generated by Oracle configuration tools.
WILLSON =   (DESCRIPTION =     (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))     (CONNECT_DATA =       (SERVER = DEDICATED)       (SERVICE_NAME = WILLSON)     )   )
pridb =        (DESCRIPTION =          (ADDRESS_LIST =            (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.149)(PORT = 1521))          )          (CONNECT_DATA =            (SERVER = DEDICATED)            (SERVICE_NAME = WILLSON)          )        )       stydb =        (DESCRIPTION =          (ADDRESS_LIST =            (ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.56.150)(PORT = 1521))          )          (CONNECT_DATA =            (SERVER = DEDICATED)            (SERVICE_NAME = WILLSON)          )        )

EXTPROC_CONNECTION_DATA =   (DESCRIPTION =     (ADDRESS_LIST =       (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))     )     (CONNECT_DATA =       (SID = PLSExtProc)       (PRESENTATION = RO)     )   )

 
 
 
 
4)测试配置
pridb:
 
alter database open;
 
select open_mode,database_role from v$database;
 
OPEN_MODE   DATABASE_ROLE ----------              ---------------- READ WRITE   PRIMARY
 
stydb
 
startup;
 
alter database recover managed standby database disconnect;
 
select open_mode,database_role from v$database;
 
OPEN_MODE  DATABASE_ROLE ----------             ---------------- MOUNTED       PHYSICAL STANDBY
 
 
同步测试:
pridb:
select sequence#,applied from v$archived_log;
stydb:
select sequence#,applied from v$archived_log;
 
 
就此oracle dataguard for linux 配置完成了,dataguard切换测试另有传送门:http://blog.csdn.net/w63667329/article/details/7900270

Linux 安装oracle10g 配置dataguard 介绍和步骤的更多相关文章

  1. linux安装及配置c++的opencv库

    linux安装及配置c++的opencv库 前言: 最近想搞个机器视觉的比赛,要求是linux+opencv环境,没有做过opencv开发的我配置环境就配了两天,看来很多乱七八糟的博客,终于装好了.网 ...

  2. 【JDK】Linux安装源码包JDK完整步骤

    [JDK]Linux安装源码包JDK完整步骤 1.检查一下系统中的jdk版本 [root@localhost software]# java -version 显示: openjdk version ...

  3. Microsoft SQL Server for Linux安装和配置

    虽说mssql for linux早已经出来了,但原本没有打算这么早就去尝试的,无奈之下还是得先尝试用了,这里分几篇介绍我在用mssql for linux时遇到的问题,不得不说作为先吃螃蟹的人总是要 ...

  4. Arch Linux 安装、配置、美化和优化

    国庆假期玩了下Arch Linux,发现这货跟Ubuntu之流相差甚远,甚难调教,而且安裝过程全命令行,会有各种问题,各种知识... --- 安装引导器--- -------------------- ...

  5. Linux学习(一)--VMware下Linux安装和配置

    本片随便将给大家讲述linux在VM虚拟机上安装及终端的安装和配置 一.Linux介绍 Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户.多任务.支持多线 ...

  6. Linux 安装及配置 Nginx + ftp 服务器

    Nginx 安装及配置 一.Nginx 简介: Nginx("engine x") 是一款是由俄罗斯的程序设计师 Igor Sysoev 所开发高性能的 Web和 反向代理服务器, ...

  7. 安装和配置hadoop集群步骤

    hadoop集群的安装步骤和配置 hadoop是由java语言编写的,首先我们肯定要在电脑中安装jdk,配置好jdk的环境,接下来就是安装hadoop集群的步骤了,在安装之前需要创建hadoop用户组 ...

  8. linux安装和配置 mysql、redis 过程中遇到的问题记录

    linux下部署mysql和redis网上的教程很多,这里记录一下我部署.配置的过程中遇到的一些问题和解决办法. mysql ①安装完成后启动的时候报错 Starting MySQL.The serv ...

  9. linux环境下配置solr5.3详细步骤

    本人上周五刚刚配置了一遍centos下配置solr5.3版本,综合借鉴并改进了一些教程,贴出如下 单位使用内网,本教程暂无截图,抱歉 另,本人是使用.net编程调用solr的使用的是solrnet,在 ...

随机推荐

  1. 随机变量的方差variance & 随机向量的协方差矩阵covariance matrix

    1.样本矩阵 如果是一个随机变量,那么它的样本值可以用一个向量表示.相对的,如果针对一个随机向量,那么就需要利用矩阵表示,因为向量中的每一个变量的采样值,都可以利用一个向量表示. 然后,一个矩阵可以利 ...

  2. ORACLE 如何定位消耗资源的SQL

    在分析SQL性能的时候,经常需要确定资源消耗多的SQL,总结如下: 1 查看值得怀疑的SQLselect substr(to_char(s.pct, '99.00'), 2) || '%' load, ...

  3. shell -Z- d等等代表

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 [ -a FILE ]   ...

  4. CocoaPods一个Objective-C第三方库的管理利器

    转:http://blog.csdn.net/totogo2010/article/details/8198694 介绍: 开发应用的时候第三方的库是不可缺少的,能提高开发的效率. 一些经常用到的库, ...

  5. HDU 5432 Pyramid Split

    题意:有n个底面是正方形的四棱锥,用一个水平截面将所有四棱锥分成两半,要求上一半体积的和等于下一半,求水平截面的高度,输出整数部分. 解法:二分截面高度.比赛的时候二分写不明白了orz…… 代码: # ...

  6. 【LeetCode 209】Minimum Size Subarray Sum

    Given an array of n positive integers and a positive integer s, find the minimal length of a subarra ...

  7. 【windows核心编程】DLL相关(1)

    DLL相关的东西 1.DLL的加载方式 隐式: #pragma comment(lib, "XX.lib"); 编译器去查找名为XX.dll的DLL,除了名字相同,该DLL和该LI ...

  8. redo文件四

    v$session_wait 用来查询redo buffer的空间信息 select sid,event,seconds_in_wait,state from v$session_wait where ...

  9. 多校7 HDU5816 Hearthstone 状压DP+全排列

    多校7 HDU5816 Hearthstone 状压DP+全排列 题意:boss的PH为p,n张A牌,m张B牌.抽取一张牌,能胜利的概率是多少? 如果抽到的是A牌,当剩余牌的数目不少于2张,再从剩余牌 ...

  10. 多校6 1003 HDU5795 A Simple Nim (sg函数)

    思路:直接打表找sg函数的值,找规律,没有什么技巧 还想了很久的,把数当二进制看,再类讨二进制中1的个数是必胜或者必败状态.... 打表: // #pragma comment(linker, &qu ...