关于MyCat,入门到放弃(一、简介)

一、什么是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,而且还能读写分离,进而提升集群的并发能力。

  • 5
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要实现Mycat中间件的读写分离一主两从,需要按照以下步骤进行配置: 1. 在你的Mycat配置文件中,找到并编辑`server.xml`文件。你可以参考之前提到的文章《CentOS下安装和使用Mycat实现分布式数据库》中的配置方法。确保你已经正确配置了Mycat的主节点和两个从节点。 2. 在`server.xml`文件中,找到`<dataHost>`标签,并按照以下格式添加两个从节点的配置信息。例如: ```xml <dataHost name="node2" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native"> <heartbeat>select user()</heartbeat> <writeHost host="node1" url="192.168.0.1:3306" user="root" password="root"/> <readHost host="node2" url="192.168.0.2:3306" user="root" password="root"/> </dataHost> <dataHost name="node3" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native"> <heartbeat>select user()</heartbeat> <writeHost host="node1" url="192.168.0.1:3306" user="root" password="root"/> <readHost host="node3" url="192.168.0.3:3306" user="root" password="root"/> </dataHost> ``` 这里的`node2`和`node3`是从节点的名称,`192.168.0.1`是主节点的IP地址和端口号,`192.168.0.2`和`192.168.0.3`分别是两个从节点的IP地址和端口号。请根据你的实际情况进行修改。 3. 在`server.xml`文件中,找到`<schema>`标签,添加以下配置信息来指定读写分离规则: ```xml <schema name="testdb" checkSQLschema="false" sqlMaxLimit="100"> <table name="user" primaryKey="id" dataNode="node1,node2,node3" rule="mod-long" /> </schema> ``` 这里的`testdb`是数据库的名称,`user`是表的名称,`node1,node2,node3`是数据节点的名称,`rule="mod-long"`表示使用取模的方式进行读写分离。请根据你的实际情况进行修改。 4. 保存并关闭`server.xml`文件。 5. 重启Mycat服务。 这样,你就成功配置了Mycat中间件的读写分离,其中包括一个主节点和两个从节点。当有读操作时,Mycat会自动将读请求分发给从节点进行处理,实现了读写分离的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mycat中间件实现一主一从和双主双从的读写分离](https://blog.csdn.net/qq_33200967/article/details/80948708)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Mycat搭建读写分离(一主一从、双主双从)](https://blog.csdn.net/qq_41779565/article/details/125375231)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值