DG怎样手动切主从-用普通命令方式(不用dg broker)

这里主库是orcl,从库是orclstd

一 将主库降为从库

1.1查看主库SWITCHOVER_STATUS的状态

#确认主库是否可以做switchover

#不能切换的情况

SQL>SELECT SWITCHOVER_STATUS FROM V$DATABASE;

SWITCHOVER_STATUS

------------------

SESSIONS ACTIVE

在这种情况下,说明还有活动session,需要先kill掉,只留下当前sys进程

select sid,SERIAL# from v$session;

SID SERIAL#

---------- ----------

12 14

17 3

查出当前连接session

SQL> select distinct ss.sid from v$mystat ss;

杀掉其他session ,示例

SQL> alter system kill session '12,14';

#可以切换的情况:

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

SWITCHOVER_STATUS

--------------------

TO STANDBY

1.2 将主库切换至备用模式

SQL> alter database commit to switchover to physical standby with session shutdown;

假如报错:

ORA-16416: 没有可行的 Physical Standby切换目标

则检查下主从的log_archive_dest_2值是否为空,如果为空,需要设置

示例:

show parameter log_archive_dest_2;

alter system set  log_archive_dest_2='service=orclstd valid_for=(online_logfiles,primary_role) db_unique_name=orclstd' scope=both ;

1.3关闭主数据库将其启动到mount状态

SQL> shutdown abort;

SQL> startup mount;

二 将从库提升为主库

2.1 查看备库SWITCHOVER_STATUS状态

SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE;

SWITCHOVER_STATUS

-----------------

TO PRIMARY

注:如果是TO PRIMARY表示可以正常切换,不过还会遇到NOT ALLOWED和PENDING或者LATENT,实际操作下来如果备库的switchover_status为not allowed或者to primary都可以正常切换。假如是RECOVERY NEEDED,则执行下alter database recover managed standby database using current logfile disconnect from session;否则后面切换至主库的时候会报错:

ORA-16139: 需要介质恢复

2.2 将备库切为主库

SQL> alter database commit to switchover to primary with session shutdown;

2.3 打开新的主数据库

SQL> ALTER DATABASE OPEN;

#查看状态,确保open_mode是READ WRITE,DATABASE_ROLE是primary

select open_mode,database_role from v$database;

OPEN_MODE            DATABASE_ROLE

-------------------- ----------------

READ WRITE           PRIMARY

原主库/新的备库上启动 REDO apply

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

假如报错:

ORA-01153: 激活了不兼容的介质恢复,则先启动数据库到open状态,再执行该命令,试下。

#启动数据库

alter database open;

#检查状态,确保open_mode值是READ ONLY WITH APPLY,database_role是PHYSICAL STANDBY

select open_mode,database_role from v$database;

假如open_mode值是read only,不是read only with apply,则再应用一次redo试下:

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

select open_mode,database_role from v$database;

四 检查主从的log_archive_dest_2是否为空

#检查主从的log_archive_dest_2值是否为空,如果为空,需要设置

示例:

show parameter log_archive_dest_2;

alter system set  log_archive_dest_2='service=orclstd valid_for=(online_logfiles,primary_role) db_unique_name=orclstd' scope=both ;

五 验证数据同步

在主库插入一条数据,看能否同步到从库上。

如果不能,则做以下检查。

5.1 检查主从log_archive_dest_state_nlog_archive_dest_2状态

需要确保log_archive_dest_state_1/2的状态是ENABLE。我遇到过一次状态是RESET,导致主库的归档日志无法传输到备库上。

show parameter log_archive_dest_state_1;

show parameter log_archive_dest_state_2; 

#检查主从的log_archive_dest_2值是否为空,如果为空,需要设置

示例:

show parameter log_archive_dest_2;

alter system set  log_archive_dest_2='service=orclstd valid_for=(online_logfiles,primary_role) db_unique_name=orclstd' scope=both ;

5.2 检查从库standby log的状态是否正常

SQL> select group#,sequence#,first_change#,next_change#,status,used from  v$standby_log;

如果都为UNASSIGNED,则说明备库异常,是active状态方为正常。

5.3 检查告警日志有何报错

假如报FAL[client]: Error fetching gap sequence, no FAL server specifie,则需要配置fal_server

5.4 检查主库中归档位置配置是否有误

select error from v$archive_dest where target='STANDBY';

5.5 检查DG状态

SELECT MESSAGE FROM V$DATAGUARD_STATUS;

5.6 检查主库的switchover_status

SQL> select switchover_status from v$database ;

SWITCHOVER_STATUS

----------------------------------------

TO STANDBY

如果结果为FAILED DESTINATION,则不正常,需要检查下主备的告警日志,排查下原因。

5.7 检查主库归档日志能否实时同步到备库

5.7.1 查看备库现有归档日志

SQL> SELECT SEQUENCE#, FIRST_TIME, NEXT_TIME  FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#;

 SEQUENCE# FIRST_TIME NEXT_TIME

---------- ------------ ------------

 6 08-NOV-19 08-NOV-19

 7 08-NOV-19 08-NOV-19

 8 08-NOV-19 08-NOV-19

 8 08-NOV-19 08-NOV-19

5.7.2 在主库上切换日志

SQL> ALTER SYSTEM SWITCH LOGFILE;

5.7.3 检查备库是否能接收到新产生的归档日志并应用

SQL>  SELECT SEQUENCE#,APPLIED FROM V$ARCHIVED_LOG  ORDER BY SEQUENCE#;

SEQUENCE# APPLIED

---------- ------------------

 6 YES

 7 YES

 8 YES

 8 YES

最近收到的日志文件的APPLIED列的值将是IN-MEMORY,如果该日志文件已应用,则为YES。

六 确保程序里连接的是新主库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/821298.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

别踩白块web小游戏

整体思路 1.设置一个游戏界面main(最外面一圈方框) 2.main内部放置一个容器container,容器非常长,且容器底部位于main的顶部 3.将容器内的黑块和白块事先处理好,并将黑块存储在黑块数组中 容器黑白块处理&#xf…

【开发问题记录】Nacos修改服务实例权重时报错

问题记录 一、问题描述1.1 产生原因1.2 产生问题 二、问题解决2.1 docker部署的nacos解决方案2.1.1 进入nacos容器2.1.2 查看当前目录2.1.3 进入data文件夹2.1.4 删除protocol文件2.2 本地部署的nacos 一、问题描述 1.1 产生原因 在运行项目时,在本地启动了一个服务…

vue3项目 使用 element-plus 中 el-collapse 折叠面板

最近接触拉了一个项目,使用到 element-plus 中 el-collapse 折叠面板,发现在使用中利用高官网多多少少的会出现问题。 (1.直接默认一个展开值,发现时显时不显 2 . 数据渲染问题,接口请求了,页面数据不更新 …

js 截取指定字符后面/前面的所有字符串...

项目场景 在 JavaScript 中,你可以使用 substring() 或 substr() 方法来截取字符串中指定字符前面或后面的所有字符。 再配合**indexOf()**方法来判断字符所在的位置从而实现截取指定字符的前后字符串 解决方案: //js 截取指定字符后面/前面的所有字…

类激活映射详解

类激活映射(CAM, Class Activation Mapping)是一种常用于卷积神经网络(CNN)的技术,用来识别和解释模型在进行图像或时间序列分类任务时,哪些区域对最终分类决定起到了关键作用。下面,我将详细解…

大数据平台搭建2024(一)

一:基础配置 创建虚拟机并查出ip地址进行连接 ip a1.配置node01静态ip地址与主机名 vi /etc/sysconfig/network-scripts/ifcfg-ens33修改或添加如下内容: BOOTPROTO"static" ONBOOTyes #根据虚拟机网卡信息配置 IPADDR192.168.200.141 NET…

360度VR全景汽车漫游展示让爱车者能感受真实的驾驶体验

小米汽车的惊艳亮相,让无数爱车族心潮澎湃。然而,对于因时间和地理限制无法亲临现场的人来说,这份激动或许带有些许遗憾。如今,有了3D虚拟看车软件,这一切不再是问题。 web3D开发公司深圳华锐视点通过运用尖端的web3D开…

IntelliJ IDEA2024 安装包(亲测可用)

目录 一、软件简介 二、软件下载 一、软件简介 IDEA(Integrated Development Environment for Apache) 是一款专为 Apache 开发者设计的集成开发环境。该软件提供了丰富的功能和工具,帮助开发者更高效地创建、调试和部署 Apache 项目。 主…

hot100 -- 链表(中)

不要觉得力扣核心代码模式麻烦,它确实比不上ACM模式舒服,可以自己处理输入输出 只是你对 链表 和 return 的理解不到位 👂 ▶ 屿前世 (163.com) 👂 ▶ see you tomorrow (163.com) 目录 🎂两数相加 🚩删…

python 绘制六种激活函数(sigmoid、tanh、relu、softmax、relu、elu)

1、效果 2、实现代码(带注释) import numpy as np # 导入 numpy 库, 用于数学运算 import matplotlib.pyplot as plt # 导入 matplotlib.pyplot, 用于绘图 import matplotlib as mpl # 导入 matplotlib 库, 用于图形配置plt.rcParams[font.sans-se…

mysql奇葩问题union

单独执行第一条,有三条结果; union之后,只有一条结果; union自动的把重复数据合并了;

使用Python生成100到算术题

需求描述:生成100道包含加法、减法、乘法、除法题目的数学题。 import random import pandas as pddef generate_math_questions(num_questions, question_types[addition, subtraction, multiplication, division], difficultyeasy, range_start1, range_end10):&…

Vue基础使用之V-Model绑定单选、复选、动态渲染选项的值

这里要说明一下&#xff0c;在v-model 绑定的值是id还是value是和<option>中的v-bind保持一致的&#xff0c;如第四个&#xff0c;如果是 <option :value"op[1]" 那v-model绑定的就是数组第二项的值2&#xff0c;4&#xff0c;6 如果是 <option :va…

《AI编程类工具之一——CodeArts Snap》

一.简介 CodeArts Snap是一款基于华为云研发的智能开发助手&#xff0c;它覆盖软件开发的全生命周期&#xff0c;提供端到端的智能支持。该工具的核心功能包括代码生成、研发知识问答、单元测试用例生成、代码解释、代码注释、代码翻译、代码调试以及代码检查等八大方面&#…

软件开发的20条原则

原则是工作的准则,代表了许多人从经验中总结出来的集体智慧 源自《软件开发的201个原则》 需求 需要明确 需求是什么?需求有具体文档记录吗?需求经过多方评审了吗?需求合理吗?需求投入产出比如何?原则46:避免再需求分析时进行系统设计 需求分析:定义系统/软件的黑盒行…

Arduino通过I2C驱动MT6701磁编码器并读取角度数据

Arduino通过I2C驱动MT6701磁编码器并读取角度数据 &#x1f4cd;相关篇《Arduino通过Wire库读取AS5600编码器数据》 ✨测试了使用STM32硬件I2C扫描其地址失败。使用软件I2C可以。 &#x1f4d1;MT6701&#xff08;基于差分霍尔的磁性角度传感器芯片&#xff09;芯片特性简介 &…

WPF中DataGrid主从数据(父子数据)展示

在wpf中可以使用DataGrid控件,进行主从数据展示,也称父子数据展示。下面展示纯原生控件编码实现功能(样式自己可以根据需求进行修改)。 效果如下: 点击图标,展开和收缩可以自由的切换,也可以自己重新写一个样式,比如+,-或者类似图标的样式,都是可以的。 1.首先创建一…

spispispi

SPI C.. & C.. logic是SPI的控制逻辑&#xff0c;芯片内部进行地址锁存、数据读写等操作&#xff0c;都是由控制逻辑自动完成。控制逻辑的左边是SPI的通信引脚&#xff0c;这些引脚和主控芯片相连&#xff0c;主控芯片通过SPI协议&#xff0c;把指令和数据发送给控制逻辑&a…

多线程传参以及线程的优缺点

进程是资源分配的基本单位 线程是调度的基本单位 笼统来说&#xff0c;线程有以下优点&#xff1a; 创建一个新线程的代价要比创建一个新进程小得多 与进程之间的切换相比&#xff0c;线程之间的切换需要操作系统做的工作要少很多 线程占用的资源要比进程少很多 能充分利用多…

leetcode1448.统计二叉树中的好节点数目

1. 题目描述 题目链接 2. 解题思路 首先看一下题目的“核心”&#xff0c;什么是好节点&#xff1a;从根到该节点 X 所经过的节点中&#xff0c;没有任何节点的值大于 X 的值。也就是说&#xff0c;我们只要知道了从根节点到该节点的所有的值&#xff0c;就可以判断该节点是…