MySQL运维13-Mycat分库分表之按月分片

这篇具有很好参考价值的文章主要介绍了MySQL运维13-Mycat分库分表之按月分片。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、按照月分片

  使用场景为按照自然月来分片,每个自然月为一个分片,但是一年有12个月,是不是要有12个数据节点才行呢?并不是。例如我现在只有三个分片数据库,这样就可以1月在第一个数据分片中,2月在第二个数据分片中,3月在第三个数据分片中,当来到4月的时候,就会重新开始分片,4月在第一个数据分片,5月在第二个数据分片,6月在第三个数据分片,以此类推。

  MySQL运维13-Mycat分库分表之按月分片

  说明1:从开始时间开始,一个月为一个分片,到达结束时间之后,会重复开始分片插入

  说明2:配置表的dataNode的分片,必须和分片规则数量一致,例如:2023-01-01到2023-12-31,一共就需要12个数据节点

  说明3:我只有三个数据节点,所以配置表中,我只需要配置2023-01-01到2023-03-31即可,即使一年又12个月会可以重复插入的。  

二、准备工作

  使用之前已经创建tb_logs数据库

  MySQL运维13-Mycat分库分表之按月分片

三、rule.xml配置 

  MySQL运维13-Mycat分库分表之按月分片

  说明1:分片规则:"sharding-by-month"

  说明2:分库分表字段为create_time

  说明3:dateFormat为时间格式

  说明4:sBeginDate是配置的起始日期

  说明5:sEndDate是配置的结束日期

  说明6:有几台数据节点,就只需要配置几个月的范围即可,即开始日期到结束日期的月份要等于数据节点的数。

四、配置schem.xml

  MySQL运维13-Mycat分库分表之按月分片

  说明1:逻辑库为hl_logs

  说明2:逻辑表为tb_month

  说明3:分片规则为:"sharding-by-month"

  MySQL运维13-Mycat分库分表之按月分片

  MySQL运维13-Mycat分库分表之按月分片

  说明4:dn4对应的是dbhost1即192.168.3.90分片

  说明5:dn5对应的是dbhost2即192.168.3.91分片

  说明6:dn6对应的是dbhost3即192.168.3.92分片

五、配置server.xml

  MySQL运维13-Mycat分库分表之按月分片

  说明1:在之前的文章中已经将tb_logs表添加到root用户的权限中了,所以这里不需要更改即可。

六、按(月)日期分片测试

  首先重启Mycat

  MySQL运维13-Mycat分库分表之按月分片

  登录Mycat

  MySQL运维13-Mycat分库分表之按月分片

  查看逻辑库和逻辑表

  MySQL运维13-Mycat分库分表之按月分片

  这里的tb_month只是逻辑库,而在MySQL中还并没有tb_month这个表,需要在Mycat中创建

create table tb_month(id int auto_increment primary key, name varchar(20), create_time varchar(19));

  MySQL运维13-Mycat分库分表之按月分片   

  插入一组测试数据

insert into tb_month(name, create_time) values ("张三", "2023-01-02");
insert into tb_month(name, create_time) values ("李四", "2023-02-12");
insert into tb_month(name, create_time) values ("王五", "2023-03-22");
insert into tb_month(name, create_time) values ("赵六", "2023-04-18");
insert into tb_month(name, create_time) values ("侯七", "2024-05-01");
insert into tb_month(name, create_time) values ("孙八", "2024-06-11");
insert into tb_month(name, create_time) values ("周九", "2024-07-21");

  MySQL运维13-Mycat分库分表之按月分片

  MySQL运维13-Mycat分库分表之按月分片

  说明1:一共三个数据节点,其中1月,4月,7月,10月的数据会分布在192.168.3.90第一个数据节点上,OK

  MySQL运维13-Mycat分库分表之按月分片

  说明2:一共三个数据节点,其中2月,5月,8月,11月的数据会分布在192.168.3.91第二个数据节点上,OK

  MySQL运维13-Mycat分库分表之按月分片

  说明3:一共三个数据节点,其中3月,6月,9月,12月的数据会分布在192.168.3.92第三个数据节点上,OK

  MySQL运维13-Mycat分库分表之按月分片

  说明4:在Mycat上进行查询的数据是,所有数据节点的全集。按(月)日期分片是水平分库分表的一种方式。

 

 

 

  文章来源地址https://www.toymoban.com/news/detail-760314.html

到了这里,关于MySQL运维13-Mycat分库分表之按月分片的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • mysql运维------分库分表

    随着互联网以及移动互联网的发展,应用系统的数据量也是成指数式增长,若采用单数据库进行数据存储,存在以下性能瓶颈: IO瓶颈 :热点数据太多,数据库缓存不足,产生大量磁盘IO,效率较低。请求数据太多,带宽不够,网络IO瓶颈。 CPU瓶颈 :排序、分组、连接查询、

    2023年04月11日
    浏览(45)
  • MySQL运维3-分库分表策略

    单库瓶颈:如果在项目中使用的都是单MySQL服务器,则会随着互联网及移动互联网的发展,应用系统的数据量也是成指数式增长,若采用单数据库进行存储,存在一下性能瓶颈: IO瓶颈:热点数据太多,数据库缓存不足,产生大量磁盘IO,效率低下,请求数据太多,带宽不够,

    2024年02月05日
    浏览(41)
  • Mycat分库分表实时同步到GreatSQL

    MyCat作为经典的分库分表中间件,在长时间内被广泛认为是管理超大MySQL数据库集合的有效解决方案。近来接到客户需求,需要将MyCat集群迁移到GreatSQL中,并且在一段时间内需要实时从MyCat中同步数据到GreatSQL中,全量同步数据比较容易操作,增量同步有如下两个棘手的问题:

    2024年02月03日
    浏览(43)
  • 15天学习MySQL计划(运维篇)分库分表-监控-第十四天

    1.介绍 1.问题分析 ​ 随着互联网及移动互联网的发展,应用系统的数据量也是成指数式增加,若采用但数据进行数据存储,存在以下性能瓶颈: IO瓶颈:热点数据太多,数据库缓存不足,产生大量磁盘IO,效率较低。请求数据太多,带宽不够,网络IO瓶颈。 CPU瓶颈:排序,分

    2024年02月05日
    浏览(49)
  • MyCat2介绍以及部署和读写分离/分库分表(MyCat2.0)

    1.什么是mycat ​ mycat是数据库中间件 它可以干什么? 读写分离 数据分片:垂直拆分,水平拆分 多数据源整合 2.数据库中间件 ​ 中间件:是一类连接软件组件和应用的计算机软件,以便于软件各部件之间的沟通。 ​ 例子:tomcat,kafka,redis等中间件 3.为什么使用macat java与数

    2024年02月09日
    浏览(41)
  • MySQL 数据存储和优化------MySQL索引原理和优化 ---- (架构---索引---事务---锁---集群---性能---分库分表---实战---运维)持续更新

    Mysql架构体系全系列文章主目录(进不去说明还没写完) https://blog.csdn.net/grd_java/article/details/123033016 本文只是整个系列笔记的第二章:MySQL索引原理和优化,只解释索引相关概念。 索引可以提高查询效率,影响where查询和order by排序,它可以从多方面进行分类,但是实际创建时

    2024年02月02日
    浏览(54)
  • 分库分表如何管理不同实例中几万张分片表?

    在进行分库分表设计时,确认好了数据节点数量和分片策略以后,接下来要做的就是管理大量的分片表。实际实施过程中可能存在上百个分片数据库实例,每个实例中都可能有成千上万个分片表,如果仅依靠人力来完成这些任务显然是不现实的。所以,想要快速且自动化管理

    2024年03月12日
    浏览(77)
  • Sharding-JDBC分库分表四种分片算法

    精确分片算法(PreciseShardingAlgorithm)精确分片算法(=与IN语句),用于处理使用单一键作为分片键的=与IN进行分片的场景。需要配合StandardShardingStrategy使用 范围分片算法(RangeShardingAlgorithm)用于处理使用单一键作为分片键的BETWEEN AND进行分片的场景。需要配合StandardShardingS

    2024年02月10日
    浏览(40)
  • Sharding-JDBC分库分表-自动配置与分片规则加载原理-3

    Sharding JDBC自动配置的原理 与所有starter一样,shardingsphere-jdbc-core-spring-boot-starter也是通过SPI自动配置的原理实现分库分表配置加载,spring.factories文件中的自动配置类shardingsphere-jdbc-core-spring-boot-starter功不可没,他主要是自动创建了模式bean、事务类型bean和数据源bean,配置加载

    2024年02月10日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包