MyCat教程【分库分表】

简介: 本文我们来介绍下MyCat的分库分表操作

本文我们来介绍下MyCat的分库分表操作


分库分表


一、分片规则介绍


 在rule.xml中定义了各种myCat支持的分片规则。


取模mod-long

自然月分片 sharding-by-month

按日期(天)分片sharding-by-date

按单月小时拆分sharding-by-hour

范围约定,提前规划好分片字段某个范围属于哪个分片,auto-sharding-long

范围求模分片

取模范围约束sharding-by-pattern

分片枚举sharding-by-intfile

固定分片hash算法

截取数字hash解析sharding-by-stringhash

一致性hash

日期范围hash分片rangeDateHash

截取数字做hash求模范围约束sharding-by-prefixpattern

应用指定,在运行阶段有应用自主决定路由到那个分片。sharding-by-substring

冷热数据分片 sharding-by-date

有状态分片算法

crc32slot分片算法

注意:


id中推荐配置主键列

所有的 tableRule 只能使用一次。如果需要为多个表配置相同的分片规则,那么需要在此重新定义该规则。

在 crc32Slot 算法中的分片数量一旦给定,MyCat 会将该分片数量和 slor 的取值范围保存到文件中。在次修改分片数量时是不会生效的,需要将该文件删除。文件位置位于 conf目录中的 ruledata 目录中。

二、分库配置


2.1 创建3个数据库


 在master中分别创建3个数据库demo1,demo2,demo3,因为主从的关系会同步到从库中。


create database demo1 default character set utf8;
create database demo2 default character set utf8;
create database demo3 default character set utf8;

20191016161140184.png



2.2 schema.xml配置


 修改schema.xml文件中的信息,如下:

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
  <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100">
    <table name="t_user" dataNode="dn1,dn2,dn3" rule="crc32slot" />
  </schema>
  <dataNode name="dn1" dataHost="localhost1" database="demo1" />
  <dataNode name="dn2" dataHost="localhost1" database="demo2" />
  <dataNode name="dn3" dataHost="localhost1" database="demo3" />
  <dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
        writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
    <heartbeat>select user()</heartbeat>
    <!-- can have multi write hosts -->
    <writeHost host="hostM1" url="192.168.88.180:3306" user="root"
           password="123456">
      <!-- can have multi read hosts -->
      <readHost host="hostS2" url="192.168.88.181:3306" user="root" password="123456" />
    </writeHost>
  </dataHost>
</mycat:schema>


注意:


因为有三个库,所以添加了三个dataNode

使用的分配规则是crc32slot

主从和读写分离设置没有动,所以writeHost和readHost的配置没变

2.3 修改rule.xml文件


 因为使用的是crc32slot算法,且有3个数据库,所以需要修改rule.xml中的配置

20191016163425142.png


同时我们需要删除掉ruledata目录中的规则文件,不然修改的3不会起作用


20191016163719535.gif


重启mycat服务


20191016162843797.png


查看分配规则


20191016163801734.png


2.3 在mycat中创建t_user表


 先删除原来创建的t_user表,然后通过mycat创建t_user表示,通过mycat创建会多出来一个_slot字段。

CREATE TABLE t_user (
  `id` INT,
  `name` VARCHAR (30),
  `age` INT,
  PRIMARY KEY (`id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8;

20191016163115502.gif



三、分库测试


 在mycat客户端插入数据,然后去对应的物理库中查询具体的情况

insert into t_user(id,name,age)values(1,'波波烤鸭',18)


注意:插入语句的语法要完整,不要偷懒省略字段,尤其是id自增长

20191016164100547.gif

数据按照我们设置的规则分别存储到了各自数据的表结构中了。


然后我们来看下查询操作,通过mycat看能否将所有的数据都查询出来,


20191016164319609.png

相关文章
|
SQL 关系型数据库 MySQL
MyCat2介绍以及部署和读写分离/分库分表(MyCat2.0)
MyCat2介绍以及部署和读写分离/分库分表(MyCat2.0)
2172 0
|
Rust 物联网 人机交互
一文看懂蓝牙在物联网中的应用场景
蓝牙作为一项发明于上世纪的近距离无线通信技术,在手机,电脑领域已经有了充分地基础,那么这项技术在物联网领域又会有哪些应用场景呢?
一文看懂蓝牙在物联网中的应用场景
|
存储 SQL 关系型数据库
使用MyCat单库分表实战详解
本文目录 1. 场景 2. 实现 3. 配置真实服务器信息 4. 配置路由规则 5. 配置MyCat服务信息 6. 启动测试
1330 0
使用MyCat单库分表实战详解
|
数据可视化 数据挖掘
4. Excel高效操作
【10月更文挑战第20天】4. Excel高效操作
101 4
|
存储 Docker 容器
docker中挂载现有目录作为数据卷
【10月更文挑战第14天】
238 1
|
NoSQL 关系型数据库 Redis
高可用和性能:基于ACK部署Dify的最佳实践
本文介绍了基于阿里云容器服务ACK,部署高可用、可伸缩且具备高SLA的生产可用的Dify服务的详细解决方案。
|
监控 Java 数据库
SpringBoot 实现动态切换数据源:优雅之道
在微服务架构和复杂的应用系统中,随着业务规模的扩大,单个数据源往往无法满足多样化的数据访问需求。这时,动态切换数据源成为了一个重要的技术需求,它允许应用程序在运行时根据业务逻辑或用户请求,灵活地选择不同的数据源进行操作。在Spring Boot框架中,实现数据源的动态切换既是一项挑战,也是一项展现技术优雅性的机会。以下,我们将深入探讨如何在Spring Boot中实现数据源的动态切换,并追求实现的优雅性。
749 1
|
存储 算法 容器
顺序栈的实现
顺序栈的实现
165 0
|
机器学习/深度学习 资源调度 PyTorch
面向大规模分布式训练的资源调度与优化策略
【8月更文第15天】随着深度学习模型的复杂度不断提高,对计算资源的需求也日益增长。为了加速训练过程并降低运行成本,高效的资源调度和优化策略变得至关重要。本文将探讨在大规模分布式训练场景下如何有效地进行资源调度,并通过具体的代码示例来展示这些策略的实际应用。
1367 1
|
存储 Kubernetes 监控
KubeSphere平台安装系列之一【Kubernetes上安装KubeSphere(亲测--实操完整版)】(1/3)
KubeSphere平台安装系列之一【Kubernetes上安装KubeSphere(亲测--实操完整版)】(1/3)
564 0