Data Guard及ADG日常运维操作
从这期开始讲Oracle Data Guard方面的内容
Data Guard作为Oracle提供的一个高可用及灾备解决方案,理解并可以实施它对于DBA来说是非常重要套的技能
前面我们已经介绍了如何假设物理备库,今天介绍日常如何运维和如何开启ADG
1. Data Guard状态查看
1.1 查看归档路径信息
select dest_name,
status,
target,
ARCHIVER,
destination,
log_sequence,
valid_type,
valid_role
from V$ARCHIVE_DEST;
这个视图可以看到归档日志的一些配置信息
1.2 查看归档路径状态
select dest_name,
type,
database_mode,
recovery_mode,
protection_mode,
destination,
SRL,
GAP_STATUS
from V$ARCHIVE_DEST_STATUS;
这个视图的信息比上个更加的具体,包括保护模式,应用模式等
1.3 查看归档日志gap状态
select * from V$ARCHIVE_GAP;
1.4 查看数据库状态
select name,log_mode,open_mode,protection_mode
from V$DATABASE;
1.5 查看备库同步状态
select*
from V$DATAGUARD_STATS;
1.6 查看ORL日志状态
select * from V$LOG;
1.7 查看ORL及SRL状态
select * from V$LOGFILE;
1.8 查看SRL状态
select* from V$STANDBY_LOG;
这里UNASSIGNED是由于负载较轻导致
相关的视图简单介绍到这,具体请参见官方文档
https://docs.oracle.com/cd/E11882_01/server.112/e41134/views.htm#SBYDB01300
2. 主库保护模式切换
请确保备库处于同步状态
2.1 最大性能到最大可用*
alter database set standby database to maximize availability;
2.2 最大可用到最大保护
alter database set standby database to maximize protection;
2.3 向后切换
alter database set standby database to maximize availability;
alter database set standby database to maximize performance;
注意:不可直接从performance切换到 protection
3. 日常操作
3.1 关闭同步
SQL>alter database recover managed standby database cancel;
3.2 开启物理备库*
SQL>startup nomount;
SQL>alter database mount standby database;
3.2.1 实时同步
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;
3.2.2 非实时同步
SQL>alter database recover managed standby database disconnect from session;
3.2.2.1 延迟4小时同步
SQL>alter database recover managed standby database delay 240 disconnect from session;
3.2.2.2 取消延迟
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE NODELAY;
3.3 重新注册归档日志
有时备库的归档文件不是主库传输的而是手动拷贝过来的,需要注册才能够应用
SQL> ALTER DATABASE REGISTER LOGFILE '/oracle/NP1/oraarch/NP1arch/1_224744_671386971.dbf';
4. 开启ADG
Oracle 11g提供了ADG功能
让我们在物理备库处于Open read only状态时可以继续应用日志
4.1 关闭同步功能
如果处于同步状态需要先关闭
SQL> alter database recover managed standby database cancel;
4.2 只读方式打开备库
SQL> alter database open read only;
4.3 开启同步功能
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;
这时ADG已经开启,可以保证数据一致的情况下提供只读功能
5. 故障处理
5.1日志无法传输到备库
查询V$ARCHIVE_DEST视图看是否有错误,并查看alert日志
一般有如下情形
- tnsnames.ora配置不正确,请用tnsping查看是否能正确解析
- LOG_ARCHIVE_DEST_n service_name配置不正确
- LOG_ARCHIVE_DEST_STATE_n参数未设置成enable
- 监听配置不正确,请在主库上尝试连接备库
- 备库实例未启动,至少需要处于mount状态
- 密码文件不一致,请重新拷贝主库文件至备库
5.2 备库无法mount
备库的控制文件不能是如下形式
- 操作系统备份的
- 没有用stnadby关键字备份控制文件
好了,到这里我们讲了DG日常的一些运维操作,下一节讲如何进行switchover
- 【架构拾集】: Android 移动应用架构设计
- Dore 混合应用框架 —— 基于 React Native 的混合应用迁移方案
- Android6.0源码分析之View(二)--measure Android6.0源码分析之View(一)
- 程序员,2017年你的技能树上增加了哪些新技能?
- Android6.0源码分析之View(一)
- 2017 年,我挖的那些开源软件坑
- Android6.0蓝牙开发中获取附近低功耗蓝牙设备结果权限问题分析
- 我的技术投资策略:如何决定学习哪一个新技术的?
- 我的技术投资策略:如何决定学习哪一个新技术的?
- Android6.0源码之蓝牙研究汇总(一)--from初学者
- Android6.0蓝牙协议之OPP
- 简单直白教你理解Java中四大引用强引用,软引用,弱引用,虚引用
- ubuntu系统上配置git
- Android源码编译出错No rule to make...
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- ApplicationListener接口实践
- 浅谈vue+element全局loading加载
- LeetCode59|重复N次的元素
- 谈Vue组件的is特性
- 基于日志的回放对比系统设计
- 【收藏向】常用Java排错工具单
- MYSQL数据同步之基于GTID事务数据同步
- 【风险通告】XXL-JOB远程命令执行漏洞
- MySQL8.0特性之redo logging动态开关
- 3分钟短文:Laravel模型集合跟基类真不一样,别混为一谈
- 3分钟短文:Laravel模型一对一一对多关系真的乱吗?
- 3分钟短文:Laravel请求对象方法极多,可不是花拳绣腿
- 3分钟短文:Laravel验证用户输入,不要把啥都存到系统里
- 3分钟短文:Laravel用户自定义命令行简明教程
- 3分钟短文:Laravel命令行参数和可选项分不清?怎么可能!