网站首页 > 技术文章 正文
1995年首发以来,MySQL不仅自己“星途坦荡”,成为了现今最流行的关系型数据库,同时还衍生出很多备受瞩目的分支,如在数据库领域撕开缺口并成功占据一席之地的 MariaDB 及 Percona。
今天,我们就来谈谈如何查看MySQL性能状态并优化。
如何查看查看MySQL性能?
现在大家对MySQL的监控通常有两种做法,一是连接到mysql数据库内部,使用show status,show variables,flush status 来查看mysql的各种性能指标;二是直接使用mysqladmin查看其性能指标。
方法一的使用:
- 查看MySQL服务器配置信息 :mysql> show variables;
- 查看MySQL服务器运行的各种状态值 :mysql> show global status;
- 慢查询:mysql> show variables like '%s%';
- mysql> show global status like '%slow%';
- 连接数:mysql> show variables like 'max_connections';
- key_buffer_size 是对MyISAM表性能影响最大的一个参数mysql> show variables like 'key_buffer_size';
- 临时表:mysql> show global status like 'created_tmp%';
- 查看open table :mysql> show global status like 'open%tables%';
- 进程使用情况:mysql> show global status like 'Thread%';
- 查询缓存(query cache) :mysql> show global status like 'qcache%';
- 文件打开数(open_files) :mysql> show global status like 'open_files';
- 表锁情况 :mysql> show global status like 'table_locks%';
- 表扫描情况 :mysql> show global status like 'handler_read%';
方法二的使用:
UserParameter=mysql.uptime,mysqladmin -uroot status|cut -f2 -d":"|cut -f1 -d"T"
mysqladmin两个参数,status,extended-status
shell > mysqladmin -uroot -ppassword variables status
其中包含的信息如下:
- Uptime: 4557887 #mysql运行的秒数
- Threads: 1 #连接数
- Questions: 1684130 #The number of questions (queries) from clients since the server was started.
- Slow queries: 0 #The number of queries that have taken more than long_query_time seconds
- Opens: 221872 #The number of tables the server has opened.
- Flush tables: 1 #The number of flush-*, refresh, and reload commands the server has executed.
- Open tables: 64 #The number of tables that currently are open.
- Queries per second avg: 0.369 #从上次运行开始计算,每秒钟平均查询次数
关键的MySQL统计指标
当数据库出现查询缓慢或者无法响应查询的情况时,应该怎么办呢?我们可以通过监控与性能及资源利用率相关的指标,来查找出现这个问题的原因,避免依赖数据库性能的相关组件也产生影响。
MySQL用户可以接触到的性能指标有几百个,本文介绍四个比较关键常用的指标,查询吞吐量、查询执行性能、连接情况和缓冲池使用情况。
查询吞吐量: MySQL内部有一个名为 Questions 的计数器,客户端每发送一个查询语句,其值就会加一,可利用其来衡量查询吞吐量,SHOW GLOBAL STATUS LIKE "Questions";
查询执行性能: 监控查询延迟的方式有很多,例如通过 MySQL 内置的指标,或者通过查询性能模式。 MySQL 5.6.6 版本开始默认启用,MySQL 的 performance_schema 数据库中的表格存储着服务器事件与查询执行的低水平统计数据。
连接情况: MySQL的文档指出,健壮的服务器应该能够处理成百上千的连接数,可通过SHOW VARIABLES LIKE 'max_connections';的形式来查看。
缓冲池使用情况: MySQL 默认的存储引擎 InnoDB 使用了一片称为缓冲池的内存区域,用于缓存数据表与索引的数据。如果数据库性能开始下滑,而磁盘 I/O 在不断攀升,扩大缓冲池往往能带来性能回升。
猜你喜欢
- 2024-10-20 如何在 CentOS7 下改造MySQL开机启动服务?
- 2024-10-20 MySQL日志篇(mysql的日志文件在哪里)
- 2024-10-20 如何快速定位MySQL 的错误日志(Error Log)?
- 2024-10-20 小白自学MySQL笔记(一):Mac环境的安装和启动
- 2024-10-20 MySQL执行计划主要通过EXPLAIN命令来查看
- 2024-10-20 MySQL service启动脚本浅析(r12笔记第59天)
- 2024-10-20 借助shell脚本,解决MySQL服务自动停止的问题
- 2024-10-20 MySQL 还在跑任务时,突然断电,数据库崩了又好像没崩……
- 2024-10-20 超详细的mysql数据库查询缓存总结,值得收藏
- 2024-10-20 一文看懂mysql数据库本质及存储引擎innodb+myisam
- 1517℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 594℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 521℃MySQL service启动脚本浅析(r12笔记第59天)
- 489℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 489℃启用MySQL查询缓存(mysql8.0查询缓存)
- 477℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 456℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 454℃MySQL server PID file could not be found!失败
- 最近发表
-
- PS所有滤镜的说明(六)(ps滤镜详解)
- 5款小白也能用的在线图片编辑器!电商效率飙升就靠它!
- Java变量(java变量有什么作用)
- Java面试常见问题:Java注解(java中的面试题)
- Java编程入门第一课:HelloWorld(java编程从入门到实践)
- Java基础教程:Java继承概述(java里继承的概述)
- java基础之——访问修饰符(private/default/protected/public)
- 如何规划一个合理的JAVA项目工程结构
- 将机器指令翻译成 JavaScript -- 终极目标
- Web 服务器基准测试:Go vs. Node.js vs. Nim vs. Bun
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)