数据库优化的逻辑顺序
来源:互联网 发布:淘宝的渠道管理在哪里 编辑:程序博客网 时间:2024/06/11 00:01
原链:https://www.zhihu.com/question/19719997
来源:知乎
很多人第一反应是各种切分;我给的顺序是:
第一优化你的sql和索引;
第二加缓存,memcached,redis;
第三以上都做了后,还是慢,就做主从复制或主主复制,读写分离,可以在应用层做,效率高,也可以用三方工具,第三方工具推荐360的atlas,其它的要么效率不高,要么没人维护;
第四如果以上都做了还是慢,不要想着去做切分,mysql自带分区表,先试试这个,对你的应用是透明的,无需更改代码,但是sql语句是需要针对分区表做优化的,sql条件中要带上分区条件的列,从而使查询定位到少量的分区上,否则就会扫描全部分区,另外分区表还有一些坑,在这里就不多说了;
第五如果以上都做了,那就先做垂直拆分,其实就是根据你模块的耦合度,将一个大的系统分为多个小的系统,也就是分布式系统;
第六才是水平切分,针对数据量大的表,这一步最麻烦,最能考验技术水平,要选择一个合理的sharding key,为了有好的查询效率,表结构也要改动,做一定的冗余,应用也要改,sql中尽量带sharding key,将数据定位到限定的表上去查,而不是扫描全部的表;
mysql数据库一般都是按照这个步骤去演化的,成本也是由低到高;
阅读全文
0 0
- 数据库优化的逻辑顺序
- 性能优化--数据库优化--业务逻辑优化
- SQL优化--逻辑优化--数据库的约束规则与语义优化
- 查询处理的逻辑顺序
- SQL----逻辑查询的顺序
- 历史的逻辑与顺序
- ORACLE数据库SQL优化--->如何执行计划的执行顺序
- 逻辑数据库的用法
- SAP的逻辑数据库
- 数据库优化1(逻辑结构)
- Mongodb的逻辑优化过程
- 队列的优化(顺序)
- 数据库中的SELECT语句逻辑执行顺序分析
- 稍微复杂的sql逻辑(从数据库逆序查找有限条记录(limit))并按相反顺序输出
- 逻辑数据库的设计标准
- oracle数据库的逻辑结构
- 数据库的逻辑结构设计mysql
- 数据库的逻辑结构设计步骤
- 冒泡排序,选择排序,插入排序,快排
- 9月1日开发笔记
- java web体系发展历史和未来
- EasyMall第十一天
- HDU 1233 还是畅通工程(prim)
- 数据库优化的逻辑顺序
- EasyMall第十二天
- momentum梯度下降
- HDU
- 标准模式和怪异模式
- EasyMall第十三天
- centos 中的yum的详解与配置
- grep for windows (支持命令行)
- 内存分配形式