摘要:个人博客地址方案项目背景在现在题库架构下,针对新购买的多道数据进行整合,不影响现有功能。数据切分尽量通过数据冗余或表分组来降低跨库的可能。
个人博客地址 https://www.texixi.com/2019/0...方案 项目背景
在现在题库架构下,针对新购买的1300W多道数据进行整合,不影响现有功能。由于数据量偏多,需要进行数据的切分
目标场景兼容旧的功能
对1300多W数据进行分库分表
需要对旧的数据进行整合
老师端选题组卷 可以根据 学段、学科、知识点、难度、题型 来筛选
学生端根据老师端所选题目获取对应的题目
对3年内以后扩展的增量数据预留数量空间
数据样例学段 | 数据量 |
---|---|
小学 | 1285336 |
初中 | 6655780 |
高中 | 6144072 |
学段学科 | 数据量 |
---|---|
初中数学 | 1869524 |
初中化学 | 1356224 |
初中英语 | 288440 |
切分为3个库, 分别是小学、初中、高中 数据占比如上
每个库切分10个表 根据 (学科+首级知识点)%10
每个库一个总表
缺点:例:用到不同知识点时,需要多表获取数据
优点:数据分布较为平均
切分方案二 (采用)切分为3个库, 分别是小学、初中、高中 数据占比如上
每个库切分10个表(全部10个学科) 根据 学科区分, 例: 数学表、物理表
每个库一个总表
缺点:数据不大平均, 数据量多的例数学有186W多、英语28W多
优点:当有用到组卷等需要筛选多知识点题目时,不用多表查询
数据id 自增区间划分小学 1-2亿
中学 2-3亿
高中 3亿起
关联关系图 根据知识点获取题目流程 自增id对原有的id区间段不做处理
对切分后的id自增段进行规划
兼容旧功能新旧数据有重复的知识点、题目
新旧数据的结构不一样
对旧的题库功能代码的修改
两套题库合并主键冲突问题
有操作的旧的数据洗入新的结构,旧的数据只为兼容原有的功能数据,不做显示。
优点:
不用变动数据结构,最新的购买的数据结构较为清晰。 易维护扩展,因为目前旧的数据已经整合了两套数据
缺点:
需要修改全部旧有的功能代码(针对新的数据结构)
把新购买的数据整合进老的数据结构,同时保留三批数据,需要处理所有表的主键冲突、三批各表数据去重
优点:
旧有代码只修改数据结构切分的部分,不用全部修改功能代码
缺点:
数据较乱,三套不同的数据同时存在数据库
需要处理新的结构整合进旧的数据结构,同时需要处理主键冲突,
代码上需要处理对应的数据
问题点测试环境和正式环境图片存放在那里?100多G,上传cdn需要几十天时间,有4000多W张,目前cdn不支持打包上传
解决方案:购买多带带服务器,主备,存放图片
测试db 正式db 1300多w 目前占用100G左右, 需要存放空间
解决方案:测试环境新加硬盘,新加db实例端口3307,正式环境db存放在图片服务器
代码设计模式采用适配器模式(原先的代码结构不变)
类图
调研内容 中间件MYCAT(未使用)一个彻底开源的,面向企业应用开发的大数据库集群
支持事务、ACID、可以替代MySQL的加强版数据库
一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群
一个融合内存缓存技术、NoSQL技术、HDFS大数据的新型SQL Server
结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品
一个新颖的数据库中间件产品
==支持库内分表(1.6)==
==支持单库内部任意join,支持跨库2表join,甚至基于caltlet的多表join==
支持全局序列号,解决分布式下的主键生成问题。
==分片规则丰富==,插件化开发,易于扩展。
基于Nio实现,有效管理线程,解决高并发问题。
==支持通过全局表,ER关系的分片策略,实现了高效的多表join查询==
支持分布式事务(弱xa)。
支持SQL黑名单、sql注入攻击拦截
==支持MySQL、Oracle、DB2、SQL Server、PostgreSQL等DB的常见SQL语法==
==遵守Mysql原生协议==,跨语言,跨平台,跨数据库的通用中间件代理。
==基于心跳的自动故障切换,支持读写分离,支持MySQL主从,==以及galera cluster集群。
可以大幅降低开发难度,提升开发速度
具体看 mycat 官网
全局表一致性检测 1.6版本开始支持(一致性的定时检测)
分片 join(尽量避免使用 Left join 或 Right join,而用 Inner join)
应用要面对很多个数据库的时候,这个时候就需要对数据库层做一个抽象,来管理这些数据库,而最上面的应用只需要面对一个数据库层的抽象或者说数据库中间件就好了,这就是Mycat的核心作用。
分片分析、路由分析、读写分离分析、缓存分析等,然后将此SQL发往后端的真实数据库,并将返回的结果做适当的处理,最终再返回给用户。
读写分离,配置简单
分表分库,对于超过1000万的表进行分片,最大支持1000亿的单表分片
报表系统,借助于Mycat的分表能力,处理大规模报表的统计
应用场景 那些适合,那些不适合 https://www.cnblogs.com/barry...
使用说明 https://juejin.im/post/59c325...
总表使用mysql MERGE 引擎(不考虑)合并的表使用的必须是MyISAM引擎
表的结构必须一致,包括索引、字段类型、引擎和字符集
对于增删改查,直接操作总表即可。
数据切分原则能不切分尽量不要切分。
如果要切分一定要选择合适的切分规则,提前规划好。
数据切分尽量通过数据冗余或表分组(Table Group)来降低跨库 Join 的可能。
由于数据库中间件对数据 Join 实现的优劣难以把握,而且实现高性能难度极大,业务读取尽量少使用多表 Join。
尽可能的比较均匀分布数据到各个节点上
该业务字段是最频繁的或者最重要的查询条件。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30062.html
摘要:开篇金币积分商城下称商城是众多内的一个产品,随着使用的用户越来越多,商城对于用户留存的提升,扮演着重要的角色做为提高用户黏性的核心产品,在拥有很好用户体验的同时,也必须存在着一个高效稳定的系统。分析上述两点,得到结论按用户进行分库分表。 开篇 金币(积分)商城(下称商城)是众多App内的一个产品,随着App使用的用户越来越多,商城对于用户留存的提升,扮演着重要的角色;做为提高用户黏性的...
摘要:这里有一份面试题相关总结,涉及高并发分布式高可用相关知识点,在此分享给大家,希望大家能拿到一份理想的知识点会陆续更新在上,觉得还算凑和的话可以关注一下噢高并发架构消息队列为什么使用消息队列消息队列有什么优点和缺点都有什么优点和缺点如何保证消 这里有一份面试题相关总结,涉及高并发、分布式、高可用相关知识点,在此分享给大家,希望大家能拿到一份理想的 Offer! 知识点会陆续更新在 Git...
阅读 3727·2021-11-17 09:33
阅读 2752·2021-09-22 15:12
阅读 3354·2021-08-12 13:24
阅读 2451·2019-08-30 11:14
阅读 1741·2019-08-29 14:09
阅读 1332·2019-08-26 14:01
阅读 3072·2019-08-26 13:49
阅读 1785·2019-08-26 12:16