阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle 11g DataGuard 双机实验

146次阅读
没有评论

共计 10193 个字符,预计需要花费 26 分钟才能阅读完成。

| 操作系统 | release 6.7 | release 6.7 |

| 主机名 | stuaapp01 | stuaapp02 |
|IP | 192.168.20.234 | 192.168.20.235 |
| 数据库软件版本 | Oracle 11.2.0.4.0 | oracle 11.2.0.4.0 |
|ORACLE_BASE | /u01/app/oracle/ | /u01/app/oracle/ |
|ORACLE_HOME |$ORACLE_BASE/product/11.2.0/db_1 | $ORACLE_BASE/product/11.2.0/db_1 |
|ORACLE_SID | orcl | |
| 闪回区 | 4G | |
| 归档 | 开启 | |
———————————————————————————————
查看数据库版本
SQL> select * from v$version;
一.Primary 数据库配置及相关操作
1. 确认 primary 库处于归档模式
2. 将 primary 库置为 FORCE LOGGING 模式
3. 添加 STANDBY 日志文件
4. 创建 primary 库客户端初始化参数文件
1). 创建主库中的 pfile
2). 备份到 backup 目录用于创建备库的 pfile
3). 修改后主库 pfile 中内容如下
4). 通过 pfile 重建 spfile
5). 修改监听配置文件
6). 配置 tnsnames.ora 文件
7). 启动数据库,测试
5.rman 备份数据库, 在闪回区中
二.Standby 数据库配置及相关操作
1. 创建所需目录(注意 OMF 管理的文件)
2. 复制数据文件到 standby 库对应的目录
1). 拷贝闪回区内容
2). 拷贝参数文件
3). 拷贝密码文件
4). 拷贝监听文件和 tns 文件
3. 修改相应配置
1). 修改监听配置文件
2). 修改 TNS 配置文件
3). 重启监听服务
4).standby 的初始化参数如下
5). 通过该 pfile 创建 spfile
4. 恢复数据库
5. 启动 redo 应用
6. 验证
7. 切换到只读模式
8. 切换到同步模式(不需要停库)

 

一.Primary 数据库配置及相关操作
1. 确认 primary 库处于归档模式
SQL> archive log list;
Database log mode Archive Mode
Automatic archival Enabled
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 2
Next log sequence to archive 4
Current log sequence 4

2. 将 primary 库置为 FORCE LOGGING 模式
SQL> alter database force logging;

SQL> select force_logging from v$database;

FOR

YES

Database altered.

3. 添加 STANDBY 日志文件
alter database add standby logfile group 4 (‘/u01/app/oracle/oradata/orcl/redo04.log’) size 50m;
alter database add standby logfile group 5 (‘/u01/app/oracle/oradata/orcl/redo05.log’) size 50m;
alter database add standby logfile group 6 (‘/u01/app/oracle/oradata/orcl/redo06.log’) size 50m;
alter database add standby logfile group 7 (‘/u01/app/oracle/oradata/orcl/redo07.log’) size 50m;

4. 创建 primary 库客户端初始化参数文件
1). 创建主库中的 pfile
SQL> create pfile from spfile;

File created.

2). 备份到 backup 目录用于创建备库的 pfile
[oracle@rac1 dbs]$ pwd
/u01/app/oracle/product/11.2.0/db_1/dbs
[oracle@rac1 dbs]$ cp ./initorcl.ora /home/oracle/backup/

3). 修改后主库 pfile 中内容如下
orcl.__db_cache_size=327155712
orcl.__java_pool_size=4194304
orcl.__large_pool_size=8388608
orcl.__oracle_base=’/u01/app/oracle’
#ORACLE_BASE set from environment
orcl.__pga_aggregate_target=318767104
orcl.__sga_target=469762048
orcl.__shared_io_pool_size=0
orcl.__shared_pool_size=121634816
orcl.__streams_pool_size=0
*.audit_file_dest=’/u01/app/oracle/admin/orcl/adump’
*.audit_trail=’db’
*.compatible=’11.2.0.4.0′
*.control_files=’/u01/app/oracle/oradata/orcl/control01.ctl’,’/u01/app/oracle/fast_recovery_area/orcl/control02.ctl’
*.db_block_size=8192
*.db_domain=”
*.db_name=’orcl’
*.db_recovery_file_dest=’/u01/app/oracle/fast_recovery_area’
*.db_recovery_file_dest_size=4385144832
*.diagnostic_dest=’/u01/app/oracle’
*.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)’
*.log_archive_format=’%t_%s_%r.dbf’
*.memory_target=786432000
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile=’EXCLUSIVE’
*.undo_tablespace=’UNDOTBS1′
#################################################################
#Parameters for Primary Database.
#################################################################
*.DB_NAME=’orcl’
*.DB_UNIQUE_NAME=orcl
*.LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
*.LOG_ARCHIVE_CONFIG=’DG_CONFIG=(orcl,orcldg)’
*.LOG_ARCHIVE_DEST_1=’LOCATION=/u01/app/oracle/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=orcl’
*.LOG_ARCHIVE_DEST_2=’SERVICE=orcldg LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=orcldg’
*.LOG_ARCHIVE_DEST_STATE_1=ENABLE
*.LOG_ARCHIVE_DEST_STATE_2=ENABLE
*.REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
*.standby_file_management=auto

#################################################################
#Parameters which using for switch over from Primary to Standby.
#################################################################
*.FAL_SERVER=orcldg
*.FAL_CLIENT=orcl
*.DB_FILE_NAME_CONVERT=’/u01/app/oracle/oradata/orcldg’,’/u01/app/oracle/oradata/orcl’
*.log_file_name_convert=’/u01/app/oracle/oradata/orcldg’,’/u01/app/oracle/oradata/orcl’
*.standby_archive_dest=’/u01/app/oracle/archive_log’

4). 通过 pfile 重建 spfile
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.

SQL> create spfile from pfile=’initorcl.ora’;

File created.

5). 修改监听配置文件
# listener.ora Network Configuration File: /u01/app/oracle/product/11.2.0/db_1/network/admin/listener.ora
# Generated by Oracle configuration tools.

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.241)(PORT = 1521))
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
)
)

ADR_BASE_LISTENER = /u01/app/oracle
6). 配置 tnsnames.ora 文件
[oracle@rac1 admin]$ pwd
/u01/app/oracle/product/11.2.0/db_1/network/admin
orcl =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.234)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)

orcldg =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.235)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcldg)
)
)

EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)
7). 启动数据库,测试
[oracle@rac1 admin]$ tnsping orcl

TNS Ping Utility for Linux: Version 11.2.0.4.0 – Production on 17-NOV-2016 19:22:52

Copyright (c) 1997, 2013, Oracle. All rights reserved.

Used parameter files:

Used TNSNAMES adapter to resolve the alias
Attempting to contact (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.50.241)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl)))
OK (0 msec)

alter database set standby database to maximize availability;
5.rman 备份数据库, 在闪回区中
backup database plus archivelog;
backup current controlfile for standby;

二.Standby 数据库配置及相关操作

1. 创建所需目录(注意 OMF 管理的文件)
show parameter dest
mkdir -p /u01/app/oracle/admin/orcl/adump
mkdir -p /u01/app/oracle/admin/orcl/dpdump
mkdir -p /u01/app/oracle/diag/rdbms/orcl/orcldg/trace
mkdir -p /u01/app/oracle/diag/rdbms/orcl/orcldg/cdump
mkdir -p /u01/app/oracle/flash_recovery_area
mkdir -p /u01/app/oracle/archivelog
mkdir -p /u01/app/oracle/archive_log
mkdir -p /u01/app/oracle/fast_recovery_area

2. 复制数据文件到 standby 库对应的目录
从主数据库服务器上拷贝文件
1). 拷贝闪回区内容
scp -r ./* 192.168.20.235:/u01/app/oracle/fast_recovery_area/

2). 拷贝参数文件
scp ./* 192.168.20.235:/u01/app/oracle/product/11.2.0/dbhome_1/dbs

3). 拷贝密码文件
[oracle@stuaapp01 dbs]$ scp orapworcl 192.168.20.235:/u01/app/oracle/product/11.2.0/dbhome_1/dbs/

4). 拷贝监听文件和 tns 文件
scp *.ora 192.168.20.235:/u01/app/oracle/product/11.2.0/dbhome_1/network/admin/

3. 修改相应配置

1). 修改监听配置文件
[oracle@stuaapp02 admin]$ vi listener.ora

# listener.ora Network Configuration File: /u01/app/oracle/product/11.2.0/dbhome_1/network/admin/listener.ora
# Generated by Oracle configuration tools.

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.235)(PORT = 1521))
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
)
)

ADR_BASE_LISTENER = /u01/app/oracle

2). 修改 TNS 配置文件

3). 重启监听服务
lsnrctl stop
lsnrctl start

4).standby 的初始化参数如下
orcl.__db_cache_size=327155712
orcl.__java_pool_size=4194304
orcl.__large_pool_size=8388608
orcl.__oracle_base=’/u01/app/oracle’
#ORACLE_BASE set from environment
orcl.__pga_aggregate_target=318767104
orcl.__sga_target=469762048
orcl.__shared_io_pool_size=0
orcl.__shared_pool_size=121634816
orcl.__streams_pool_size=0
*.audit_file_dest=’/u01/app/oracle/admin/orcl/adump’
*.audit_trail=’db’
*.compatible=’11.2.0.4.0′
*.control_files=’/u01/app/oracle/oradata/orcl/control01.ctl’,’/u01/app/oracle/fast_recovery_area/orcl/control02.ctl’
*.db_block_size=8192
*.db_domain=”
*.db_name=’orcl’
*.db_recovery_file_dest=’/u01/app/oracle/fast_recovery_area’
*.db_recovery_file_dest_size=4385144832
*.diagnostic_dest=’/u01/app/oracle’
*.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)’
*.log_archive_format=’%t_%s_%r.dbf’
*.memory_target=786432000
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile=’EXCLUSIVE’
*.undo_tablespace=’UNDOTBS1′
#################################################################
#Parameters for Standby Database.
#################################################################
*.DB_NAME=’orcl’
*.DB_UNIQUE_NAME=orcldg
*.LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
*.LOG_ARCHIVE_CONFIG=’DG_CONFIG=(orcl,orcldg)’
*.DB_FILE_NAME_CONVERT=’/u01/app/oracle/oradata/orcl’,’/u01/app/oracle/oradata/orcldg’
*.LOG_FILE_NAME_CONVERT=’/u01/app/oracle/oradata/orcl’,’/u01/app/oracle/oradata/orcldg’
*.STANDBY_ARCHIVE_DEST=’/u01/app/oracle/archive_log’
*.FAL_SERVER=orcl
*.FAL_CLIENT=orcldg
*.STANDBY_FILE_MANAGEMENT=AUTO

#################################################################
#Parameters which using for switch over from Standby to Primary.
#################################################################
*.LOG_ARCHIVE_DEST_1=’LOCATION=/u01/app/oracle/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=orcldg’
*.LOG_ARCHIVE_DEST_2=’SERVICE=orcl LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=orcl’
*.LOG_ARCHIVE_DEST_STATE_1=ENABLE
*.LOG_ARCHIVE_DEST_STATE_2=ENABLE
*.REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE

5). 通过该 pfile 创建 spfile
SQL> create spfile from pfile= ‘initorcldg.ora’;

File created.
4 恢复数据库
启动备库到 nomount
startup nomount
[oracle@dg2 admin]$ rman target sys/oracle@orcl auxiliary /
RMAN> duplicate target database for standby nofilenamecheck;
RMAN> exit
关闭数据库
shutdown immediate

 

5. 启动 redo 应用
startup nomount;
alter database mount standby database;

SQL> alter database recover managed standby database using current logfile disconnect from session;

Database altered.

6. 验证
主库
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination /u01/app/oracle/archivelog
Oldest online log sequence 73
Next log sequence to archive 75
Current log sequence 75
备库
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination /u01/app/oracle/archivelog
Oldest online log sequence 70
Next log sequence to archive 0
Current log sequence 75
7. 切换到只读模式
SQL> alter database recover managed standby database cancel;

Database altered.
SQL> alter database open read only;

Database altered.
8. 切换到同步模式(不需要停库)
SQL> alter database recover managed standby database using current logfile disconnect from session;

Database altered.

Oracle Data Guard 重要配置参数 http://www.linuxidc.com/Linux/2013-08/88784.htm

基于同一主机配置 Oracle 11g Data Guard http://www.linuxidc.com/Linux/2013-08/88848.htm

手把手教你搭建 Oracle 11g DataGuard  http://www.linuxidc.com/Linux/2016-06/132128.htm

Oracle Data Guard(RAC+DG) 归档删除策略及脚本 http://www.linuxidc.com/Linux/2013-07/87782.htm

Oracle Data Guard 的角色转换 http://www.linuxidc.com/Linux/2013-06/86190.htm

Oracle Data Guard 的日志 FAL gap 问题 http://www.linuxidc.com/Linux/2013-04/82561.htm

Oracle 11g Data Guard Error 16143 Heartbeat failed to connect to standby 处理方法 http://www.linuxidc.com/Linux/2013-03/82009.htm

Oracle 11g RAC 搭建单机 DataGuard  http://www.linuxidc.com/Linux/2016-10/136115.htm

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-11/137349.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计10193字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中