ASM 管理的 Oracle 19C 数据库ADG的搭建及主备切换

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: -- 主备库Grid及Oracle Home 目录/u01/app/grid/product/19.0.0/gihome_1/u01/app/oraInventory/u01/app/oracle/product/19.

-- 主备库Grid及Oracle Home 目录

/u01/app/grid/product/19.0.0/gihome_1

/u01/app/oraInventory

/u01/app/oracle/product/19.0.0/dbhome_1


-- 主库开启强制日志模式、归档模式

SQL> alter database force logging;  

SQL> select force_logging from v$database; 


SQL> archive log list; 

SQL> shutdown immediate 

SQL> startup mount 

SQL> alter database archivelog; 

SQL> alter database open;  


SQL> alter system set sga_max_size=180G scope=spfile;

SQL> alter system set sga_target=180G scope=spfile;

SQL> alter system set pga_aggregate_target=30G scope=spfile;


-- 主库查询添加 stby redo logfile

SQL> select group#, members, bytes from v$log; 

SQL> select member from v$logfile; 


SQL> alter database add standby logfile group 7 ('+DATA') size 1G;

SQL> alter database add standby logfile group 8 ('+DATA') size 1G;

SQL> alter database add standby logfile group 9 ('+DATA') size 1G;

SQL> alter database add standby logfile group 10 ('+DATA') size 1G;

SQL> alter database add standby logfile group 11 ('+DATA') size 1G;

SQL> alter database add standby logfile group 12 ('+DATA') size 1G;

SQL> alter database add standby logfile group 13 ('+DATA') size 1G;


-- 分别在主备库配置监听并启动,直接使用 netmgr 工具生成 添加如下内容

$ vi listener.ora

-- prmy

SID_LIST_LISTENER =

 (SID_LIST =

    (SID_DESC =

      (GLOBAL_DBNAME = ynsb)

      (ORACLE_HOME =/u01/app/oracle/product/19.0.0/dbhome_1)

      (SID_NAME = ynsb)

    )

 )

-- stby

SID_LIST_LISTENER =

 (SID_LIST =

    (SID_DESC =

      (GLOBAL_DBNAME = ynsbsby)

      (ORACLE_HOME =/u01/app/oracle/product/19.0.0/dbhome_1)

      (SID_NAME = ynsbsby)

    )

 )

$ lsnrctl reload


-- 主备库配置 tnsnames.ora 内容如下

$ vi tnsnames.ora 

LISTENER_YNSB =

  (ADDRESS = (PROTOCOL = TCP)(HOST = sjz)(PORT = 1521))


YNSB =

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = sjz)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = ynsb)

    )

  )

  

YNSBSBY =

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = sjz)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = ynsbsby)

    )

  )

-- 配置好后拷贝到备库

$ scp $ORACLE_HOME/network/admin/ * oracle@172.30.2.54:$ORACLE_HOME/network/admin/


-- 在备库创建必要的目录,参考主库的pfile中的路径:

$ mkdir -p /u01/app/oracle/fast_recovery_area

$ mkdir -p /u01/app/oracle/oradata/... ... 

$ mkdir -p /u01/app/oracle/admin/ynsb/adump


ASMCMD> cd +DATA

ASMCMD> mkdir YNSBSBY

ASMCMD> cd YNSBSBY

ASMCMD> mkdir DATAFILE

ASMCMD> mkdir CONTROLFILE

ASMCMD> mkdir ONLINELOG

ASMCMD> mkdir PARAMETERFILE

ASMCMD> mkdir TEMPFILE


-- 主库创建 pfile 文件并修改 pfile 如下参数

*.DB_NAME='ynsb'

*.DB_UNIQUE_NAME='ynsb'

alter system set standby_file_management='AUTO';

alter system set LOG_ARCHIVE_CONFIG='DG_CONFIG=(ynsb,ynsbsby)'; -- DB_UNIQUE_NAME

alter system set LOG_ARCHIVE_DEST_1='LOCATION=/arch/archive_log/ VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=ynsb';

alter system set LOG_ARCHIVE_DEST_2='SERVICE=YNSBSBY VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) LGWR AFFIRM SYNC DB_UNIQUE_NAME=ynsbsby';

*.LOG_ARCHIVE_DEST_STATE_1='ENABLE'

*.LOG_ARCHIVE_DEST_STATE_2='ENABLE'

*.LOG_ARCHIVE_FORMAT=%t_%s_%r.arc

*.REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE

*.archive_lag_target=1800

*.LOG_ARCHIVE_MAX_PROCESSES=30

-- TNSNAME

alter system set FAL_SERVER='YNSB';

alter system set FAL_CLIENT='YNSBSBY';

alter system set LOG_FILE_NAME_CONVERT='/arch/archive_log/','/arch/archive_log/' scope=spfile;

alter system set DB_FILE_NAME_CONVERT='+DATA/YNSB/DATAFILE/','+DATA/YNSBSBY/DATAFILE/','+DATA/YNSB/TEMPFILE/','+DATA/YNSBSBY/TEMPFILE/' scope=spfile;


-- 将主库的口令文件及修改后的参数文件copy到备库

$ scp /home/oracle/temp.ora oracle@192.168.1.101:/home/oracle/temp.ora

$ scp $ORACLE_HOME/dbs/orapwdprmy oracle@192.168.1.101:$ORACLE_HOME/dbs/orapwdstby


-- 主库的参数文件copy到备库并修改如下参数

*.db_unique_name='ynsbsby'

*.log_archive_config='dg_config=(ynsb,ynsbsby)'

*.log_archive_dest_1='location=/arch/archive_log/ valid_for=(all_logfiles,all_roles) db_unique_name=ynsbsby'

*.log_archive_dest_2='service=YNSB valid_for=(online_logfiles,PRIMARY_ROLE) lgwr affirm sync db_unique_name=ynsb'

*.log_archive_dest_state_1=enable

*.log_archive_dest_state_2=enable

*.standby_file_management='auto'

*.fal_server='YNSB' -- TNSNAME

*.fal_client='YNSBSBY'


-- 用新参数重启主数据库:

SQL> shutdown immediate 

SQL> create spfile from pfile;

SQL> startup 

SQL> alter pluggable database pdborcl open;

 

-- 用 spfile 将备库启动到nomount 状态

SQL> startup nomount pfile='/home/oracle/temp.ora'

SQL> create spfile='+DATA/YNSBSBY/PARAMETERFILE/spfileynsbsby.ora' from pfile='/home/oracle/temp.ora';

SQL> shutdown immediate 


-- 添加注册数据库到 ASM 中

$ srvctl add database -db ynsbsby -o /u01/app/oracle/product/19.0/db_1

$ srvctl modify database -db ynsbsby -role physical_standby -spfile '+DATA/YNSBSBY/PARAMETERFILE/spfileynsbsby.ora'


-- 开始进行 Active duplicate, 执行完毕后,数据库自动进入mount状态

$ rman target sys/oracle123@YNSB auxiliary sys/oracle123@YNSBSBY;

RMAN> duplicate target database for standby from active database;


-- 主库配置

rman target /

CONFIGURE ARCHIVELOG DELETION POLICY TO applied on standby;


-- 打开备库并并启动 apply

SQL> select open_mode from v$database; 

SQL> alter database open;


-- 备库是只读的

-- 查看主备库 

SQL> select log_mode,open_mode ,database_role from v$database;


-- 备库启动 real-time apply:

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

SQL> select open_mode from v$database;


-- 验证DG

SQL> alter system switch logfile;


-- 主备切换

-- 正常切换:主库:

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

-- 备库:

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;


-- 主切备

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PHYSICAL standby;

SQL> startup nomount;

SQL> alter database mount standby database;

SQL> ALTER DATABASE RECOVER MANAGED standby DATABASE DISCONNECT FROM SESSION;


-- 备切主

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO primary;

SQL> select status from v$instance;

SQL> alter database open;


-- 打开备库

-- 注:如打开新备库出现如下错误的解决方式:

SQL> alter database open;

SQL> alter database recover managed standby database cancel;

SQL> alter database open;

SQL> alter database recover managed stby database using current logfile disconnect ; 

-- 注意:切换后验证DG


-- 主备启停

-- 先启动备库:

$ lsnrctl start

SQL> STARTUP MOUNT;

SQL> ALTER DATABASE OPEN READ ONLY;

SQL> ALTER DATABASE RECOVER MANAGED standby DATABASE DISCONNECT FROM SESSION;

-- 查看备库状态和模式

SQL> select name,open_mode,protection_mode,database_role from v$database;

-- 再启动主库:

$ lsnrctl start

SQL> startup


-- 查看主库状态和模式:

SQL> select name,open_mode,protection_mode,database_role from v$database;

-- 在主库归档当前日志:

SQL> alter system archive log current;


-- 监控备库:

-- 查看stby库的log_archive_dest_1下应该有archive产生。

-- 查寻v$archived_log,有新的日志记录出现。最大sequence#,应该为主库v$log中current状态日志的序列号减一。

SQL>select sequence#,applied,first_time,next_time,resetlogs_change#,completion_time from v$archived_log order by sequence#;

-- 查看服务是否启动:

SQL> select process,status,client_process,sequence#,BLOCK# from v$managed_standby;

-- 查看是否有遗漏的归档日志

SQL> select * from v$archive_gap;


-- 关闭 dataguard

-- 先关闭主库:

SQL> alter system archive log current;

SQL>SHUTDOWN IMMEDIATE;

-- 再关闭备库:

SQL> ALTER DATABASE RECOVER MANAGED standby DATABASE CANCEL;

SQL>SHUTDOWN IMMEDIATE;

目录
相关文章
|
3月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
371 93
|
2月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】使用NetManager创建Oracle数据库的监听器
Oracle NetManager是数据库网络配置工具,用于创建监听器、配置服务命名与网络连接,支持多数据库共享监听,确保客户端与服务器通信顺畅。
209 0
|
5月前
|
存储 Oracle 关系型数据库
服务器数据恢复—光纤存储上oracle数据库数据恢复案例
一台光纤服务器存储上有16块FC硬盘,上层部署了Oracle数据库。服务器存储前面板2个硬盘指示灯显示异常,存储映射到linux操作系统上的卷挂载不上,业务中断。 通过storage manager查看存储状态,发现逻辑卷状态失败。再查看物理磁盘状态,发现其中一块盘报告“警告”,硬盘指示灯显示异常的2块盘报告“失败”。 将当前存储的完整日志状态备份下来,解析备份出来的存储日志并获得了关于逻辑卷结构的部分信息。
|
3月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
317 8
|
5月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
280 11
|
5月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—服务器异常断电导致Oracle数据库报错的数据恢复案例
Oracle数据库故障: 某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库没有备份,仅有一些断断续续的归档日志。 Oracle数据库恢复流程: 1、检测数据库故障情况; 2、尝试挂起并修复数据库; 3、解析数据库文件; 4、导出并验证恢复的数据库文件。
|
5月前
|
存储 Oracle 关系型数据库
【赵渝强老师】Oracle RMAN的目录数据库
Oracle RMAN默认将备份元信息存储在控制文件中,但控制文件损坏或丢失会导致恢复失败,且备份增多会使控制文件无限增长。为解决这些问题,Oracle引入了RMAN目录数据库(Catalog Database),专门用于存储RMAN备份的元信息。使用目录数据库可提升备份管理效率,支持多数据库共享、长期备份历史记录存储,并可保存RMAN脚本。本文详细介绍了如何创建目录数据库、注册目标数据库及其操作步骤。
148 0
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
157 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。

热门文章

最新文章

推荐镜像

更多