Mycat快速入门(一),【Mycat是什么】

2 篇文章 0 订阅

  • mycat
  • mycat能做什么(功能)
  • 原理
  • 名词解释

一、MyCat:

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

Mycat是数据库分库分表的中间件,Mycat使用最多的两个功能是:读写分离和分库分表功能,支持全局表和E-R关系(这两个比较实用)。

数据库中间件:是一类链接软件组件和应用的计算机软件,以便于各部分之间的沟通。
栗子:Tomcat、web中间件
数据库中间件:链接java应用程序和数据库

在这里插入图片描述

二、Mycat能做什么(功能)

1. 读写分离

在这里插入图片描述
在这里插入图片描述

2. 数据分片
在这里插入图片描述
3. 多数据源整合

在这里插入图片描述

三、原理

Mycat 的原理中最重要的就是“拦截”,它拦截了用户发送过来的SQL语句,首先对SQL语句做了一些特定的分析:比如 分片分析、路由分析、读写分析、读写分离饭呢西、缓存分析等等,然后将此SQL法网后端的真是数据库,并将返回的结果做适当的处理,最终再返回给用户。

四、名词解释

逻辑库(schema)

数据库中间件,通常对实际应用来说,并不需要知道中间件的存在,业务开发人员只需要知道数据库的概念,所以数据库中间件可以被看做是一个或多个数据库集群构成的逻辑库。

逻辑表(table)

既然有逻辑库,那么就会有逻辑表,分布式数据库中,对应用来说,读写数据的表就是逻辑表。逻辑表,可以是数据切分后,分布在一个或多个分片库中,也可以不做数据切分,不分片,只有一个表构成。

分片表

 是指那些原有的很大数据的表,需要切分到多个数据库的表,这样,每个分片都有一部分数据,所有分片构成了完整的数据。 总而言之就是需要进行分片的表。

非分片表

 一个数据库中并不是所有的表都很大,某些表是可以不用进行切分的,非分片是相对分片表来说的,就是那些不需要进行数据切分的表。

分片节点(dataNode)

数据切分后,一个大表被分到不同的分片数据库上面,每个表分片所在的数据库就是分片节点(dataNode)。

节点主机(dataHost)

数据切分后,每个分片节点(dataNode)不一定都会独占一台机器,同一机器上面可以有多个分片数据库,这样一个或多个分片节点(dataNode)所在的机器就是节点主机(dataHost),为了规避单节点主机并发数限制,尽量将读写压力高的分片节点(dataNode)均衡的放在不同的节点主机(dataHost)。

分片规则(rule)

前面讲了数据切分,一个大表被分成若干个分片表,就需要一定的规则,这样按照某种业务规则把数据分到某个分片的规则就是分片规则,数据切分选择合适的分片规则非常重要,将极大的避免后续数据处理的难度。

文章持续更新:欢迎各位小伙伴关注我的公众号:菜丸的程序屋。希望将我的不足之处给予指点,谢谢大家。喜欢Java,热衷学习的小伙伴可以加我微信: CaiWan_Y

在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值