mysql高可用设计,主库挂了怎么办

实际上高可用就是系统能提供的一种无故障服务能力,就是避免宕机出现不能服务的场景。

首先来说对于无状态服务的高可用设计是比较简单的,发现有不能用的就直接停了换别的服务器就行,比如Nginx。这里说一下无状态服务就是不需要记录你的状态、数据等等,各个服务器提供的是一样的服务。mysql分库分表不同服务器能提供的查询服务是不一样的,因为存的东西不一样。

数据库的高可用设计是比较难的,其实最重要的就是冗余。主要有以下几种

  • 主从模式的解决方式,就是主机挂了,将服务转移到从节点上,那这个从节点变成新的主机了,其他从节点从这个新主机上拷贝数据
  • 分库分表的方式,一个库寄了,那把原本要写到这上的数据写到另一个上就行。但这个其实并不好,因为你分开了表甚至是库肯定是根据一个方式分的,那你把A类写进B类里肯定是不好的
  • 融合两种方式,如下图

在这里插入图片描述

注意以上的方法都需要完成一个叫VIP(Virtual IP)的东西,即用户访问的ip是可以随意绑定在任何一台服务器上的。因为要让用户直接用起来,当有挂了的主机时,用户刷新一下,你底层直接把这个VIP绑给其他主机就可以返回给用户结果了。但是 VIP 也是有局限性的,仅限于同机房同网段的 IP 设定。如果是跨机房容灾架构,VIP 就不可用了。这时就要用名字服务,常见的名字服务就是 DNS(Domain Name Service)

最后一种新的技术:MGR技术。因为数据库复制的瓶颈在于,只能在一个节点写入数据,然后这个节点再将日志同步给其他节点。这样单点写入会导致数据库性能无法进行扩展。MGR技术之间的数据同步没有采用复制的手段,而是用GCS(Group Communication System)协议的日志同步技术。要求组中的大部分节点都接收到日志,事务才能提交。所以,MRG 是严格要求数据一致的,特别适合用于金融级的环境。并且MGR有两种模式,单主模式只有 1 个节点可以写入,多主模式能让每个节点都可以写入。而多个节点之间写入,如果存在变更同一行的冲突,MySQL 会自动回滚其中一个事务,自动保证数据在多个节点之间的完整性和一致性。但是缺点是有一个节点网络出现抖动或不稳定,会影响集群的性能!!!切记保证网络通畅

在这里插入图片描述

相关推荐

  1. Mysql怎么办

    2024-01-25 11:52:01       20 阅读
  2. keepalived 可用

    2024-01-25 11:52:01       34 阅读
  3. 25 | MySQL怎么保证可用的?

    2024-01-25 11:52:01       16 阅读
  4. MySQL可用实战(MHA)

    2024-01-25 11:52:01       29 阅读
  5. MySQL恢复从

    2024-01-25 11:52:01       9 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-25 11:52:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-25 11:52:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-25 11:52:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-25 11:52:01       20 阅读

热门阅读

  1. 【笔记】Helm-4 最佳实践-依赖

    2024-01-25 11:52:01       35 阅读
  2. harmonyOS app 开发环境配置流程

    2024-01-25 11:52:01       32 阅读
  3. 安卓MediaRecorder(4)视频采集编码写入详细源码分析

    2024-01-25 11:52:01       46 阅读
  4. Jenkins相关

    2024-01-25 11:52:01       38 阅读
  5. android:excludeFromRecents

    2024-01-25 11:52:01       28 阅读
  6. c# 策略模式

    2024-01-25 11:52:01       39 阅读
  7. 为什么需要数据仓库

    2024-01-25 11:52:01       35 阅读
  8. 《设计模式的艺术》笔记 - 策略模式

    2024-01-25 11:52:01       35 阅读