• Mysql集群


    特性

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

             可伸缩性:方便增加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在所有服务器中执行,要么全部成功,要么全部回滚。

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

  • 相关阅读:
    mysql中GROUP_CONCAT的使用
    sublime text3 配置
    dede自定义标签
    mysql索引
    mysql5.5以上开启慢查询
    mysql定位慢查询
    mysql5.5以上my.ini中设置字符集
    mysql数据库的优化
    win下Apache2.4的下载与安装
    PHP Warning: PHP Startup: in Unknown on line 0
  • 原文地址:https://www.cnblogs.com/peiyu1988/p/7715242.html
Copyright © 2020-2023  润新知