【YashanDB 知识库】数据库一主一备部署及一主两备部署时,主备手动切换方法及自动切换配置

简介: **数据库主备切换简介**在数据库正常或异常情况下,实现主备切换至关重要。若配置不当,主节点故障将影响业务使用,尤其在23.2版本中。原因包括资源紧张或主节点异常。解决方法涵盖手动和自动切换:1. **一主一备部署**: - **手动切换**:支持Switchover(同步正常时)和Failover(主库损坏时)。 - **自动切换**:启用yasom仲裁选主开关。2. **一主两备部署**: - 默认最大保护模式,自动切换开启。需检查并配置自动切换以确保高可用性。经验总结:一主一备默认关闭自动切换,需手动开启;一主两备默认开启。

问题现象
数据库在正常或异常情况下,如何实现主备切换

问题的风险及影响
数据库主备切换若没有正确配置,在数据库发生主节点故障时,会影响业务的使用

问题影响的版本
23.2 整个大版本

问题发生的原因
1、若主节点所在主机因为其他原因导致资源紧张的情况下,想要切换备节点为主节点更好的提供服务,此时就需要在数据库正常的情况下执行手动主备切换

2、数据库主节点异常时,若配置了自动主备切换,则数据库在心跳时间内会自动切换,若没有配置自动切换就只能执行手动切换

解决方法及规避方法
以下主要示例数据库一主一备部署和一主两备部署的情况

一主一备部署

1、手动切换

YashanDB 支持在主备库同步正常的情况下进行主备库的手动 Switchover 切换,也支持在主库异常的情况下进行备库的手动 Failover 切换,但在开启自动选主时无法使用 Failover 切换。

(1)Switchover 切换

Switchover 切换方式适用于主备库同步正常的情况,可选择任意一个备库执行操作。

● Switchover 过程中,主库已连接的会话将全部断连,并且主库不可连接新的会话,直到切换完成或失败。

● Switchover 过程中,如果主备网络断连,切换将失败。

● 如果备库 transport_lag 或 apply_lag 不为 0,即备库有待接收和回放的 redo,Switchover 过程可能时间较久,通过查询 V$RECOVERY_PROGRESS 视图查看剩余回放时间。

● Switchover 完成后,主备库会重新进行连接,将出现短暂的网络断连。

示例:

检查主备库同步状态,确认主备库同步无异常,并确认主备库的角色

yasboot cluster status -c yashandb -d

1.jpeg

备节点执行 switchover 切换主备节点

ALTER DATABASE SWITCHOVER;

2.jpeg

可以看到主备切换完成

(2)failover 切换

Failover 切换方式适用于主库损坏,或者服务器宕机等不可用时,必须立即进行故障切换,尽快恢复业务。

前提是未开启自动切换

yasboot election config show -c yashandb

3.jpeg

备节点为 readonly 状态

SELECT database_id,database_name,open_mode,database_role,protection_mode FROM V$DATABASE;

4.jpeg

kill 主节点进程,模拟主节点故障

5.jpeg

备节点执行 failover 主备切换

ALTER DATABASE FAILOVER;

SELECT database_id,database_name,open_mode,database_role,protection_mode FROM V$DATABASE;

6.jpeg

升主成功

7.jpeg

接下来进行旧主降备操作,将旧主库实例启动到 MOUNT 状态

yasboot node start -c yashandb -n 1-2 -m mount

8.jpeg

执行降备命令,并 OPEN 数据库

ALTER DATABASE CONVERT TO PHYSICAL STANDBY;

ALTER DATABASE OPEN;

9.jpeg

2、自动切换

启用基于 yasom 的仲裁选主开关

yasboot election enable on -c yashandb

10.jpeg

kill 主机点数据库服务,备节点会自动切主

yasboot cluster status -c yashandb -d

11.jpeg

一主两备部署

12.jpeg

查看主备库的保护模式

13.jpeg

当前为最大保护模式

查看自动选主开关,主备节点都查看

SHOW PARAMETER HA_ELECTION_ENABLED;

14.jpeg

当前为开启,若是关闭状态,执行 ALTER SYSTEM SET HA_ELECTION_ENABLED=TRUE; 开启,主备节点都执行

kill 主节点数据库服务,模拟主库挂点

15.jpeg

主节点切换完成

问题分析方法及处理过程
数据库部署后先检查是否配置自动切换

(1)一主一备部署

yasboot election config show -c yashandb

若 Automatic Failover 为 DISABLED,则自动切换为关闭状态

执行 yasboot election enable on -c yashandb 开启

(2)一主两备部署

SHOW PARAMETER HA_ELECTION_ENABLED 查看,若为 TRUE 则为开启状态

否则执行 ALTER SYSTEM SET HA_ELECTION_ENABLED=TRUE 开启

经验总结
目前,数据库一主一备部署,自动切换时默认关闭的,需要手动开启;一主两备部署,数据库默认是最大保护模式,主备自动切换是默认开启的

相关文章
|
28天前
|
SQL 存储 关系型数据库
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
|
15天前
|
安全 Linux 网络安全
YashanDB数据库服务端SSL连接配置
YashanDB支持通过SSL连接确保数据传输安全,需在服务端生成根证书、服务器证书及DH文件,并将根证书提供给客户端以完成身份验证。服务端配置包括使用OpenSSL工具生成证书、设置SSL参数并重启数据库;客户端则需下载根证书并正确配置环境变量与`yasc_env.ini`文件。注意:启用SSL后,所有客户端必须持有根证书才能连接,且SSL与密码认证独立运行。
|
15天前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
166 28
|
7天前
|
Java 关系型数据库 MySQL
JDK、Tomcat、MariaDB数据库和Profile多环境的配置与使用
以上就是JDK、Tomcat、MariaDB数据库和Profile多环境的配置与使用的基本步骤。这些步骤可能会因为你的具体需求和环境而有所不同,但是基本的思路是一样的。希望这些信息能够帮助你更好地理解和使用这些工具。
52 17
|
7天前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
29天前
|
SQL 数据库连接 Linux
数据库编程:在PHP环境下使用SQL Server的方法。
看看你吧,就像一个调皮的小丑鱼在一片广阔的数据库海洋中游弋,一路上吞下大小数据如同海中的珍珠。不管有多少难关,只要记住这个流程,剩下的就只是探索未知的乐趣,沉浸在这个充满挑战的数据库海洋中。
49 16
|
28天前
|
SQL 关系型数据库 MySQL
【YashanDB知识库】MySQL field 函数的改写方法
【YashanDB知识库】MySQL field 函数的改写方法
|
15天前
|
Oracle 关系型数据库 Linux
YashanDB异构数据库链接配置
本指南介绍在YashanDB中配置异构数据库链接(DBLINK)的方法,特别是连接至Oracle数据库的前置要求与步骤。需确保YashanDB服务端安装plugin插件包、Oracle Instant Client及libaio库,否则可能导致错误或进程崩溃。文档还提供了Oracle Instant Client和libaio库的具体安装指导,帮助管理员顺利完成配置。
|
30天前
|
SQL 关系型数据库 MySQL
【YashanDB知识库】MySQL field 函数的改写方法
本文来自YashanDB官网,介绍将MySQL的FIELD函数改写到YashanDB的方法。MySQL中,FIELD函数用于自定义排序;而在YashanDB中,可使用DECODE或CASE语句实现类似功能。示例展示对表`t1`按指定顺序排序的过程,提供两种改写方式,结果均符合预期。
|
1月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库

热门文章

最新文章

下一篇
oss创建bucket