mycat_mycat读写分离 - CSDN
mycat 订阅
Mycat是一个彻底开源的,面向企业应用开发的大数据库集群。 展开全文
Mycat是一个彻底开源的,面向企业应用开发的大数据库集群。
信息
外文名
Mycat
应用领域
计算机、软件、数据库
MyCat定义
从定义和分类来看,它是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为N个小表,存储在后端MySQL服务器里或者其他数据库里。 [1] 
收起全文
精华内容
参与话题
  • MyCat是什么?为什么要用MyCat

    万次阅读 多人点赞 2017-02-21 10:24:54
    实习的时候,在一个项目当中,项目经理要求把原先的MySQL数据连接基于mycat来进行改造 。当时就在想MyCat是什么东西?为什么要用它呢?*一、什么是MyCatMyCat是一个开源的分布式数据库系统,是一个实现了MySQL...

    实习的时候,在一个项目当中,项目经理要求把原先的MySQL数据连接基于mycat来进行改造 。当时就在想MyCat是什么东西?为什么要用它呢?

    *一、什么是MyCat:
    MyCat是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为N个小表,存储在后端MySQL服务器里或者其他数据库里。

    MyCat发展到目前的版本,已经不是一个单纯的MySQL代理了,它的后端可以支持MySQL、SQL Server、Oracle、DB2、PostgreSQL等主流数据库,也支持MongoDB这种新型NoSQL方式的存储,未来还会支持更多类型的存储。而在最终用户看来,无论是那种存储方式,在MyCat里,都是一个传统的数据库表,支持标准的SQL语句进行数据的操作,这样一来,对前端业务系统来说,可以大幅降低开发难度,提升开发速度


    二、那么为什么要用到MyCat呢?

    *例如操作系统是对各类计算机硬件的抽象。那么我们什么时候需要抽象?假如只有一种硬件的时候,我们需要开发一个操作系统吗?
    再比如一个项目只需要一个人完成的时候不需要leader,但是当需要几十人完成时,就应该有一个管理者,发挥沟通协调等作用,而这个管理者对于他的上层来说就是对项目组的抽象。
    同样的,当我们的应用只需要一台数据库服务器的时候我们并不需要Mycat,而如果你需要分库甚至分表,这时候应用要面对很多个数据库的时候,这个时候就需要对数据库层做一个抽象,来管理这些数据库,而最上面的应用只需要面对一个数据库层的抽象或者说数据库中间件就好了,这就是Mycat的核心作用。
    所以可以这样理解:数据库是对底层存储文件的抽象,而Mycat是对数据库的抽象。*

    展开全文
  • MyCat实战讲解(MySQL集群)

    千人学习 2018-10-22 21:38:06
    Mycat是阿里推广的一个开源组件,其核心的概念为库表分离实现操作,利用合理的库表分离可以用更高效的方式来进行SQL数据库的开发与处理,适合高并发的数据访问处理。 在本课程中将为读者讲解库表分离的设计思想,...
  • 关于MyCat,入门到放弃(一、简介)

    千次阅读 2019-05-04 21:50:15
    一、什么是MyCat? 《MyCat》是代替昂贵的oracle的MySQL集群中间件。---百度百科(嗯,简介明了,nice) 所以从官网copy了一份: 一个彻底开源的,面向企业应用开发的大数据库集群 支持事务、ACID、可以替代MySQL...

    一、什么是MyCat?

    《MyCat》是代替昂贵的oracle的MySQL集群中间件。—百度百科(嗯,简介明了,nice)

    所以从官网copy了一份:

    • 一个彻底开源的,面向企业应用开发的大数据库集群
    • 支持事务、ACID、可以替代MySQL的加强版数据库
    • 一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群
    • 一个融合内存缓存技术、NoSQL技术、HDFS大数据的新型SQL Server
    • 结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品
    • 一个新颖的数据库中间件产品

    Mycat作用为:能满足数据库数据大量存储;提高了查询性能

    二、关键特性

    mycat支持基本上所有的主流数据库。

    MYCAT原生实现了对MySQL的支持,也可以通过jdbc形式连接其它关系型数据库 如 Oracle,Sqlserver,也可以连接非关系型数据库 如 mongodb,这个功能其他同类型产品没有。可实现数据库的读写分离,在后端的主从复制数据库集群中,通过MYCAT配置,将前台的写操作路由到主数据库中,将读操作路由到从数据库上。

    MYCAT可以实现读写分离下的读操作负载均衡,将大量的读操作均衡到不同的从库上,主要出现在一主多从情形下。

    MYCAT可实现数据库的高可用,在数据库主节点可用的情况下,配置一台可写从节点,这两个节点都配置在MYCAT中,当主节点宕机时,MyCAT会自动将写操作路由到备用节点上,但并不支持在切换之后的继续主从同步。

    当读写分离已经不能满足持续增加的访问量时,MYCAT可实现数据库的垂直拆分,将所有的数据库表按照模块划分,不同类型的表拆分到不同的数据库服务器。

    随着业务量的增长,垂直拆分之后如果又出现了数据库性能问题,则需要进行水平切分,这就是俗称的分库分表。将数据量很大的表数据切分到不同的服务器库中,表结构是一样的,而使用MYCAT实现水平切分,对前端应用是完全透明的,不用调整前台逻辑。

    Mycat原理

    简单来说就是拦截用户发来的SQL语句,对SQL语句做了一些特定的分析,如分片分析,路由分析,读写分离分析,缓存分析等,然后将此SQL发往后端的真实数据库,并将返回的结果做适当处理,最终返回给用户。

    分片原理

    数据库分片指:通过某种特定的条件,将我们存放在一个数据库中的数据分散存放在不同的多个数据库(主机)中,这样来达到分散单台设备的负载,根据切片规则,可分为以下两种切片模式:

    • 水平分片:将不同的表切分到不同的数据库中。
    • 垂直分片:一个数据库中多个表格A,B,C,A存储到节点1上,B存储到节点2上,C存储到节点3上。

    读写分离

    读写分离就是主从复制,让主库负责写,从库负责读,这样,即使主库出现了锁表的情景,通过读从库也可以保证业务的正常运作。
    一主一从和一主多从是最常见的主从架构,实施起来简单并且有效,不仅可以实现HA,而且还能读写分离,进而提升集群的并发能力。

    展开全文
  • Mycat使用详解

    万次阅读 2018-09-14 17:06:18
    一、Mycat是什么

    MyCat是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为N个小表,存储在后端MySQL服务器里或者其他数据库里。

    MyCat发展到目前的版本,已经不是一个单纯的MySQL代理了,它的后端可以支持MySQL、SQL Server、Oracle、DB2、PostgreSQL等主流数据库,也支持MongoDB这种新型NoSQL方式的存储,未来还会支持更多类型的存储。而在最终用户看来,无论是那种存储方式,在MyCat里,都是一个传统的数据库表,支持标准的SQL语句进行数据的操作,这样一来,对前端业务系统来说,可以大幅降低开发难度,提升开发速度。

    我们的应用只需要一台数据库服务器的时候我们并不需要Mycat,而如果你需要分库甚至分表,这时候应用要面对很多个数据库的时候,这个时候就需要对数据库层做一个抽象,来管理这些数据库,而最上面的应用只需要面对一个数据库层的抽象或者说数据库中间件就好了,这就是Mycat的核心作用。

    总结:Mycat是一个广受好评的数据库中间件,为了减轻单数据库的压力,可以实现主从、热备、分表分库,从而实现数据库的分布式架构。

    参考博客:https://blog.csdn.net/nxw_tsp/article/details/56277430

    二、Mycat原理

    Mycat的原理中最重要的一个动词是“拦截”,它拦截了用户发送过来的SQL语句,首先对SQL语句做了一些特定的分析:如分片分析、路由分析、读写分离分析、缓存分析等,然后将此SQL发往后端的真实数据库,并将返回的结果做适当的处理,最终再返回给用户。
    这里写图片描述
    上述图片里,应用程序不再直接访问数据库,而是访问Mycat,由Mycat与数据库交互,数据库数据返回给Mycat,Mycat再返回给应用程序。三个Database才是真正的数据库,又称为三个节点,也称为三个分片。

    总结:Mycat作为一个中间件,应用程序直接访问它,不用 再去管真实的数据库,而由Mycat来与真实的数据库进行交互,真实的数据库可能有多个,这就是分布式架构,即多节点(多分片)
    三、Mycat应用场景

    Mycat发展到现在,适用的场景已经很丰富,而且不断有新用户给出新的创新性的方案,以下是几个典型的应用场景:

    单纯的读写分离,此时配置最为简单,支持读写分离,主从切换分表分库,对于超过1000万的表进行分片,最大支持1000亿的单表分片

    多租户应用,每个应用一个库,但应用程序只连接Mycat,从而不改造程序本身,实现多租户化

    报表系统,借助于Mycat的分表能力,处理大规模报表的统计

    替代Hbase,分析大数据

    作为海量数据实时查询的一种简单有效方案,比如100亿条频繁查询的记录需要在3秒内查询出来结果,除了基于主键的查询,还可能存在范围查询或其他属性查询,此时Mycat可能是最简单有效的选择

    Mycat长期路线图

    强化分布式数据库中间件的方面的功能,使之具备丰富的插件、强大的数据库智能优化功能、全面的系统监控能力、以及方便的数据运维工具,实现在线数据扩容、迁移等高级功能

    进一步挺进大数据计算领域,深度结合Spark Stream和Storm等分布式实时流引擎,能够完成快速的巨表关联、排序、分组聚合等 OLAP方向的能力,并集成一些热门常用的实时分析算法,让工程师以及DBA们更容易用Mycat实现一些高级数据分析处理功能。

    不断强化Mycat开源社区的技术水平,吸引更多的IT技术专家,使得Mycat社区成为中国的Apache,并将Mycat推到Apache基金会,成为国内顶尖开源项目,最终能够让一部分志愿者成为专职的Mycat开发者,荣耀跟实力一起提升。

    依托Mycat社区,聚集100个CXO级别的精英,众筹建设亲亲山庄,Mycat社区+亲亲山庄=中国最大IT O2O社区

    参考:https://www.cnblogs.com/andy6/p/6622324.html
    收录于:Mycat权威指南,感谢作者

    四、Mycat安装教程
    下载:去Mycat官网下载,我这里下载的是1.6版本的,Windows系统的

    Mycat官方网站:http://www.mycat.io/
    这里写图片描述
    这里写图片描述

    安装:下载后解压,以管理员身份运行cmd,进入bin目录,这里有几个操作命令

    这里写图片描述
    安装:

    mycat install

    启动:

    mycat start

    停止:

    mycat stop

    重启:

    mycat restart
    安装以后,我们就可以直接去服务里面启动与停止了,不用再使用命令

    这里写图片描述
    参考:https://blog.csdn.net/smilefyx/article/details/72810531

    五、Mycat使用案例(分表分库)

    需求:我在云服务器与本机都安装有Myql,现在我要使用这两个Mysql共同来给我的应用程序提供服务,主要涉及到的是MAVEN_SSM数据下面的user表,下面分别给出sql:

    本机Mysql执行的sql为:

    drop database if exists MAVEN_SSM;
    create database MAVEN_SSM;
    use MAVEN_SSM;
    create table user(
        id int not null auto_increment,
        username char(20) not null,
        password char(33) not null,
        address char(8) not null,
        birthday date,
        department_id int not null,
        primary key (id)
    );
    insert into user(id,username,password,address,birthday,department_id) values(1,'小余','123456','四川成都','2018-06-01',2);
    insert into user(id,username,password,address,birthday,department_id) values(2,'小余','982352','成都大学','2015-04-03',3);
    

    云服务器上执行的sql为:

    drop database if exists MAVEN_SSM;
    create database MAVEN_SSM;
    use MAVEN_SSM;
    create table user(
        id int not null auto_increment,
        username char(20) not null,
        password char(33) not null,
        address char(8) not null,
        birthday date,
        department_id int not null,
        primary key (id)
    );
    insert into user(id,username,password,address,birthday,department_id) values(3,'小王','982352','四川绵阳','1996-08-26',2);
    

    Mycat的默认端口是:8066,对于应用程序来说,数据库名为Mycat的中间件逻辑数据库名,不再是某个真实的数据库名

    Mycat的配置文件,在conf目录下面有:server.xml、schema、rule.xml,以及ehcache.xml、log4j2.xml,我们主要使用前三个

    首先配置:server.xml,将默认的该配置文件下的user全都删掉,新建了一个用户peng:

    这里写图片描述

    用户名:peng

    其密码为:123456

    其逻辑数据库名为:MYCAT_DB

    是否为只读数据库:否

    由于Mycat安装在本机,则需要更换驱动的url为本机的Mycat中间件

        jdbc:mysql://localhost:3306/MAVEN_SSM

    改为

        jdbc:mysql://localhost:8806/MYCAT_DB

    其次配置schema.xml,配置数据库的表结构,配置分片

    这里写图片描述

    <?xml version="1.0"?>
    <!DOCTYPE mycat:schema SYSTEM "schema.dtd">
    <mycat:schema xmlns:mycat="http://io.mycat/">
    
        <schema name="MYCAT_DB" checkSQLschema="false" sqlMaxLimit="100">
            <table name="user" primaryKey="id" autoIncrement="true" dataNode="dn1,dn2" rule="mod-long"/>
        </schema>
    
        <dataNode name="dn1" dataHost="localhost" database="MAVEN_SSM"/>
        <dataNode name="dn2" dataHost="remotehost" database="MAVEN_SSM"/>
    
        <dataHost name="localhost" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
            <heartbeat>select user()</heartbeat>
            <writeHost host="hostM1" url="localhost:3306" user="root" password="123456"></writeHost>
        </dataHost>
    
        <dataHost name="remotehost" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
            <heartbeat>select user()</heartbeat>
            <writeHost host="hostM1" url="47.55.478.991:3306" user="root" password="123456"></writeHost>
        </dataHost>
    
    
    </mycat:schema>

    当然这里的云服务47.55.478.991:3306,是我个人的,我用完就处理了,你们是用不了的,需要使用自己的服务器

    最后配置rule.xml,我们在schema.xml中使用了mod-long规则,由于是两个节点来提供服务,这里我就将其设置为均分:比如插入时,一个一库,轮流进行

    这里写图片描述
    将count设置为2

    更多的配置规则与详情,请查看Mycat的官方文档,官网可以找到

    测试:为了方便我这里使用的是Navicat,读者也可以使用其他数据库连接工具

    首先查看本机Mysql:
    这里写图片描述

    查看云服务器Mysql:

    这里写图片描述

    连接Mycat中间件:
    这里写图片描述

    这里写图片描述

    查询操作:

    这里写图片描述

    插入操作1:

    insert into user(id,username,password,address,birthday,department_id) values(4,'帅哥1','123456','四川成都','2018-06-01',2);

    插入操作2:

    insert into user(id,username,password,address,birthday,department_id) values(5,'帅哥2','123456','四川成都','2018-06-01',2);

    这时候本机与云服务器的数据库,各插了一条,均匀分配。再次进入Mysql进行验证:

    本机Mysql:
    这里写图片描述

    云服务器Mysql:

    这里写图片描述

    再次查询:

    这里写图片描述

    可以看到这里顺序是有问题的,我们需要使用order by

    这里写图片描述

    现在顺序正常了,不过我们可以发现,我们以前的理所当然的sql语句可能出现很多不适用,比如上面出现的顺序问题,就需要依照Mycat的要求来写sql了

    参考:https://www.cnblogs.com/fyy-hhzzj/p/9044775.html

    我们在案例中实现了分表分库,那么读写分离等,九幽读者自行实现了,其实也很简单

    六、不适用的场景

    参考博客:https://blog.csdn.net/gaobudong1234/article/details/79581846

    谢谢大家的观看!

    展开全文
  • Mycat从入门到放弃

    万次阅读 多人点赞 2018-03-09 10:12:12
    Mycat中的路由结果是通过分片字段和分片方法来确定的。例如下图中的一个Mycat分库方案: 根据 tt_waybill 表的 id 字段来进行分片 分片方法为 id 值取 3 的模,根据模值确定在DB1,DB2,DB3中的某个分片 如果...

    当初写这篇文章的初衷只是想提醒自己在用一个开源产品前不仅要了解其提供的功能,更要了解其功能和场景边界。

    1.非分片字段查询

    Mycat中的路由结果是通过分片字段分片方法来确定的。例如下图中的一个Mycat分库方案:

    • 根据 tt_waybill 表的 id 字段来进行分片
    • 分片方法为 id 值取 3 的模,根据模值确定在DB1,DB2,DB3中的某个分片

    非分片字段查询

    如果查询条件中有 id 字段的情况还好,查询将会落到某个具体的分片。例如:

    mysql>select * from tt_waybill where id = 12330;

    此时Mycat会计算路由结果

    12330 % 3 = 0 –> DB1

    并将该请求路由到DB1上去执行。


    如果查询条件中没有 分片字段 条件,例如:

    mysql>select * from tt_waybill where waybill_no =88661;

    此时Mycat无法计算路由,便发送到所有节点上执行:

    DB1 –> select * from tt_waybill where waybill_no =88661;
    DB2 –> select * from tt_waybill where waybill_no =88661;
    DB3 –> select * from tt_waybill where waybill_no =88661;

    如果该分片字段选择度高,也是业务常用的查询维度,一般只有一个或极少数个DB节点命中(返回结果集)。示例中只有3个DB节点,而实际应用中的DB节点数远超过这个,假如有50个,那么前端的一个查询,落到MySQL数据库上则变成50个查询,会极大消耗Mycat和MySQL数据库资源。

    如果设计使用Mycat时有非分片字段查询,请考虑放弃!

    2.分页排序

    先看一下Mycat是如何处理分页操作的,假如有如下Mycat分库方案:
    一张表有30份数据分布在3个分片DB上,具体数据分布如下

    DB1:[0,1,2,3,4,10,11,12,13,14]
    DB2:[5,6,7,8,9,16,17,18,19]
    DB3:[20,21,22,23,24,25,26,27,28,29]

    (这个示例的场景中没有查询条件,所以都是全分片查询,也就没有假定该表的分片字段和分片方法)

    分页

    当应用执行如下分页查询时

    mysql>select * from table limit 2;

    Mycat将该SQL请求分发到各个DB节点去执行,并接收各个DB节点的返回结果

    DB1: [0,1]
    DB2: [5,6]
    DB3: [20,21]

    但Mycat向应用返回的结果集取决于哪个DB节点最先返回结果给Mycat。如果Mycat最先收到DB1节点的结果集,那么Mycat返回给应用端的结果集为 [0,1],如果Mycat最先收到DB2节点的结果集,那么返回给应用端的结果集为 [5,6]。也就是说,相同情况下,同一个SQL,在Mycat上执行时会有不同的返回结果。

    在Mycat中执行分页操作时必须显示加上排序条件才能保证结果的正确性,下面看一下Mycat对排序分页的处理逻辑。
    假如在前面的分页查询中加上了排序条件(假如表数据的列名为id

    mysql>select * from table order by id limit 2;

    Mycat的处理逻辑如下图:

    排序分页

    在有排序呢条件的情况下,Mycat接收到各个DB节点的返回结果后,对其进行最小堆运算,计算出所有结果集中最小的两条记录 [0,1] 返回给应用。

    但是,当排序分页中有 偏移量 (offset)时,处理逻辑又有不同。假如应用的查询SQL如下:

    mysql>select * from table order by id limit 5,2;

    如果按照上述排序分页逻辑来处理,那么处理结果如下图:

    排序偏移分页

    Mycat将各个DB节点返回的数据 [10,11], [16,17], [20,21] 经过最小堆计算后返回给应用的结果集是 [10,11]。可是,对于应用而言,该表的所有数据明明是 0-29 这30个数据的集合,limit 5,2 操作返回的结果集应该是 [5,6],如果返回 [10,11] 则是错误的处理逻辑。

    所以Mycat在处理 有偏移量的排序分页 时是另外一套逻辑——改写SQL 。如下图:

    正确排序偏移分页

    Mycat在下发有 limit m,n 的SQL语句时会对其进行改写,改写成 limit 0, m+n 来保证查询结果的逻辑正确性。所以,Mycat发送到后端DB上的SQL语句是

    mysql>select * from table order by id limit 0,7;

    各个DB返回给Mycat的结果集是

    DB1: [0,1,2,3,4,10,11]
    DB2: [5,6,7,8,9,16,17]
    DB3: [20,21,22,23,24,25,26]

    经过最小堆计算后得到最小序列 [0,1,2,3,4,5,6] ,然后返回偏移量为5的两个结果为 [5,6]

    虽然Mycat返回了正确的结果,但是仔细推敲发现这类操作的处理逻辑是及其消耗(浪费)资源的。应用需要的结果集为2条,Mycat中需要处理的结果数为21条。也就是说,对于有 t 个DB节点的全分片 limit m, n 操作,Mycat需要处理的数据量为 (m+n)*t 个。比如实际应用中有50个DB节点,要执行limit 1000,10操作,则Mycat处理的数据量为 50500 条,返回结果集为10,当偏移量更大时,内存和CPU资源的消耗则是数十倍增加。

    如果设计使用Mycat时有分页排序,请考虑放弃!

    3.任意表JOIN

    先看一下在单库中JOIN中的场景。假设在某单库中有 playerteam 两张表,player 表中的 team_id 字段与 team 表中的 id 字段相关联。操作场景如下图:

    单个DB中JOIN

    JOIN操作的SQL如下

    mysql>select p_name,t_name from player p, team t where p.no = 3 and p.team_id = t.id;

    此时能查询出结果

    p_name t_name
    Wade Heat


    如果将这两个表的数据分库后,相关联的数据可能分布在不同的DB节点上,如下图:

    分库JOIN

    这个SQL在各个单独的分片DB中都查不出结果,也就是说Mycat不能查询出正确的结果集。

    设计使用Mycat时如果要进行表JOIN操作,要确保两个表的关联字段具有相同的数据分布,否则请考虑放弃!

    4.分布式事务

    Mycat并没有根据二阶段提交协议实现 XA事务,而是只保证 prepare 阶段数据一致性的 弱XA事务 ,实现过程如下:

    应用开启事务后Mycat标识该连接为非自动提交,比如前端执行

    mysql>begin;

    Mycat不会立即把命令发送到DB节点上,等后续下发SQL时,Mycat从连接池获取非自动提交的连接去执行。

    弱XA事务1

    Mycat会等待各个节点的返回结果,如果都执行成功,Mycat给该连接标识为 Prepare Ready 状态,如果有一个节点执行失败,则标识为 Rollback 状态。

    弱XA事务2

    执行完成后Mycat等待前端发送 commitrollback 命令。发送 commit 命令时,Mycat检测当前连接是否为 Prepare Ready 状态,若是,则将 commit 命令发送到各个DB节点。

    弱XA事务3

    但是,这一阶段是无法保证一致性的,如果一个DB节点在 commit 时故障,而其他DB节点 commit 成功,Mycat会一直等待故障DB节点返回结果。Mycat只有收到所有DB节点的成功执行结果才会向前端返回 执行成功 的包,此时Mycat只能一直 waiting 直至TIMEOUT,导致事务一致性被破坏。

    设计使用Mycat时如果有分布式事务,得先看是否得保证事务得强一致性,否则请考虑放弃!

    展开全文
  • MyCat是什么?这个概念可大可小,作为使用者,我的理解是这样的: MyCat是一款开源的数据库中间件 什么是中间件?中间件是什么东西? 可以理解为在两个东西中间起到衔接协调作用的这么一个东西。在软件架构中的位置...
  • Mycat

    千次阅读 2019-10-26 10:01:47
    文章目录一、Mycat介绍1、是什么(数据库中间件)2、干什么的(1)读写分离(2)数据分片(3)多数据源整合3、原理4、Mycat监控5、Mycat架构二、安装启动1、安装2、三个文件3、启动前先修改schema.xml4、再修改...
  • Mycat介绍及简单使用

    千次阅读 2018-03-27 10:20:42
    今天我们来简单的介绍下数据库中间件——Mycat,以及它的简单使用Mycat概述Mycat是数据库中间件,就是介于数据库与应用之间,进行数据处理与交互的中间服务。对数据进行分片处理之后,从原有的一个库,被切分为多个...
  • Mycat深入学习

    千次阅读 2018-11-24 15:20:50
    Mycat深入学习   海量数据的存储问题 如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB。对数据的各种操作也是愈加的困难,传统的关系性数据库已经无法满足快速查询与插入数据的需求。这个时候...
  • Linux启动/停止/重启Mycat

    千次阅读 2018-02-05 10:51:20
    启动MyCat:  ./mycat start  查看启动状态:  ./mycat status  停止:  ./mycat stop  重启:  ./mycat restart
  • 使用Navicat连接Mycat的诡异事件

    千次阅读 2018-05-29 12:54:46
    在家搭建Mycat进行测试,当使用Navicat连接时,报错 no mycat database selected,检查了mycat配置文件,是没有配错的,百思不得其姐 原因 Mycat不支持低版本的工具连接,家里的Navicat是8.0版本,需要升级到较...
  • mycat 测试后的结果让我决定放弃mycat作为中间件

    万次阅读 热门讨论 2018-09-27 17:06:02
    需求:mycat 出来好几年了,而且还是阿里的大神开发的产品,目前国内的mysql中间件它的名气最大且免费使用,我是打算先把mycat 做中间件 使用它的负载均衡和读写分离功能来达到mysql 数据库的高可用高性能高并发;...
  • MyCat - 使用篇(6)

    万次阅读 热门讨论 2016-02-24 17:16:05
    数据库路由中间件MyCat - 使用篇(5)配置MyCat-eye接下来在开始使用MyCat之前,我们先把监控平台部署好。下载MyCat-eye项目,mvn打包。之后得到类似于Mycat-web-1.0-SNAPSHOT-20160215151602-linux.tar.gz这个文件...
  • Mycat和Sharding-jdbc的区别

    千次阅读 2019-05-10 11:33:38
    http://www.cnblogs.com/leeSmall/p/9539370.html
  • 本地环境:mycat+mybatis+springboot实现demo

    万次阅读 热门讨论 2017-12-11 21:47:33
    mycat+mybatis+springboot的简单demo实现
  • linux安装及配置mycat eye可视化监控界面

    万次阅读 热门讨论 2019-03-18 20:13:15
    强烈推荐一个大神的人工... 一、安装jdk环境 Mycat eye依赖jdk1.7及以上的环境,首先先安装jdk 二、Zookeeper环境 Mycat需要zookeeper作为注册中心,所以需要先安装zookeeper: 1.下载zookeeper,zookeeper-3.4...
  • mycat遇到no mycat database selected

    千次阅读 热门讨论 2018-06-08 22:32:02
    今天在用Navicat for MySQL连接mycat时总是出现no mycat database selected问题,在命令行重连接mycat正常,日志也显示正常,一直百思不得其解,后来发现是自己的Navicat版本太低了,用的还是8,换成了Navicat ...
  • MyCat在MySQL主从复制基础上实现读写分离
  • Mycat-eye使用入门教程

    千次阅读 2017-02-25 11:35:32
    下载地址在mycat的官网上,目前的版本为1.0,主要是对mycat,mysql,jvm以及sql执行情况的统计展示工具。 下载地址 前置条件 必须先提前在自己的机器上暗转zookeeper,因为各种节点数据都是通过zk来管理的。 zk安装...
  • Mycat使用之MySQL单库分表及均分数据

    万次阅读 2017-11-19 12:44:16
    Mycat安装部署之MySQL单库分表及写入数据均分
1 2 3 4 5 ... 20
收藏数 25,167
精华内容 10,066
关键字:

mycat