[转帖]MySQL使用为什么要分库分表_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1672 | 回复: 0   主题: [转帖]MySQL使用为什么要分库分表        下一篇 
huanyuer
注册用户
等级:新兵
经验:66
发帖:6
精华:0
注册:2013-11-14
状态:离线
发送短消息息给huanyuer 加好友    发送短消息息给huanyuer 发消息
发表于: IP:您无权察看 2015-3-23 15:24:13 | [全部帖] [楼主帖] 楼主

可以用说用到MySQL的地方,只要数据量一大, 马上就会遇到一个问题,要分库分表.

    这里引用一个问题为什么要分库分表呢?MySQL处理不了大的表吗?

    其实是可以处理的大表的.我所经历的项目中单表物理上文件大小在80G多,单表记录数在5亿以上,而且这个表属于一个非常核用的表:朋友关系表.

    但这种方式可以说不是一个最佳方式. 因为面临文件系统如Ext3文件系统对大于大文件处理上也有许多问题.

    这个层面可以用xfs文件系统进行替换.但MySQL单表太大后有一个问题是不好解决: 表结构调整相关的操作基本不在可能.所以大项在使用中都会面监着分库分表的应用.

    从Innodb本身来讲数据文件的Btree上只有两个锁, 叶子节点锁和子节点锁,可以想而知道,当发生页拆分或是添加新叶时都会造成表里不能写入数据.

    所以分库分表还就是一个比较好的选择了.

    那么分库分表多少合适呢?

    经测试在单表1000万条记录一下,写入读取性能是比较好的. 这样在留点buffer,那么单表全是数据字型的保持在800万条记录以下, 有字符型的单表保持在500万以下.

    如果按 100库100表来规划,如用户业务:

    500万*100*100 = 50000000万 = 5000亿记录.

    心里有一个数了,按业务做规划还是比较容易的.

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论