随笔 - 34  文章 - 0 评论 - 270 阅读 - 15万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

特性

         高可用性:主服务器故障后可切换到备用服务器

         可伸缩性:方便增加db

         负载均衡:支持将某数据切换到另外的服务器

  1. mysqlcluster

mysql cluster 是mysql官方集群部署方案,通过自动分片支持读写扩展,通过实时备份冗余数据,是可用性最高的方案,声称可做到99.999%的可用性。

Mysql cluster 主要由三种类型的服务组成。

NDB management server:管理服务器主要管理cluster中的其他类型节点(data node和sql node),通过它可以配置node信息,启动和停止node。

Sql node:在mysql cluster中,一个sql node就是一个使用NDB引擎的mysql server进程,用于供外部应用提供集群数据的访问入口。

Data node:用于储存集群数据。

缺点:对需要进行分片的表需要修改引擎Innodb为NDB。NDB的事务隔离级别只支持read commited,即一个事务在提交前,查询不到在事务内所做的修改。Innodb支持所有事务隔离级别,默认用 repeatable read。尽量不要使用外键,因为外键所关联的记录可能在别的分片节点中。

四种事务隔离界别

Serializable 串行化,事务一个接一个地执行,而不能并发执行

Repeatable read 可重复读,一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,但是不能看到其他其他事务对已有记录的更新。

Read Commited(读已提交数据):一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,而且能看到其他事务已经提交的对已有记录的更新。

Read Uncommitted(读未提交数据):一个事务在执行过程中可以看到其他事务没有提交的新插入的记录,而且能看到其他事务没有提交的对已有记录的更新。

  1. mysql fabric

两个特性:高可用和使用数据分片实现可扩展性和负载均衡。

Fabric 使用ha组实现高可用,一台主服务器,其他是备份服务器,备份服务器通过同步复制实现数据冗余。链接到fabric的connector组件,当服务器发生故障后,connector自动升级其中一个备份服务器为主服务器。

使用多个HA组实现分片,每个组分担不同的分片数据。应用只需向connector发送query和insert语句,connector 通过master group自动分配数据到各个组,或者从各个组中组合符合条件的数据,返回给应用程序。

缺点:自增长键不能作为分片的键;事务及查询只支持在同一个分片内,事务中更新的数据不能跨分片,查询语句返回的数据也不能跨分片。

Fabric 分片:当一台机器或一个组承受不了服务压力后,可以添加服务器分摊读写压力,通过Fabirc的分片功能可以将某些表中数据分散存储到不同服务器。我们可以设定分配数据存储的规则,通过在表中设置分片key设置分配的规则。另外,有些表的数据可能并不需要分片存储,需要将整张表存储在同一个服务器中,可以将设置一个全局组(Global Group)用于存储这些数据,存储到全局组的数据会自动拷贝到其他所有的分片组中。

  1. Galera Cluster

多个服务能够同时被读写,无延迟复制,不会产生数据丢失,备用服务器会自动接管,不会产生宕机时间,无需手动复制数据库到新的节点上,支持innodb引擎。

架构实现原理:

传统:Replication(复制)方式是通过启动复制线程从主服务器上拷贝更新日志,然后传送到备份服务器上执行,存在丢失或者同步不及时的风险。

Galera:客户端通过Galera Load Balancer访问数据,提交每个事物都通过wrsp api在所有服务器中执行,要么全部成功,要么全部回滚。

缺点:由于同一个事务需要在集群的多台机器上执行,性能上会有消耗。

posted on   peiyu1988  阅读(433)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示