对比各类 AWS MySQL 升级方案及原理

搞了好几个月的MySQL升级终于接近尾声,进入总结梳理阶段~

本文主要对比升级期间用到的三种方案:

  • 本地升级
  • 蓝绿升级
  • API同步升级

|-----------------|-------------------|--------------------------|------------------|
| 对比项 \ 升级方式 | 本地升级 | 蓝绿升级 | API同步升级 |
| 停机时间 | 长,3-5分钟不可读写 | 较短,约15秒实例变为只读 | 短,5秒以内不可读写 |
| 准备时间 | 无 | 小时级至一天 | 一天至一周 |
| 资源费用 | 无 | 较高,需要双份实例,但使用时间较短 | 高,需要双份实例,且使用时间长 |
| DB操作 | 简单,点击升级即可 | 较复杂,需提前准备绿色实例、执行切换、回收旧实例 | 非常复杂,一篇写不下 |
| 应用操作 | 简单,升级后检查业务情况即可 | 简单,升级后检查业务情况即可 | 复杂,需将应用全部迁移至新连接串 |
| 连接串变化 | 不变 | 不变(但底层库变了) | 变化(可以手动改,但需重启) |
| 对DTS同步链路的影响 | 低,升级期间会中断,过后可自动恢复 | 链路中断,需要升级后重建 | 链路中断,但可在升级前新建 |
| 风险 | 低 | 较低,回收操作不友好,让人两眼一黑 | 高,太过复杂 |

一、 AWS的版本支持策略

可以参考 aws RDS 版本升级最佳实践的探讨 -- OracleBlog 介绍非常详细

MySQL Amazon RDS 上的 MySQL 版本 - Amazon Relational Database Service

PG Amazon RDS for PostgreSQL 发布日历 - Amazon Relational Database Service

二、 本地升级

1. 操作步骤

操作最简单,实例右上角点击"修改",设置对应小版本,等待升级完成即可。

2. 升级原理

  • 备份数据库(快照备份)
  • 准备升级
  • 关闭实例进行升级
  • 开启实例
  • 再次进行快照备份
  • 一些后续配置

3. 注意事项

  • 升级时长=备份时长+升级时长(约10分钟),实例中断一般发生在最后3-5分钟
  • 务必提前确认历史备份时长,避免超出变更窗口
  • 实际上在开启实例后,业务就已经恢复访问,而界面恢复需完成所有阶段,耗时较长

未完待续...

相关推荐
码小跳2 分钟前
软件无法连接MySql数据库
数据库·mysql
DCTANT8 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
sealaugh328 小时前
aws(学习笔记第四十八课) appsync-graphql-dynamodb
笔记·学习·aws
程序员岳焱10 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
喜欢敲代码的程序员10 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
钢铁男儿10 小时前
C# 委托(调用带引用参数的委托)
java·mysql·c#
叁沐11 小时前
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
mysql
RunsenLIu11 小时前
基于Vue.js + Node.js + MySQL实现的图书销售管理系统
vue.js·mysql·node.js
码不停蹄的玄黓11 小时前
MySQL Undo Log 深度解析:事务回滚与MVCC的核心功臣
数据库·mysql·undo log·回滚日志
Arthurmoo12 小时前
Linux系统之MySQL数据库基础
linux·数据库·mysql