一、 实施方案
这几天给客户的Oracle 11gr2 RAC搭建到单实例的DG,整理了一下步骤,理清一下思路,文中敏感信息已做模糊处理。
RAC至单实例的Dataguard为双节点各自传递自己当前线程的归档至备库。
由于节点1存储不足,备份在节点2上跑。整体搭建思路如下:
备库文件目录创建à主库force logging(已是归档模式)
à备份节点二à复制节点二口令文件à创建备库pfileà创建备库à恢复备库
à创建主备standby logfileà配置主备监听及TNSà修改主库(节点一、节点二)参数à打开备库并实时应用
1.1 主备环境说明
Primary
Node1
Node2
Hostname
hostname01
hostname02
Public
10.10.10.141
10.10.10.143
VIP
10.10.10.142
10.10.10.144
SCAN
10.10.10.140
Instance_name
repprod1
repprod2
DB_name
repprod
Service_names
repprod
DB_unique_name
repprod
Storage_mode
ASM
Standby
Node
Hostname
hostnamedg
IP
10.10.10.191
Instance_name
Repproddg
DB_name
repprod
Service_names
repproddg
DB_unique_name
repproddg
Storage_mode
Local disk
1.2 文件系统规划
Primary
Standby
+DATADG/repprod/datafile
/oradata/datafile
+DATADG/repprod/tempfile
/oradata/tempfile
+ARCDG/repprod/onlinelog
+DATADG/repprod/onlinelog
/oradata/onlinelog
+ARCDG/
/oradata/arch
1.3 实施操作步骤
1.3.1 备库存储和文件系统创建
#standby库上新建各个数据文件的存放位置
$mkdir -p /oradata/datafile --数据文件
$mkdir -p /oradata/tempfile --临时文件
$mkdir -p /oradata/onlinelog --redo日志
$mkdir -p /oradata/controlfile --控制文件
$mkdir -p /oradata/arch --归档文件
#备库为全新安装oracle 11.2.0.4软件,需要手工建立以下目录,保持与主库目录一致。
$cd $ORACLE_BASE
$mkdir -p admin/repproddg/adump
$mkdir -p admin/repproddg/dpdump
$mkdir -p admin/repproddg/hdump
$mkdir -p admin/repproddg/pfile
1.3.2 主库上设置数据库运行在force logging模式
#查看数据库的模式:
SQL> selectLOG_MODE,OPEN_MODE,PROTECTION_MODE,DATABASE_ROLE,SWITCHOVER_STATUS,GUARD_STATUS,FORCE_LOGGINGfrom v$database;
#在主库上执行:
SQL> alter database force logging;
1.3.3 备份主库
#节点二备份
$rman target/RMAN>run{
allocate channel c1 typedisk;
allocate channel c2 typedisk;backup filesperset=3 format='/oracle/backup/%T_%d_%s_%p.bus' as compressed backupset database;backup format='/oracle/backup/%T_%d_%s_%p.ctl' currentcontrolfile;
release channel c1;
release channel c2;
}
#传递备份至备库
$scp /oracle/backup/20180418* oracle@10.10.10.191:/oradata/backup
1.3.4 口令文件复制
#将主库的口令文件复制到备库相同目录下,并改名为orapwrepproddg。
$scp/oracle/app/oracle/db/dbs/orapwrepprod oracle@10.10.10.191:/u01/app/oracle/product/11.2.0/db_1/dbs
#重命名
$mv orapwrepprod orapwrepproddg
1.3.5 创建和修改备库pfile 参数文件
#主库上生成pfile
SQL> create pfie fromspfile;
#传递至备库
$cd $ORACLE_HOME/dbs
$scp initrepprod.ora oracle@10.10.10.191: /u01/app/oracle/product/11.2.0/db_1/dbs
#修改为initrepproddg.ora并修改相关参数
$mv initrepprod.ora initrepproddg.ora
$vi initrepprod.ora
*.__db_cache_size=21206401024*.__java_pool_size=1879048192*.__large_pool_size=805306368*.__pga_aggregate_target=70061654016*.__sga_target=38386270208*.__shared_io_pool_size=0*.__shared_pool_size=13421772800*.__streams_pool_size=536870912
*.audit_file_dest= '/u01/app/oracle/repproddg/adump'
*.audit_trail='db'
*.compatible='11.2.0.4.0'
*.control_files='/oradata/controlfile/control01.ctl'
*.db_block_size=8192
*.db_domain=''
*.db_name=repprod*.db_unique_name=repproddg*.service_names=repproddg*.db_recovery_file_dest_size=209715200000
*.open_cursors=300
*.pga_aggregate_target=70061654016
*.processes=1500
*.sessions=1655
*.sga_target=38386270208
*._undo_autotune=FALSE*.log_archive_format='%t_%s_%r.arc'
*.db_recovery_file_dest='/oradata/arch'
*.db_file_name_convert='+DATADG/repprod/datafile','/oradata/datafile','+DATADG/repprod/tempfile','/oradata/tempfile'
*.LOG_ARCHIVE_CONFIG='DG_CONFIG=(repprod, repproddg)'
*.LOG_ARCHIVE_DEST_1='LOCATION=/oradata/arch VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=repproddg'
*.LOG_ARCHIVE_DEST_2='SERVICE=repprod_pri LGWR ASYNC NOAFFIRM VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME= repprod'
*.log_file_name_convert='+ARCDG/repprod/onlinelog','/oradata/onlinelog','+DATADG/repprod/onlinelog','/oradata/onlinelog'
*.remote_login_passwordfile='exclusive'
*.standby_file_management=auto
*.diagnostic_dest= '/u01/app/oracle'
*.fal_server='repprod1_pri','repprod2_pri'
*.fal_client='repproddg_stb'$sqlplus/ assysdba
SQL> startup pfile='/u01/app/oracle/product/11.2.0/db_1/dbs/initrepproddg.ora'nomount;
SQL> create spfile frompfile
SQL> shut immediate
1.3.6 恢复备库
#备库恢复控制文件
SQL>startup nomount;
RMAN> restore standby controlfile from '/oradata/backup/20180418_REPPROD_4020_1.ctl';
RMAN> alter databasemount;
#注册备份集
RMAN> CATALOG START WITH ‘/oradata/backup/’;
RMAN> CROSSCHECK BACKUP;
rman target/run
{set newname for datafile 1 to '/oradata/datafile/system01.dbf';set newname for datafile 2 to '/oradata/datafile/sysaux01.dbf';set newname for datafile 3 to '/oradata/datafile/undotbs01.dbf';set newname for datafile 4 to '/oradata/datafile/undotbs02.dbf';set newname for datafile 5 to '/oradata/datafile/users01.dbf';set newname for datafile 6 to '/oradata/datafile/bylgt01.dbf';set newname for tempfile 1 to '/oradata/tempfile/temp01.dbf';restore database;
SWITCH DATAFILEALL;
SWITCH TEMPFILEALL;
}
#把归档从主库中copy到备库后,进行手工recover
#根据备库alter.log查看缺失的日志sequence号
#节点二上从ASM上copy归档到本地再scp至备库
$su – grid
$asmcmd
ASMCMD> cd +ARCDG/repprod/AR*/2018_04_18ASMCMD> cp thread_2_seq_3741.2001.973785643 /oracle/backupASMCMD> cp thread_2_seq_3742.2012.973785651 /oracle/backupASMCMD> cp thread_2_seq_3743.2015.973785659 /oracle/backupASMCMD> cp thread_2_seq_3744.1987.973785669 /oracle/backupASMCMD> cp thread_2_seq_3745.2008.973785709 /oracle/backupASMCMD> cp thread_2_seq_3746.1977.973785717 /oracle/backupASMCMD> cp thread_2_seq_3747.1996.973791733 /oracle/backupASMCMD> cp thread_2_seq_3748.2005.973791739 /oracle/backup$cd/oracle/backup$ scp thread_2_seq* oracle@10.10.10.191:/oradata/arch
#备库上注册归档并recoverdatabaseSQL> alter database register logfile '/oradata/arch/thread_2_seq_3741.2001.973785643';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3742.2012.973785651';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3743.2015.973785659';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3744.1987.973785669';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3745.2008.973785709';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3746.1977.973785717';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3747.1996.973791733';
SQL> alter database register logfile '/oradata/arch/thread_2_seq_3748.2005.973791739';
SQL> recover managed standby database disconnect fromsession;
Media recovery complete.
SQL> recover managed standby databasecancel;
Media recovery complete.
1.3.7 在主库中建立standby logfile
#最大保护及最高可用性保护模式必须创建SRL,但强烈建议也为最大性能模式添加,为了简化切换以后的操作,建议同时在主库也进行添加。SRL大小必须跟主数据库ORL一样,且比ORL数量多1。
具体可参考“thread数*(ORL+1)”,即两节点的rac,ORL为3,则SRL数量为2*(3+1)=8。配置主数据库standby redo日志,在节点一或节点二进行:
SQL> alter database add standby logfile thread 1('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 1('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 1('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 1('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 2('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 2('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 2('+ARCDG','+DATADG') size 512M;
SQL> alter database add standby logfile thread 2('+ARCDG','+DATADG') size 512M;
1.3.8 在备库中建立standby logfile
#与主库一样的redo组
SQL> alter database add standby logfile group 7 ('/oradata/onlinelog/redo7a.dbf','/oradata/onlinelog/redo7b.dbf') size 512m;
SQL> alter database add standby logfile group 8 ('/oradata/onlinelog/redo8a.dbf','/oradata/onlinelog/redo8b.dbf') size 512m;
SQL> alter database add standby logfile group 9 ('/oradata/onlinelog/redo9a.dbf','/oradata/onlinelog/redo9b.dbf') size 512m;
SQL> alter database add standby logfile group 10 ('/oradata/onlinelog/redo10a.dbf','/oradata/onlinelog/redo10b.dbf') size 512m;
SQL> alter database add standby logfile group 11 ('/oradata/onlinelog/redo11a.dbf','/oradata/onlinelog/redo11b.dbf') size 512m;
SQL> alter database add standby logfile group 12 ('/oradata/onlinelog/redo12a.dbf','/oradata/onlinelog/redo12b.dbf') size 512m;
SQL> alter database add standby logfile group 13 ('/oradata/onlinelog/redo13a.dbf','/oradata/onlinelog/redo13b.dbf') size 512m;
SQL> alter database add standby logfile group 14 ('/oradata/onlinelog/redo14a.dbf','/oradata/onlinelog/redo14b.dbf') size 512m;
1.3.9 备库上监听和TNS配置
#配置监听
$cd $ORACLE_HOME/network/admin
$vi listener.ora
repproddg=(DESCRIPTION_LIST=(DESCRIPTION=(ADDRESS= (PROTOCOL = TCP)(HOST = 10.10.10.191)(PORT = 1521))
(ADDRESS= (PROTOCOL = IPC)(KEY =EXTPROC0))
)
)
SID_LIST_repproddg=(SID_LIST=(SID_DESC=(SID_NAME=repproddg)
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1)
#(PROGRAM=extproc)
)
)
#配置TNS
$vi tnsname.ora
repprod_pri=(DESCRIPTION=(ADDRESS= (PROTOCOL = TCP)(HOST =10.10.10.140)(PORT = 1521))
(CONNECT_DATA=(SERVER=DEDICATED)
(SERVICE_NAME =repprod)
)
)repproddg_stb=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS= (PROTOCOL = TCP)(HOST =10.10.10.191)(PORT = 1521))
)
(CONNECT_DATA=(SERVICE_NAME=repproddg)
)
)
#开启监听
$lsnrctl statrt
1.3.10 主库上TNS配置
#将以下备库的tns加入到主库两节点的tnsnames.ora中:
$cd $ORACLE_HOME/network/admin
$vi tnsnames.ora
repprod_pri=(DESCRIPTION=(ADDRESS= (PROTOCOL = TCP)(HOST =10.10.10.141)(PORT = 1521))
(CONNECT_DATA=(SERVER=DEDICATED)
(SERVICE_NAME =repprod)
)
)repproddg_stb=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS= (PROTOCOL = TCP)(HOST =10.10.10.191)(PORT = 1521))
)
(CONNECT_DATA=(SERVICE_NAME=repproddg)
)
)
监听和TNS检查
#在主库两节点上执行以下:
$tnsping repproddg_stb
#在备库中执行以下:
$tnsping repprod_pri
1.3.11 主库上修改参数
#节点一、节点二均设置以下参数
SQL> alter system set log_archive_config='DG_CONFIG=(repprod,repproddg)' scope=both sid='*';
SQL> alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(all_logfiles,all_roles) db_unique_name=repprod' scope=both sid='*';
SQL> alter system set log_archive_dest_2='SERVICE=repproddg_stb lgwr ASYNC NOAFFIRM VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=repproddg' scope=both;
SQL> alter system set log_archive_max_processes=10 scope=both;
SQL> alter system set db_file_name_convert='/oradata/datafile', '+DATADG/repprod/datafile', 'oradata/tempfile', '+DATADG/repprod/tempfile' scope=spfile;
SQL> alter system set log_file_name_convert='/oradata/onlinelog','+ARCDG/repprod/onlinelog','/oradata/onlinelog','+DATADG/repprod/onlinelog' scope=spfile;
SQL> alter system set standby_file_management=auto scope=both;
1.3.12 打开数据库并实时应用redo
#开启数据库并打卡redo日志实时应用
SQL> alter database open;
SQL> alter database recover managed standby database using current logfile disconnect from session;
二、 *实施完成后的验证
#主库检查current sequence#
SQL> select thread#,sequence#,status from v$log;
#主库检查LNS进程正在写的sequence#
SQL> select process,sequence#,status fromv$managed_standby;
#备库检查正在应用的sequence#
SQL> SELECT PROCESS,THREAD#,SEQUENCE#,STATUS FROMV$MANAGED_STANDBY;
#检查是否存在GAP
SQL> SELECT THREAD#,LOW_SEQUENCE#,HIGH_SEQUENCE# FROMV$ARCHIVE_GAP;
no rows selected
三、 问题汇总
3.1 备库未打补丁处理
1.传递与主库一致的补丁p24006111_112040_Linux-x86-64.zip至/software上
2.关闭与Oracle相关的所有进程,包括sqlplus
3.opatch version必须大于11.2.0.3.64.检查环境
unzip p24006111_112040_ Linux-x86-64.zip
cd24006111$ORACLE_HOME/OPatch/opatch prereq CheckConflictAgainstOHWithDetail -ph ./
5.应用补丁
$ORACLE_HOME/OPatch/opatch apply
3.2 Temp文件错误处理
1.恢复时set newname路径错误
2.将tempfile下线:
SQL> alter database tempfile '/oradata/tempile/temp01.dbf'offline;
3.新建正确路径的tempfile:
SQL> alter tablespace TEMP add tempfile '/oradata/tempfile/temp01.dbf' size 2G autoextend on;
4.删除错误tempfile
SQL> alter database tempfile '/oradata/tempile/temp01.dbf' drop
3.3 归档删除脚本部署
#在/home/oracle/下新建归档删除脚本,保留3天
$ vi/home/oracle/delete_arch.sh
.~/.bash_profile
rman target/ <
crosscheck archivelogall;delete noprompt archivelog until time 'sysdate-3';
crosscheck archivelogall;exitEOF
#Oracle crontab,每天0点自动删除归档文件
$crontab-e
#每天0点自动删除归档文件0 * * * * /home/oracle/delete_arch.sh 1>/home/oracle/delete_arch.sh.out 2>&1
SERVICE_NAME=repproddg