mysql分库分表_后序查询操作待补充

多少条开始多表?什么场景分库?
单表几百万条数据,对读写操作影响较大

数据库分库分表,何时分?怎样分?详细解读,一篇就够了 【https://blog.csdn.net/azhuyangjun/article/details/86976514】
1、能不切分尽量不要切分

并不是所有表都需要进行切分,主要还是看数据的增长速度。切分后会在某种程度上提升业务的复杂度,数据库除了承载数据的存储和查询外,协助业务更好的实现需求也是其重要工作之一。

不到万不得已不用轻易使用分库分表这个大招,避免"过度设计"和"过早优化"。分库分表之前,不要为分而分,先尽力去做力所能及的事情,例如:升级硬件、升级网络、读写分离、索引优化等等。当数据量达到单表的瓶颈时候,再考虑分库分表。

2、数据量过大,正常运维影响业务访问

这里说的运维,指:

1)对数据库备份,如果单表太大,备份时需要大量的磁盘IO和网络IO。例如1T的数据,网络传输占50MB时候,需要20000秒才能传输完毕,整个过程的风险都是比较高的

2)对一个很大的表进行DDL修改时,MySQL会锁住全表,这个时间会很长,这段时间业务不能访问此表,影响很大。如果使用pt- online-schema-change,使用过程中会创建触发器和影子表,也需要很长的时间。在此操作过程中,都算为风险时间。将数据表拆分,总量减 少,有助于降低这个风险。

3)大表会经常访问与更新,就更有可能出现锁等待。将数据切分,用空间换时间,变相降低访问压力

3、随着业务发展,需要对某些字段垂直拆分

4、数据量快速增长

随着业务的快速发展,单表中的数据量会持续增长,当性能接近瓶颈时,就需要考虑水平切分,做分库分表了。此时一定要选择合适的切分规则,提前预估好数据容量

5、安全性和可用性

鸡蛋不要放在一个篮子里。在业务层面上垂直切分,将不相关的业务的数据库分隔,因为每个业务的数据量、访问量都不同,不能因为一个业务把数 据库搞挂而牵连到其他业务。利用水平切分,当一个数据库出现问题时,不会影响到100%的用户,每个库只承担业务的一部分数据,这样整体的可用性就能提 高。

======================================mysql 分库分表======================================
垂直拆分
    分表:将不经常用或字段长度较大的字段拆分去扩展表中。
    分库:根据业务的耦合性,将关联度低的不同表存储在不同的数据库中。

    垂直切分的优点:

    ·解决业务系统层面的耦合,业务清晰
    ·与微服务的治理类似,也能对不同业务的数据进行分级管理、维护、监控、扩展等
    ·高并发场景下,垂直切分一定程度的提升IO、数据库连接数、单机硬件资源的瓶颈
    缺点:

    ·部分表无法join,只能通过接口聚合方式解决,提升了开发的复杂度
    ·分布式事务处理复杂
    ·依然存在单表数据量过大的问题(需要水平切分)



水平拆分

    水平切分的优点:

    ·不存在单库数据量过大、高并发的性能瓶颈,提升系统稳定性和负载能力
    ·应用端改造较小,不需要拆分业务模块
    缺点:

    ·跨分片的事务一致性难以保证
    ·跨库的join关联查询性能较差
    ·数据多次扩展难度和维护量极大
    ·水平切分后同一张表会出现在多个数据库/表中,每个库/表的内容不同。

 ======================================mysql 分库分表 后的查询操作======================================
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值