iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么实现mysql数据库性能诊断
  • 293
分享到

怎么实现mysql数据库性能诊断

2024-04-02 19:04:59 293人浏览 八月长安
摘要

本篇文章给大家分享的是有关怎么实现Mysql数据库性能诊断,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 一:检查mysql所在的服务器的性

本篇文章给大家分享的是有关怎么实现Mysql数据库性能诊断,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

一:检查mysql所在的服务器的性能,linux环境使用top和iOStat

[root@S243 etc]# top 

top - 11:40:41 up 23 days, 17:06,  2 users,  load average: 0.11, 0.31, 0.32

Tasks: 617 total,   1 running, 616 sleeping,   0 stopped,   0 zombie

Cpu0  :  0.0%us,  0.0%sy,  0.0%ni,100.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu1  :  0.0%us,  0.0%sy,  0.0%ni,100.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu2  :  1.0%us,  0.7%sy,  0.0%ni, 98.0%id,  0.0%wa,  0.0%hi,  0.3%si,  0.0%st

Cpu3  :  0.0%us,  0.0%sy,  0.0%ni,100.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st

关于top的结果主要关注下 load average: 0.11, 0.31, 0.32 

系统负载(任务队列的平均长度)三个值分别为1分钟、5分钟、15分钟前到现在的平均值,小于1正常【这三个一般会小于1,如果持续高于5,请仔细查看那个程序影响系统的运行】”

[root@S243 etc]# iostat -d -x

Linux 2.6.32-131.0.15.el6.x86_64 (S243)         2016年10月20日  _x86_64_        (24 CPU)

Device:         rrqm/s   wrqm/s     r/s     w/s   rsec/s   wsec/s avgrq-sz avgqu-sz   await  svctm  %util

sda               1.02    14.59    6.77   27.88   297.25   519.70    23.58     0.07    1.92   0.34   1.17

输出信息的含义

rrqm/s:每秒这个设备相关的读取请求有多少被Merge了(当系统调用需要读取数据的时候,VFS将请求发到各个FS,如果FS发现不同的读取请求读取的是相同Block的数据,FS会将这个请求合并Merge);wrqm/s:每秒这个设备相关的写入请求有多少被Merge了。
rsec/s:每秒读取的扇区数;
wsec/:每秒写入的扇区数。
rKB/s:The number of read requests that were issued to the device per second;
wKB/s:The number of write requests that were issued to the device per second;
avgrq-sz 平均请求扇区的大小
avgqu-sz 是平均请求队列的长度。毫无疑问,队列长度越短越好。   
await:  每一个IO请求的处理的平均时间(单位是微秒毫秒)。这里可以理解为IO的响应时间,一般地系统IO响应时间应该低于5ms,如果大于10ms就比较大了。
         这个时间包括了队列时间和服务时间,也就是说,一般情况下,await大于svctm,它们的差值越小,则说明队列时间越短,反之差值越大,队列时间越长,说明系统出了问题。
svctm    表示平均每次设备I/O操作的服务时间(以毫秒为单位)。如果svctm的值与await很接近,表示几乎没有I/O等待,磁盘性能很好,如果await的值远高于svctm的值,则表示I/O队列等待太长,         系统上运行的应用程序将变慢,上例中1.92高于0.34说明存在一定的等待。

%util: 在统计时间内所有处理IO时间,除以总共统计时间。例如,如果统计间隔1秒,该设备有0.8秒在处理IO,而0.2秒闲置,那么该设备的%util = 0.8/1 = 80%,所以该参数暗示了设备的繁忙程度

。一般地,如果该参数是100%表示设备已经接近满负荷运行了(当然如果是多磁盘,即使%util是100%,因为磁盘的并发能力,所以磁盘使用未必就到了瓶颈)。

二:查看有没有阻塞:

mysql> show processlist;        关注state  有没有lock的状态。有的话kill解决。

+---------+-------------+---------------------+---------------+-------------+---------+-----------------------------------------------------------------------------+------------------+

| Id      | User        | Host                | db            | Command     | Time    | State                                                                       | Info             |

|       3 | mailer      | 192.168.0.225:45135 | mailer        | Sleep       |      26 |                                                                             | NULL             |

|       8 | info_reader | 192.168.0.225:45194 | info          | Sleep       |      56 |                                                                             | NULL             |

|      23 | info_reader | 192.168.0.225:45451 | info          | Sleep       |      13 |                                                                             | NULL             |

|      78 | info_reader | 192.168.0.225:54249 | info          | Sleep       |      68 |                                                                             | NULL             |

|     180 | WEB_editer  | 192.168.0.225:46200 | info          | Sleep       |      26 |                                                                             | NULL             |

|     226 | web_editer  | 192.168.0.225:46584 | info          | Sleep       |      13 |                                                                             | NULL             |

|    2035 | info_reader | 192.168.0.225:53314 | info          | Sleep       |      36 |                                                                             | NULL             |

|    2052 | info_reader | 192.168.0.225:53447 | info          | Sleep       |      36 |                                                                             | NULL             |

|    2384 | ruby_syncer | 192.168.0.218:41868 | info          | Sleep       |       0 |                                                                             | NULL             |

|    2387 | ruby_syncer | 192.168.0.218:41870 | info          | Sleep       |       0 |                                                                             | NULL             |

三:查看mysql慢sql
1)首先检查是否开启了慢sql.  如下红色显示为开启了mysql慢查询。

mysql> show variables like '%query%';    

+------------------------------+------------------------------+

| Variable_name                | Value                        |

+------------------------------+------------------------------+

| binlog_rows_query_log_events | OFF                          |

| ft_query_expansion_limit     | 20                           |

| have_query_cache             | YES                          |

| long_query_time              | 4.000000                     |

| query_alloc_block_size       | 8192                         |

| query_cache_limit            | 2097152                      |

| query_cache_min_res_unit     | 4096                         |

| query_cache_size             | 104857600                    |

| query_cache_type             | OFF                          |

| query_cache_wlock_invalidate | OFF                          |

| query_prealloc_size          | 8192                         |

| slow_query_log               | ON                           |

| slow_query_log_file          | /mysql/datadir/S243-slow.log |

+------------------------------+------------------------------+

13 rows in set (0.00 sec)

拓展:mysql慢查询相关的主要的三个参数为

(1)slow_query_log    #指定是否开启慢查询日志(0/1或者off/on)

(2)slow_query_log_file  # 指定慢日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log

(3)long_query_time   #设定慢查询的阀值,超出次设定值的SQL即被记录到慢查询日志,缺省值为10s 

(4)log_queries_not_using_indexes: 不使用索引的慢查询日志是否记录到索引  (on/off)

(5)min_examined_row_limit:查询检查返回少于该参数指定行的SQL不被记录到慢查询日志 。

2)mysql>  show status like '%Slow_queries%';     #显示了当前慢查询的数量,也就是正在执行的。如果显示0,说明当前没有正在执行的时间超过long_query_time 值的sql.你需要去慢查询日志中查看。
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Slow_queries  | 2    |
+---------------+-------+
1 row in set (0.00 sec)
3)直接查看慢查询日志的内用就可以,如下显示了两条慢sql.

[root@S243 datadir]# tail -n 10  S243-slow.log

# Time: 161020 15:19:39

# User@Host: mailer[mailer] @  [192.168.0.226]  Id: 1372832

# Query_time: 12.617656  Lock_time: 0.000072 Rows_sent: 1  Rows_examined: 19796776

SET timestamp=1476947979;

select count(*) as col_0_0_ from mailer.kehuguanzhus_logs_meta kehuguanzh0_ where kehuguanzh0_.state<>100 and kehuguanzh0_.guanzhu_id='4f41910e-0ec6-4042-8c4a-b2f0f9c8' and kehuguanzh0_.last_modify>='2016-09-20' and kehuguanzh0_.last_modify<'2016-10-21' order by kehuguanzh0_.id desc limit 2;

# Time: 161020 15:21:19

# User@Host: mailer[mailer] @  [192.168.0.226]  Id: 1372832

# Query_time: 12.489680  Lock_time: 0.000155 Rows_sent: 1  Rows_examined: 19796842

SET timestamp=1476948079;

select count(*) as col_0_0_ from mailer.kehuguanzhus_logs_meta kehuguanzh0_ where kehuguanzh0_.state<>100 and kehuguanzh0_.guanzhu_id='53b344cf-6239-4882-afbb-772b90a4' and kehuguanzh0_.last_modify>='2016-09-20' and kehuguanzh0_.last_modify<'2016-10-21' order by kehuguanzh0_.id desc limit 2;

我们也可以利用mysqldumpslow来格式化慢查询日志的格式,便于我们查阅。

#获取mysqldumpslow的帮助信息 

[root@S243 datadir]# mysqldumpslow --help 

Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]

Parse and summarize the MySQL slow query log. Options are

--verbose    verbose

  --debug      debug

  --help       write this text to standard output

  -v           verbose

  -d           debug

  -s ORDER     what to sort by (al, at, ar, c, l, r, t), 'at' is default

                al: average lock time

                ar: average rows sent

                at: average query time

                 c: count

                 l: lock time

                 r: rows sent

                 t: query time 

  -r           reverse the sort order (largest last instead of first)

  -t NUM       just show the top n queries

  -a           don't abstract all numbers to N and strings to 'S'

  -n NUM       abstract numbers with at least n digits within names

  -g PATTERN   grep: only consider stmts that include this string

  -h HOSTNAME  hostname of db server for *-slow.log filename (can be wildcard),

               default is '*', i.e. match all

  -i NAME      name of server instance (if using mysql.server startup script)

  -l           don't subtract lock time from total time

例如:

以下是按照最大耗用时间排最后,只显示2条的方式格式化日志文件  

[root@S243 datadir]# mysqldumpslow -r -t 2  /mysql/datadir/S243-slow.log

Reading mysql slow query log from /var/lib/mysql/suse11b-slow.log  

Count: 1  Time=1.57s (1s)  Lock=0.00s (0s)  Rows=83.0 (83), root[root]@localhost  

select table_schema,table_name,count(*) from tb_slow  

group by table_schema,table_name order by N,N  

Count: 4  Time=16.87s (67s)  Lock=0.00s (0s)  Rows=0.0 (0), root[root]@localhost  

 insert into tb_slow select * from tb_slow  

[root@S243 datadir]# mysqldumpslow -s   /mysql/datadir/S243-slow.log   ###最耗时间的依次排序

由于这个慢查询日志是无限增大的,他是好长时间的一个累计,而数据库性能慢的时候,往往你只需要查询当时的那段时间的慢sql语句,然后针对性的去优化,所以没必要使用mysqldumpslow 去做什么排序之类的,因为最耗时的sql可能仅仅是在很久以前执行过一次,直接用tail -n 去看某个时间段的就可以了。

确定了影响性能的慢sql之后,然后针对性的去优化,加索引,改写sql,。。。。。

体会:mysql性能诊断过程和oracle类似,也是首先查看mysql的服务器的性能,然后看mysql数据的性能(有没有之类的)最后确定性能慢的sql.然后针对性的去优化。

以上就是怎么实现mysql数据库性能诊断,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么实现mysql数据库性能诊断

本文链接: https://www.lsjlt.com/news/66427.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么实现mysql数据库性能诊断
    本篇文章给大家分享的是有关怎么实现mysql数据库性能诊断,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 一:检查mysql所在的服务器的性...
    99+
    2024-04-02
  • 如何使用MySQL系统数据库做性能负载诊断
    这篇文章主要介绍了如何使用MySQL系统数据库做性能负载诊断,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。某大师曾说过,像了解自己的老婆 一...
    99+
    2024-04-02
  • 如何在MySQL中进行数据库性能监控和诊断
    在MySQL中进行数据库性能监控和诊断可以通过以下几种方式: 使用MySQL自带的性能监控工具:MySQL自带了一些性能监控工具...
    99+
    2024-03-06
    MySQL
  • 怎么诊断云服务器的性能
    诊断云服务器性能的方法:1、用系统监视和日志分析工具确定CPU和存储的利用率,包括检查支持工作负载的基础结构;2、检查应用程序本身的性能,以保证应用程序充分利用和发挥云服务器弹性环境的优势;3、检查其他组件,如检查安全系统,监控服务等;4、...
    99+
    2024-04-02
  • 如何实现Mysql数据库性能优化
    这篇文章主要为大家展示了“如何实现Mysql数据库性能优化”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现Mysql数据库性能优化”这篇文章吧。对表进行水...
    99+
    2024-04-02
  • 怎么优化MySQL数据库性能
    这篇文章主要为大家展示了“怎么优化MySQL数据库性能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么优化MySQL数据库性能”这篇文章吧。  1、选取最适用...
    99+
    2024-04-02
  • Linux中Oracle的性能怎么调优与诊断
    在Linux上调优和诊断Oracle性能通常需要遵循以下步骤: 监控系统资源利用率:使用工具如top、vmstat、sar等监控...
    99+
    2024-05-06
    Linux Oracle
  • PL/SQL中的性能怎么诊断与优化
    在PL/SQL中,性能问题通常可以通过以下方法进行诊断与优化: 使用Explain Plan:使用Oracle数据库的Expla...
    99+
    2024-05-07
    PL/SQL
  • mysql数据库怎么实现
    mysql数据库实现步骤:安装mysql服务器;创建数据库;创建用户并授予权限;连接到数据库;创建表;插入数据;查询数据;修改数据;删除数据;备份数据库。 MySQL数据库实现 如何实...
    99+
    2024-04-22
    mysql 数据丢失
  • vb怎么实现数据库功能
    在VB中实现数据库功能,可以通过以下步骤:1. 创建数据库连接:使用SqlConnection类来创建与数据库的连接。提供数据库连接...
    99+
    2023-10-18
    vb 数据库
  • MySQL数据库的性能优化
    目录一、mysql数据库的优化目标、基本原则:1、优化目标:2.基本原则:二、定位分析SQL语句的性能瓶颈:1、通过show status 命令了解各种SQL的执行效率:2、定位执行效率较低的SQL语句3、通过expla...
    99+
    2023-04-11
    MySQL性能优化 数据库性能优化 sql性能优化
  • vb数据库功能怎么实现
    在VB中实现数据库功能,可以使用以下步骤:1. 创建数据库连接:使用ADO(ActiveX Data Objects)来建立与数据库...
    99+
    2023-08-30
    数据库
  • MySQL数据库的性能分析
    本篇内容主要讲解“MySQL数据库的性能分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库的性能分析”吧!  1. MySQL性能优化简介  在...
    99+
    2024-04-02
  • mysql数据库备份怎么实现
    这篇文章主要介绍mysql数据库备份怎么实现,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!本文实例讲述了mysql 数据库备份的多种实现方式。分享给大家供大家参考,具体如下:一、使用...
    99+
    2024-04-02
  • MySQL数据库中怎么实现序列自增功能
    MySQL数据库中怎么实现序列自增功能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、创建sequence表CREATE TABL...
    99+
    2024-04-02
  • Mysql数据库中怎么实现数据同步
    Mysql数据库中怎么实现数据同步,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 安装配置两台服务器,分别安装好Mysql,都安装在 /u...
    99+
    2024-04-02
  • 怎么提高数据库性能
    这篇文章将为大家详细讲解有关怎么提高数据库性能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。以下是提升数据库性能的6种实用的方式,无需增加更强大的服务器,也无需重写代码或...
    99+
    2024-04-02
  • VSCode怎么实现一个代码诊断插件
    这篇文章主要讲解了“VSCode怎么实现一个代码诊断插件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VSCode怎么实现一个代码诊断插件”吧!基本原理Visual Studio Code ...
    99+
    2023-06-29
  • 高性能mysql怎么实现
    要实现高性能的MySQL,可以从以下几个方面进行优化:1. 硬件优化:选择高性能的硬件设备,包括高速的磁盘、大容量的内存和快速的网络...
    99+
    2023-08-24
    mysql
  • PHP如何实现MySQL数据库可用性
    本文小编为大家详细介绍“PHP如何实现MySQL数据库可用性”,内容详细,步骤清晰,细节处理妥当,希望这篇“PHP如何实现MySQL数据库可用性”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。监控数据库的运行状况通...
    99+
    2023-07-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作