首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

分布式MySQL集群方案

方案选型对比及京东实现方案 说到分布式MySQL的解决方案一般来说解决方案主要就两种,客户端的方案或者中间代理的方案,如下图所示。...image 间代理的方案,京东的分布式MySQL方案由很多部分组成,有JManager、 JProxy、 JTransfer、JMonitor、JConsole、MySQL,在实际部署的时候还涉及到LVS...更本质一点的原因是MySQL的事务都是每个实例维护自身的事务ID,而基于MySQL集群的分布式方案没有一个全局的事务ID来标识每个MySQL实例上的事务以及全局事务的元信息的管理,所以无法做到严格的分布式事务语义...今天我的分享就是这些,主要就是介绍一些分布式MySQL的相关方案以及京东是怎么做的,讨论了一下分布式事务的问题,最后是一小部分生产实践经验,谢谢大家。...基于Mysql分布式集群方案无法保证严格的分布式事务语义,但是在实际使用的时候看业务情况,如果事务之间不怎么冲突的情况下也是ok的,如果可以改成只涉及一个分库的情况下那就绕开分布式事务的问题了。

4.7K60

MySQL里的一些分布式方案

MySQL里面的分布式方案其实挺丰富的,今天来简单说下对分布式方案的理解。 首先数据库是一个软件,最基础的功能就是数据存储和数据查询。...对于数据的处理方式如果通泛来说是分为读和写,所以分布式方案的很多场景其实也是围绕着这两个维度来做的。 在开始分布式方案前,要说下为什么要有分布式方案。...如果单机可以解决的事情,其实完全没有必要去再考虑分布式了。如果要分,其实就不能再很自然的合起来,这也是分布式方案里需要掌握的一个平衡。...但是MySQL显然不行,因为你几乎听不到互联网行业里在用分区表的方案,因为再怎么分,怎么扩展,数据都是在单机上,况且单机性能还差强人意。...所以在方案的选择上,要有大局观和更高的视野,不一定什么都是MySQL,Oracle,深耕下去自然是不错的,还可以考虑其他更好的方案

1.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Mysql海量数据存储和解决方案之—分布式DB方案

    集群方案:解决DB宕机带来的单点DB不能访问问题。 读写分离策略:极大限度提高了应用中Read数据的速度和并发量。...典型例子:Taobao,Alibaba,Tencent,它们大都实现了自己的分布式数据访问层(DDAL)。...Taobao的基于ibatis和Spring的的分布式数据访问层,已有多年的应用,运行效率和生产实效性得到了开发人员和用户的肯定。...3)      用免费的MySQL和廉价的Server甚至是PC做集群,达到小型机+大型商业DB的效果,减少大量的资金投入,降低运营成本,何乐而不为呢? How?如何切分数据?...4)      接下来对分布式数据库解决海量数据的存访问题做进一步介绍 分布式数据方案提供功能如下: (1)提供分库规则和路由规则(RouteRule简称RR),将上面的说明中提到的三中切分规则直接内嵌入本系统

    2.4K31

    mysql数据库高可用方案_MySQL集群方案

    很多分布式数据库都把这个问题解决了,也能够通过很灵活的方式去满足业务需求,如同步、半同步方式、数据副本数量、主从切换、failover 等等(下面会提到),然而我们平时使用的社区官方版 mysql5.7...mysql 的数据同步和 failover mysql 支持相对严格的 ACID,是一个性能和稳定性都非常不错的关系型数据库,但是对分布式支持不是很友好,虽然它实现了NDB,不过感觉使用不太广泛,国内使用较多的还是基础的主从复制方式...原官方社区版的高可用问题,利用 mha + maxscale 的方式,该方案能以最小的代价对现有系统进行变更,提高系统的可用性和稳定性。...前面提到以前版本(5.7以前) mysql 对集群化支持相对较弱,但是其实 mysql 也一直在发展,社区也开发出了很多方案,像PhxSQL,Percona XtraDB Cluster,MariaDB...Galera Cluster,mysql 官方也开发出了使用 MySQL Group Replication的GA,来使用分布式协议来解决数据一致性问题了,非常期待未来越来越多的解决方案被提出,来更好的解决

    2K10

    分布式事务几种方案

    MySQL 从 5.5 版本开始支持,SQL Server 2005 开始支持,Oracle 7 开始支持。...其中,如果有任何一个数据库否决此次提交,那么所有数据库都会被要求回滚它们在此事务 中的那部分信息  XA 协议比较简单,而且一旦商业数据库实现了 XA 协议,使用分布式事务的成本也比较低。... XA 性能不理想,特别是在交易下单链路,往往并发量很高,XA 无法满足高并发场景  XA 目前在商业数据库支持的比较理想,在 mysql 数据库中支持的不太理想,mysql 的XA 实现,没有记录...3)、柔性事务-最大努力通知型方案 按规律进行通知,不保证数据一定能通知成功,但会提供可查询操作接口进行核对。这种 方案主要用在与第三方系统通讯时,比如:调用微信或支付宝支付后的支付结果通知。...这种 方案也是结合 MQ 进行实现,例如:通过 MQ 发送 http 请求,设置最大通知次数。达到通 知次数后即不再通知。

    20040

    分布式限流的方案

    之前谈到的限流方案只能针对于单个 JVM 有效,也就是单机应用。而对于现在普遍的分布式应用也得有一个分布式限流的方案。...既然要达到分布式全局限流的效果,那自然需要一个第三方组件来记录请求的次数。 其中 Redis 就非常适合这样的场景。...第二种方案可以采用 JavaBean 模式,利用 setter 方法进行构建: A a = new A(); a.setA(a); a.setB(b); 这种方式清晰易读,但却容易让对象处于不一致的状态...因此顺便将分布式锁的构建器方式也一并更新了: https://github.com/crossoverJie/distributed-redis-tool#features 更多内容可以参考 Effective...当然使用时也得扫描到该包: @ComponentScan(value = "com.crossoverjie.distributed.intercept") 总结 限流在一个高并发大流量的系统中是保护应用的一个利器,成熟的方案也很多

    49730

    MySQL分布式数据库解决方案TenDB Cluster正式开源~

    TenDB Cluster是腾讯游戏CROS DBA团队提供的MySQL分布式关系型数据库解决方案,主要包括兼容MySQL协议、透明分库分表、负载均衡、高可用、在线扩展等特点。...TSpider基于MariaDB 10.3.7上的开源存储引擎spider定制研发而成,是游戏场景中规模最大的分布式MySQL存储引擎。...spider存储引擎类似MySQL分区表的运作机制,spider原作者Kentoku SHIBA极具创新性的实现了跨机网络分区特性,为MySQL生态解决扩展性问题,提供了更好选择。 ?...作为一种MySQL引擎,TSpider天然的支持MySQL协议,而且使用MySQL标准API即可请求TSpider。...TenDB基于Percona Server 5.7.20定制而成,额外提供在线加字段、大字段压缩、binlog压缩/限速等特性及性能优化、分布式事务优化、BUG FIX等。

    2.9K7873

    Mysql分布式事务

    Mysql分布式事务 XA协议 分布式事务模型 流程 两阶段提交 Mysql中的XA语法 使用演示 XA状态转换图 XA的BUG XA的性能问题 总结 参考资源 ---- XA协议 为了规范分布式事务的管理...---- Mysql中的XA语法 Mysql分布式操作的基本模板如下: 开启xa事务,XA start DML语句,即SQL增删改查语句 终止XA事务,XA end 预提交事务...3)MySQL对XA方案支持的不太友好,MySQL的XA实现,没有记录prepare阶段日志。...---- 参考资源 数据库系列之MySQL分布式事务原理及实现 对XA协议的认识 《分布式事务系列教程-第四章-XA分布式事务解决方案mysql2阶段提交具体实现_深入理解二阶段提交协议(DDB对XA...悬挂事务的处理分析)(一)… 分布式事务实战—XA两阶段提交(2PC)方案详解 书籍: 深入浅出MySQL,高性能MySQL,Innodb技术内幕

    97320

    常见分布式id生成方案_分布式id生成方案

    一、为什么要用分布式ID 在说分布式ID的具体实现之前,我们来简单分析一下为什么用分布式ID?分布式ID应该满足哪些特征?...1、什么是分布式ID 拿MySQL数据库举个栗子: 在我们业务数据量不大的时候,单库单表完全可以支撑现有业务,数据再大一点搞个MySQL主从同步读写分离也能对付。...传输数据量大,且不可读 2、基于数据库自增ID 基于数据库的auto_increment自增ID完全可以充当分布式ID,具体实现:需要一个单独的MySQL实例用来生成ID,建表结构如下: CREATE...解决方案:设置起始值和自增步长 MySQL_1 配置: set @@auto_increment_offset = 1; -- 起始值 set @@auto_increment_increment...官方对于此并没有给出解决方案,而是简单的抛错处理,这样会造成在时间被追回之前的这段时间服务不可用。

    91530

    MySQL高可用方案

    这在很大程度上解决了目前很多中小型网站的数据库压力瓶颈问题,甚至有些大型网站也在使用类似的方案解决数据库瓶颈问题。...第二种:Mysql Cluster MySQL Cluster 由一组计算机构成,每台计算机上均运行着多种进程,包括 mysql 服务器,NDB Cluster的数据节点,管理服务器,以及(可能)专门的数据访问程序...由于MySQL Cluster架构复杂,部署费时(通常需要DBA几个小时的时间才能完成搭建),而依靠 MySQL Cluster Manager 只需一个命令即可完成,但 MySQL Cluster Manager...在数据方面完全兼容 MariaDB 和 MySQL。...*表将不会复制,但是DDL语句会被复制的,因此创建用户将会被复制,但是insert into mysql.user…将不会被复制的.

    1.9K80

    Mysql-15-mysql分布式应用

    近年来,随着数据量的增长,分布式数据库技术也得到了快速的发展,传统的关系型数据库开始从集中式模型向分布式存储,从集中式计算走向分布式计算。  ...2.mysql分布式应用的主要技术 (1)mysql数据切割   数据切割(sharding)是指通过某种特定的条件,将存放在同一数据库中的数据分散存放到多个数据库(主机)上面,以达到分散单台设备负载的效果...第二种方案,虽然短期内需要付出的成本可能会大一些,但是对整个系统的扩展性来说,是非常有帮助的。针对第二种方案,可以思路如下: (1)利用mysql proxy实现数据切分及整合。...4.mysql集群   Mysql cluster技术在分布式系统中为mysql数据提供了冗余特性,增强了安全性,使得单个mysql服务器故障不会对系统产生巨大的负面效应,系统的稳定性得到保障。   ...多个节点之间可以分布在不同的地理位置,因此也是一个实现分布式数据库的方案

    1.1K80

    分布式ID生成方案

    介绍ID生成和分布式方案的文章已经非常非常多了,比如文末中的参考资料中的文章,所以我在本文中简洁的汇总各个方案的优缺点,然后介绍一个分布式的ID生成器项目rpcxio/did,它可以实现单节点百万级的...ID 生成方案 UUID/GUID 通用唯一识别码(Universally Unique Identifier,缩写:UUID)是用于计算机体系中以识别信息数目的一个128位标识符,也就是可以通过16个字节来表示...UUID可以根据标准方法生成,不依赖中央机构的注册和分配,UUID具有唯一性,这与其他大多数编号方案不同。重复UUID码概率接近零,可以忽略不计。...递增的整数 可以通过关系型数据库的自增主键产生唯一的ID,现在流行的商业数据库都支持自增主键的特性,比如mysql等。 一些nosql数据库也提供类似特性,比如Redis。...可读性高 随机,不会泄漏信息 缺点 ID可能不唯一,需要检查和处理 Twitter的snowflake算法 Twitter的snowflake分布式ID的算法是目前广泛使用的分布式ID算法,尽管有很多变种

    75200
    领券