Oracle RAC+ADG集群配置

主库配置:

hostname	node1.neves.com	             node2.neves.com
Public IP	80.8.29.1	                 80.8.29.2
Virtual IP	10.20.89.1	                 10.20.89.2
Instance	racdb1	                     racdb2
DB name	                        racdb
DATA file	                    +DATA/racdb/datafile/
Control file	                +DATA/racdb/controlfile/
                                +FRA/racdb/controlfile/
Redo Log file	       		    +DATA/racdb/onlinelog/
                                +FRA/racdb/onlinelog/
db_unique_name	                racdb
service_names	                racdb.neves.com
Oracle_Version	                11.2.0.4.0

备库配置:

hostname	          	    adg.neves.com
IP	                        80.8.29.50
Oracle_version	   			11.2.0.4.0
Instance	                stddb
DB name	                	racdb
DB_unique_name				stddb
service_names				stddb.neves.com
DATA file	           	    /u01/app/oracle/oradata/stddb/
Control file	            /u01/app/oracle/oradata/stddb/
Redo Log file	            /u01/app/oracle/oradata/stddb/
                            /u01/app/oracle/oradata/arclog/
此arclog不是存放归档日志的,
只是按照RAC中两个不同的日志组路径,对应设置的。

查看集群资源情况:

[grid@node1 ~]$ crsctl status res -t
确保资源online状态。
SQL> show parameter spfile;
NAME				     TYPE	 VALUE
------------------------------------ ----------- ------------------------------
spfile				     string	 +DATA/racdb/spfileracdb.ora

修改RAC参数文件:

SQL> create pfile='/home/oracle/racdbpfile' from spfile='+DATA/racdb/spfileracdb.ora'

RAC主库参数文件:

racdb1.__db_cache_size=276824064
racdb2.__db_cache_size=289406976
racdb1.__java_pool_size=4194304
racdb2.__java_pool_size=4194304
racdb1.__large_pool_size=8388608
racdb2.__large_pool_size=8388608
racdb1.__pga_aggregate_target=348127232
racdb2.__pga_aggregate_target=335544320
racdb1.__sga_target=486539264
racdb2.__sga_target=499122176
racdb1.__shared_io_pool_size=0
racdb2.__shared_io_pool_size=0
racdb1.__shared_pool_size=188743680
racdb2.__shared_pool_size=188743680
racdb1.__streams_pool_size=0
racdb2.__streams_pool_size=0
*.audit_file_dest='/u01/app/oracle/admin/racdb/adump'
*.audit_trail='DB'
*.cluster_database=true
*.compatible='11.2.0.0.0'
*.control_files='+DATA/racdb/controlfile/current.260.1037590513','+FRA/racdb/controlfile/current.256.1037590515'
*.db_block_size=8192
*.db_create_file_dest='+DATA'
*.db_domain='neves.com'
*.db_name='racdb'
*.db_recovery_file_dest='+FRA'
*.db_recovery_file_dest_size=4558159872
*.diagnostic_dest='/u01/app/oracle'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=racdbXDB)'
*.event=''
racdb1.instance_number=1
racdb2.instance_number=2
*.log_archive_format='%t_%s_%r.dbf'
*.memory_target=834666496
*.open_cursors=300
*.processes=150
*.remote_listener='rac-scan.neves.com:1521'
*.remote_login_passwordfile='EXCLUSIVE'
racdb1.thread=1
racdb2.thread=2
racdb1.undo_tablespace='UNDOTBS1'
racdb2.undo_tablespace='UNDOTBS2'

db_unique_name=racdb
log_archive_config='DG_CONFIG=(racdb,stddb)'
log_archive_dest_1 = 'LOCATION=/u01/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=racdb'
log_archive_dest_2 = 'SERVICE=stddb LGWR SYNC AFFIRM VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=stddb'
log_archive_dest_state_1=enable
log_archive_dest_state_2=enable
db_file_name_convert='+DATA/racdb/datafile/','/u01/app/oracle/oradata/stddb/'
log_file_name_convert='+DATA/racdb/onlinelog/','/u01/app/oracle/oradata/stddb/'
standby_file_management=AUTO
FAL_SERVER=stddb
racdb1.fal_client=racdb1
racdb2.fal_client=racdb2

关闭RAC两节点实例:

[oracle@node1 ~]$ srvctl stop database -d racdb
SQL>create spfile='+DATA/racdb/spfileracdb.ora' from pfile='/home/oracle/racdbpfile'

启动RAC两节点实例:
[oracle@node1 ~]$ srvctl start database -d racdb

查看关键参数是否生效:
log_file_name_convert
db_file_name_convert
FAL_SERVER
log_archive_dest_1
log_archive_dest_2
Service_name

备库参数:
stddb.__db_cache_size=352321536
stddb.__java_pool_size=4194304
stddb.__large_pool_size=8388608
stddb.__oracle_base='/u01/app/oracle'#ORACLE_BASE set from environment
stddb.__pga_aggregate_target=335544320
stddb.__sga_target=503316480
stddb.__shared_io_pool_size=0
stddb.__shared_pool_size=125829120
stddb.__streams_pool_size=0
*.audit_file_dest='/u01/app/oracle/admin/stddb/adump'
*.audit_trail='db'
*.compatible='11.2.0.4.0'
*.control_files='/u01/app/oracle/oradata/stddb/control01.ctl','/u01/app/oracle/oradata/stddb/control02.ctl'
*.db_block_size=8192
*.db_domain='neves.com'
*.db_name='racdb'
*.db_recovery_file_dest='/u01/app/oracle/fast_recovery_area'
*.db_recovery_file_dest_size=4385144832
*.diagnostic_dest='/u01/app/oracle'
*.memory_target=838860800
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.sessions=170
*.undo_tablespace='UNDOTBS1'

db_unique_name='stddb'
log_archive_config='DG_CONFIG=(racdb,stddb)'
log_archive_dest_1 = 'LOCATION=/u01/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=stddb'
log_archive_dest_2 = 'SERVICE=racdb1 LGWR SYNC AFFIRM VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=racdb'
log_archive_dest_state_1=enable
log_archive_dest_state_2=enable
db_file_name_convert='+DATA/racdb/datafile/','/u01/app/oracle/oradata/stddb/'
log_file_name_convert='+DATA/racdb/onlinelog/','/u01/app/oracle/oradata/stddb/','+FRA/racdb/onlinelog/','/u01/app/oracle/oradata/arclog/'
standby_file_management=AUTO
FAL_SERVER='racdb1','racdb2'
fal_client='stddb'

主库.备库tnsnames.ora:

racdb1 =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 80.8.29.1)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = racdb.neves.com)
    )
  )
racdb2 =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 80.8.29.2)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = racdb.neves.com)
    )
  )
stddb =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 80.8.29.50)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = stddb.neves.com)
    )
  )

备库需要配置静态注册:
nomount为block状态下,只有配置静态注册可以连接。
Listener.ora

SID_LIST_LISTENER =
(SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = stddb.neves.com)
      (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_home1)
      (SID_NAME = stddb)
    )
  )

LISTENER =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = adg.neves.com)(PORT = 1521))
  )

将备库启动为nomount状态
SYS@stddb>Start nomout

在主库添加standby redolog:

SQL> select group#,thread#,members,bytes from v$log;
    GROUP#    THREAD#	   MEMBERS     BYTES
	 1	         1	           2         52428800
	 2	         1	           2         52428800
	 3	         2	           2         52428800
	 4	         2	           2         52428800

在主库添加standby redolog:
alter database add standby logfile thread 1 group 5 ‘+DATA/racdb/onlinelog/group_5.1’ size 50M

alter database add standby logfile thread 1 group 6 ‘+DATA/racdb/onlinelog/group_6.1’ size 50M

alter database add standby logfile thread 1 group 7 ‘+DATA/racdb/onlinelog/group_7.1’ size 50M

alter database add standby logfile thread 2 group 8 ‘+DATA/racdb/onlinelog/group_8.1’ size 50M

alter database add standby logfile thread 2 group 9 ‘+DATA/racdb/onlinelog/group_9.1’ size 50M

alter database add standby logfile thread 2 group 10 ‘+DATA/racdb/onlinelog/group_10.1’ size 50M


SQL> select group#,status,type from v$logfile;     

    GROUP# STATUS  TYPE
---------- ------- -------
	 1	   ONLINE
	 1	   ONLINE
	 2	   ONLINE
	 2	   ONLINE
	 3	   ONLINE
	 3	   ONLINE
	 4	   ONLINE
	 4	   ONLINE
	 5	   STANDBY
	 6	   STANDBY
	 7	   STANDBY

    GROUP# STATUS  TYPE
---------- ------- -------
	 8	   STANDBY
	 9	   STANDBY
	10	   STANDBY





SQL> select group#,thread# from v$standby_log;

    GROUP#    THREAD#
---------- ----------
	 5	        1
	 6	        1
	 7	        1
	 8	        2
	 9	        2
	10	    2
在主库添加standby database的原因:
1.在duplicate命令复制到standby database后,所有的standby redo会被复制到备库。
2.角色切换时,需要在主库生成standby log,也是为了减少角色切换的时间。

进行主库备份:

[oracle@node1 ~]$ rman target /
connected to target database: RACDB (DBID=1035207281)

RMAN> backup as compressed backupset database include current controlfile for standby;

[oracle@node1 ~]$ rman target sys/oracle@racdb1 auxiliary sys/oracle@stddb

RMAN> duplicate target database for standby from active database nofilenamecheck

查看主库归档信息:

SQL> archive log list;
Database log mode	       Archive Mode
Automatic archival	       Enabled
Archive destination	       /u01/archivelog
Oldest online log sequence     110
Next log sequence to archive   111
Current log sequence	       111

查看备库归档信息:

SYS@stddb>select instance_name,status from v$instance;

INSTANCE_NAME	 STATUS
---------------- ------------
stddb		 MOUNTED

SYS@stddb>archive log list;
Database log mode	       Archive Mode
Automatic archival	       Enabled
Archive destination	       /u01/archivelog
Oldest online log sequence     111
Next log sequence to archive   0
Current log sequence	       111

进行主库日志切换,查看备库是否归档。

SYS@stddb>archive log list;
Database log mode	       Archive Mode
Automatic archival	       Enabled
Archive destination	       /u01/archivelog
Oldest online log sequence     111
Next log sequence to archive   0
Current log sequence	       112

启动日志应用服务:

SYS@stddb>alter database recover managed standby database disconnect from session; 

SYS@stddb>alter database recover managed standby database using current logfile disconnect from session;


SYS@stddb>select group#,thread#,status,sequence# from v$standby_log;

    GROUP#    THREAD# STATUS	  SEQUENCE#
---------- ---------- ---------- ----------
	 5	    1 ACTIVE		119
	 6	    1 UNASSIGNED	  0
	 7	    1 UNASSIGNED	  0
	 8	    2 ACTIVE		 57
	 9	    2 UNASSIGNED	  0
	10	    2 UNASSIGNED	  0




SYS@stddb>select process,client_process,status,sequence# from v$managed_standby;

PROCESS   CLIENT_P STATUS	 SEQUENCE#
--------- -------- ------------ ----------
ARCH	  ARCH	   CLOSING			56
ARCH	  ARCH	   CLOSING	       117
ARCH	  ARCH	   CONNECTED		 0
ARCH	  ARCH	   CLOSING	       118
RFS	 	  ARCH	   IDLE 		 	 0
RFS	 	  ARCH	   IDLE 		 	 0
RFS	 	  UNKNOWN  IDLE 			 0
RFS	 	  UNKNOWN  IDLE 		   	 0
RFS	 	  UNKNOWN  IDLE 		   	 0
RFS	 	  UNKNOWN  IDLE 		     0
RFS	  	  LGWR	   IDLE 			57
PROCESS   CLIENT_P STATUS	 SEQUENCE#
--------- -------- ------------ ----------
RFS	  	  LGWR	   IDLE 	       119
MRP0	  N/A	   WAIT_FOR_LOG 	57

select dest_id,dest_name,target,status from v$archive_Dest;
DEST_ID DEST_NAME		TARGET	STATUS
---------- -------------------- ------- ---------
	 1 LOG_ARCHIVE_DEST_1	PRIMARY VALID
	 2 LOG_ARCHIVE_DEST_2	STANDBY VALID


RAC集群双节点搭建DG与单实例的主要区别:
日志线程从单线程变为双线程
会同时接收以及应用两个节点的重做日志信息。

与DG相关的动态性能视图:

V$archived_log
V$archive_dest_status
V$archive_dest
V$managed_standby
V$standby_log
V$database
V$dataguard_status

你可能感兴趣的:(数据库,linux,运维,oracle,centos)