主要考虑数据库优化与SQL语句优化
1,数据库优化,包括存储引擎的优化,缓存的优化和内存的优化等
2,SQL优化。首先先判断什么样的SQL需要优化。可以在MySQL中开启慢查询,设置成例如SQL执行时长超过5秒就可以定为慢SQL,并记录到日志中。然后拿到慢SQL的执行记录和计划,通过explain关键字做分析。分析思路有例如SQL存在索引,判断是否执行了索引或者索引失效原因,若索引未失效则要考虑索引创建是否合理,以及是否遵循最左匹配原则等
sql优化是一个比较复杂的话题。可以提供一个思路:
1。怎么识别慢sql——开启慢查询日志,设置慢查询阈值,使用通知平台(短信,企业微信,钉钉)等进行通知。
2.看下出问题的sql数据量多少,关联关系是怎么样的。有个大概的了解。
3.查看explain输出结果,关注type,key,key-len,rows,extro等(具体见官网)
4.索引优化:哪些列加到索引中,索引顺序的安排,索引失效的场景,索引覆盖和前缀索引,(索引列不是越多越好)
5.sql本身的优化,比如:仅仅select自身需要的列而不是select*,还有一些特殊场景的优化。
6.表结构的优化,冗余,汇总表,垂直拆分,水平拆分,分库分表等
7.其他手段,比如redis缓存,es等
额外
1、如果使用HDD的话,可以看下是否开启了mrr,mrr可以把随机读转化为顺序读,用了空间换时间思想提高了索引查询的性能。这个点估计百度MySQL优化都少提
2、分库分表
mysql优化前到后步骤
sql优化、索引优化、表结构优化、事务的处理、锁表的处理、系统配置的优化
相关链接