问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

请教大数据分表分数据库的问题

发布网友 发布时间:2022-04-23 22:05

我来回答

1个回答

热心网友 时间:2022-05-01 13:24

1 基本思想之什么是分库分表?
从字面上简单理解,就是把原本存储于一个库的数据分块存储到多个库上,把原本存储于一个表的数据分块存储到多个表上。
2 基本思想之为什么要分库分表?

数据库中的数据量不一定是可控的,在未进行分库分表的情况下,随着时间和业务的发展,库中的表会越来越多,表中的数据量也会越来越大,相应地,数据操作,增删改查的开销也会越来越大;另外,由于无法进行分布式式部署,而一台服务器的资源(CPU、磁盘、内存、IO等)是有限的,最终数据库所能承载的数据量、数据处理能力都将遭遇瓶颈。
3 分库分表的实施策略。

分库分表有垂直切分和水平切分两种。
3.1 何谓垂直切分,即将表按照功能模块、关系密切程度划分出来,部署到不同的库上。例如,我们会建立定义数据库workDB、商品数据库payDB、用户数据库userDB、日志数据库logDB等,分别用于存储项目数据定义表、商品定义表、用户数据表、日志数据表等。
3.2 何谓水平切分,当一个表中的数据量过大时,我们可以把该表的数据按照某种规则,例如userID散列,进行划分,然后存储到多个结构相同的表,和不同的库上。例如,我们的userDB中的用户数据表中,每一个表的数据量都很大,就可以把userDB切分为结构相同的多个userDB:part0DB、part1DB等,再将userDB上的用户数据表userTable,切分为很多userTable:userTable0、userTable1等,然后将这些表按照一定的规则存储到多个userDB上。
3.3 应该使用哪一种方式来实施数据库分库分表,这要看数据库中数据量的瓶颈所在,并综合项目的业务类型进行考虑。
如果数据库是因为表太多而造成海量数据,并且项目的各项业务逻辑划分清晰、低耦合,那么规则简单明了、容易实施的垂直切分必是首选。
而如果数据库中的表并不多,但单表的数据量很大、或数据热度很高,这种情况之下就应该选择水平切分,水平切分比垂直切分要复杂一些,它将原本逻辑上属于一体的数据进行了物理分割,除了在分割时要对分割的粒度做好评估,考虑数据平均和负载平均,后期也将对项目人员及应用程序产生额外的数据管理负担。
在现实项目中,往往是这两种情况兼而有之,这就需要做出权衡,甚至既需要垂直切分,又需要水平切分。我们的游戏项目便综合使用了垂直与水平切分,我们首先对数据库进行垂直切分,然后,再针对一部分表,通常是用户数据表,进行水平切分。
4 分库分表存在的问题。

4.1 事务问题。
在执行分库分表之后,由于数据存储到了不同的库上,数据库事务管理出现了困难。如果依赖数据库本身的分布式事务管理功能去执行事务,将付出高昂的性能代价;如果由应用程序去协助控制,形成程序逻辑上的事务,又会造成编程方面的负担。
4.2 跨库跨表的join问题。
在执行了分库分表之后,难以避免会将原本逻辑关联性很强的数据划分到不同的表、不同的库上,这时,表的关联操作将受到*,我们无法join位于不同分库的表,也无法join分表粒度不同的表,结果原本一次查询能够完成的业务,可能需要多次查询才能完成。
4.3 额外的数据管理负担和数据运算压力。
额外的数据管理负担,最显而易见的就是数据的定位问题和数据的增删改查的重复执行问题,这些都可以通过应用程序解决,但必然引起额外的逻辑运算,例如,对于一个记录用户成绩的用户数据表userTable,业务要求查出成绩最好的100位,在进行分表之前,只需一个order by语句就可以搞定,但是在进行分表之后,将需要n个order by语句,分别查出每一个分表的前100名用户数据,然后再对这些数据进行合并计算,才能得出结果。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
富士打印机怎么设置ip地址? 超市购物模拟器收银员 微信好友辅助安全登录验证该怎么做 培育钻石和天然钻石本质上有区别吗 培育钻石有哪些优缺点? 买的基金怎么取出来吗? 如何把鸡毛去掉 他先对女孩有好感,女孩对他表白了,但是他一直这样对待女孩?_百度... 主保护包括哪些 经常带孩子散步有哪些好处和坏处? 大数据表格如何做 表格大数据处理 怎样快速提高数学和英语成绩 初二的学生数学和英语很差,那怎样才能快速提高成绩? 如何提高英语和数学 怎么将英语和数学快速提高 怎样快速提高数学、英语的成绩? 如何提高高中数学和英语成绩?? 怎样才能快速提高语文,数学,英语成绩 为了阻止同学们不再玩手机我们班级制定了使用手机公约是否是病句? 如何让自己的英语成绩和数学成绩提高? 教育部要求中小学生禁止带手机进课堂,上海某中学的什么操作引发网友关注? 如何提高数学和英语 中小学生原则上不准带手机,你有带过手机去学校吗? 怎么快速提高初中数学和英语成绩 中小学生严禁带手机入校,这规定对于教育重要性体现在哪? 如何快速提高数学和英语成绩? 校园手机管理办法 如何提高数学能力和英语能力? 学生在家使用手机规则 如何在一个大数据表(7.5亿数据)中进行分组统计 请问什么算是大数据表,有什么数据衡量指标(比如:百万级)? 如何往超大表中插入大数据量的数据 MySQL大数据量查询,一张表大约有90多万数据,查询结果如下,请高手指点。 sqlserver 大数据量的表怎么修改结构 数据库大数据 请教一个问题,将一个大数据量的表,根据某列值拆分为多个表,怎样效率才... mysql 大数据表 模糊查询 如何提示查询效率 大数据系统数据表导入时出现错误是什么原因 怎么在word里做大数据表格,急 Oracle数据库大数据量表如何优化? office excel在处理大数据表格时,筛选后清除筛选就卡死 梦到自己被所有亲人、朋友抛弃了,这是预示什么? 梦到亲友的背叛,工作不如意 一夜之间梦见父母,爱人朋友都背叛了我 那么多年总梦见自己被最亲的人抛弃怎么回事? 梦见自己被所有人抛弃预示什么? 会解的请进 生日这一天我梦见亲人不理我,爱人背叛我,有什么寓意吗? 如何去编辑caj文件,需要哪种caj转换器? 什么工具可以把nh,kdh,caj文件转换成word