【数据库】必须知道的MySQL优化

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL是关系型数据库在高并发场景下,会承受巨大的压力,就需要进行优化了

SQL语言有哪几部分组成

  • 数据定义语言,简称DDL:DROP,CREATE,ALTER等语句。
  • 数据操作语言,简称DML:也就是插入(insert),修改(update),删除(delete)等操作语句。
  • 数据查询语言,简称DQL:就是常用的select语句了。
  • 数据控制语言,简称DCL:比如grant,revoke,commit,rollback等语句

在工作中,这些语言都有用到,特别是DROP,CREATE,ALTER,INSERT,UPDATE,DELETE,SELECT等语句,在实际的业务开发中,复杂的业务场景下,需要创建表,查询表。都离不开要写SQL语句来完成开发工作任务了,随着时间的增长,数据库的数据会越来越多,有可能会出现单表千万以上的数据量,这个时候你就会发现系统数据返回就变慢了,然后就去找原因,就需要进行优化之路了。

为什么要进行MySQL优化?

为什么要进行MySQL优化,我觉得应该有以下几个原因吧

  1. 系统出现了瓶颈,就需要找出来,优化掉查询慢的SQL语句,提高MySQL数据库整体性能。
  2. 表结构设计不合理,冗余字段太多了。就需要进行合理的结构设计和参数调整,来提高响应速度。
  3. 资源利用上要尽量控制,在系统前期可以用少的资源获得好的效果,后期可以根据系统具体情况进行资源上的补充。

优化方法有哪些?

优化的方法有哪些?不同的开发工程师可能使用的办法也不一样吧。但是目标是一致的,都是要提高系统的性能。

所以,我觉的可以从一下几个方面入手去操作吧

SQL层面优化

使用SHOW STATUS L语句查询一些MySQL数据的性能参数。
SHOW STATUS LIKE 'value',value就是要查询的参数值,常用参数如下表:

参数 说明
Connections 是指连接mysql服务器的次数
slow_queries 是指慢查询的次数
uptime MySQL服务器上线时间
Com_insert 插入操作次数
Com_delete 删除操作次数
Com_update 修改操作次数
Com_select 查询操作次数

可以根据相应的参数判断需要优化的sql语句,接下来就可以用执行计划EXPLAIN 来判断了

explain select * from t_order  where  user_id =1

结果如下图:
在这里插入图片描述
可以看到有几列有参数,都一一解释一下:
1.通过select_type可以判断查询语句的类型,这里simple表示简单查询,不包括连接查询和子查询。
2.type表示表的连接类型,这里的ALL表示对当前的表进行全表扫描。
3.rows列值是1,表示只有一条记录
4.Extra该列表示sql在处理查询的是的详细信息,这里表示使用了where过滤

这里的查询没有用到索引,所以需要加索引优化,那还需要进行以下优化:

  • SQL查询基于索引来进行数据扫描
  • 使用索引扫描,联合索引要遵循最左前缀原则,也就是列从左往右,命中越多越好
  • 查询有效的列信息返回就好了,避免使用‘*’查询返回全部列参数
  • where语句中like %号尽量放在右边
  • 在查询时小结果集驱动大结果集原则

MySQL配置方面

MySQL默认的配置文件是my.cnf(my.ini)
在这里插入图片描述

在这里插入图片描述
如上图有很多默认的配置参数,可以根据业务需要进行相应的更改。可以看到最大连接数是151个。binlog日志默认是不开启的。需要注意的是,配置作用域分为全局和会话级别,是否支持热加载。这些参数的更改都是要根据实际情况进行的。

架构设计方面

MySQL是关系型数据库在高并发场景下,会承受巨大的压力,就需要从架构设计方面进行优化了。主要包括:
1.搭建MySQL主从集群,单个MySQL服务容易出现单点故障,一旦服务宕机,应用全部无法响应,主从集群或者主主集群可以保证服务的可用性。
2.读写分离设计,在读多写少的场景中,通过读写分离方案可以避免读写导致的性能影响。
3.针对热点数据,可以引入非关系型数据库,如Redis,MongoDB等,可以很好的缓解MySQL访问压力,也能提高数据检索性能。
4.引入分库分表机制,通过分库可以降低单个服务节点的IO压力,通过分表的方式可以降低单表数据量,从而提升sql查询效率。

硬件和操作系统方面.

硬件和操作系统方面的话大厂一般都是有专门的DBA或者运维工程师去负责优化的,但是小厂,创业公司,这些都是有开发工程是去操作的,所以,多掌握一些技能是必不可少的。
从硬件层面上,影响MySQL性能的因素有:CPU,可用内存大小。磁盘读写速度,网络带宽等等
从操作系统上,操作系统网络的配置,文件句柄数都会影响到MySQL性能。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
19天前
|
SQL 关系型数据库 MySQL
MySQL慢查询优化、索引优化、以及表等优化详解
本文详细介绍了MySQL优化方案,包括索引优化、SQL慢查询优化和数据库表优化,帮助提升数据库性能。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
MySQL慢查询优化、索引优化、以及表等优化详解
|
19天前
|
存储 NoSQL 分布式数据库
微服务架构下的数据库设计与优化策略####
本文深入探讨了在微服务架构下,如何进行高效的数据库设计与优化,以确保系统的可扩展性、低延迟与高并发处理能力。不同于传统单一数据库模式,微服务架构要求更细粒度的服务划分,这对数据库设计提出了新的挑战。本文将从数据库分片、复制、事务管理及性能调优等方面阐述最佳实践,旨在为开发者提供一套系统性的解决方案框架。 ####
|
20天前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
36 4
|
19天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
34 1
|
21天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
35 4
|
22天前
|
SQL druid 数据库
如何进行数据库连接池的参数优化?
数据库连接池参数优化包括:1) 确定合适的初始连接数,考虑数据库规模和应用需求;2) 调整最大连接数,依据并发量和资源状况;3) 设置最小空闲连接数,平衡资源利用和响应速度;4) 优化连接超时时间,确保系统响应和资源利用合理;5) 配置连接有效性检测,定期检查连接状态;6) 调整空闲连接回收时间,适应访问模式并配合数据库超时设置。
|
24天前
|
缓存 监控 关系型数据库
如何优化MySQL查询速度?
如何优化MySQL查询速度?【10月更文挑战第31天】
56 3
|
26天前
|
SQL 缓存 监控
数据库优化
【10月更文挑战第29天】数据库优化
31 1
|
26天前
|
缓存 关系型数据库 MySQL
如何优化 MySQL 数据库的性能?
【10月更文挑战第28天】
52 1
|
15天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
125 0