特性:
高可用性:主服务器故障后可切换到备用服务器
可伸缩性:方便增加db
负载均衡:支持将某数据切换到另外的服务器
- 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(读未提交数据):一个事务在执行过程中可以看到其他事务没有提交的新插入的记录,而且能看到其他事务没有提交的对已有记录的更新。
- mysql fabric
两个特性:高可用和使用数据分片实现可扩展性和负载均衡。
Fabric 使用ha组实现高可用,一台主服务器,其他是备份服务器,备份服务器通过同步复制实现数据冗余。链接到fabric的connector组件,当服务器发生故障后,connector自动升级其中一个备份服务器为主服务器。
使用多个HA组实现分片,每个组分担不同的分片数据。应用只需向connector发送query和insert语句,connector 通过master group自动分配数据到各个组,或者从各个组中组合符合条件的数据,返回给应用程序。
缺点:自增长键不能作为分片的键;事务及查询只支持在同一个分片内,事务中更新的数据不能跨分片,查询语句返回的数据也不能跨分片。
Fabric 分片:当一台机器或一个组承受不了服务压力后,可以添加服务器分摊读写压力,通过Fabirc的分片功能可以将某些表中数据分散存储到不同服务器。我们可以设定分配数据存储的规则,通过在表中设置分片key设置分配的规则。另外,有些表的数据可能并不需要分片存储,需要将整张表存储在同一个服务器中,可以将设置一个全局组(Global Group)用于存储这些数据,存储到全局组的数据会自动拷贝到其他所有的分片组中。
- Galera Cluster
多个服务能够同时被读写,无延迟复制,不会产生数据丢失,备用服务器会自动接管,不会产生宕机时间,无需手动复制数据库到新的节点上,支持innodb引擎。
架构实现原理:
传统:Replication(复制)方式是通过启动复制线程从主服务器上拷贝更新日志,然后传送到备份服务器上执行,存在丢失或者同步不及时的风险。
Galera:客户端通过Galera Load Balancer访问数据,提交每个事物都通过wrsp api在所有服务器中执行,要么全部成功,要么全部回滚。
缺点:由于同一个事务需要在集群的多台机器上执行,性能上会有消耗。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?