首页  >  文章  >  数据库  >  常用mysql数据库工具简介

常用mysql数据库工具简介

WBOY
WBOY原创
2016-06-07 16:18:291270浏览

status系列 Mysql提供了一系列命令来获取数据库的运行状态,其中最常用的主要有show status;show innodb status;show processlist; show mutex status。通过这些命令我们可以了解到数据库和存储引擎io,内存,锁等详细信息。 参考资料: 监控工具――Mysqlre

   status系列

  Mysql提供了一系列命令来获取数据库的运行状态,其中最常用的主要有show status;show innodb status;show processlist; show mutex status。通过这些命令我们可以了解到数据库和存储引擎io,内存,锁等详细信息。

  参考资料:

  监控工具――Mysqlreport

  上面列出的各种status命令,能够方便地实时查看。 若需要长期监控,则需要工具对这些信息进行整理汇总。目前常见的mysql监控有mysqlreport、mysqlsla、innotop,还有公司内部开发的Mysql-mon。其中mysqlreport和mysql-mon属于状态统计类型。

  数据来源:

  [mysql]show global status

  [mysql]Show Global Variables

  [mysql]Show Full Processlist

  [系统] vmstat/iostat/mpstat

  由于上述参数复杂,因此监控工具抽取重要的信息,以方便查看的方式显示,并记录都在日志中。

  Mysqlreport是一款支持周期生成报表的工具。

  从mysqlreport报表中能够得到的信息有分为一下几类:

  1、总体数据:包括读写总请求、接收/发送总数据量、慢查询次数

  2、DMS(数据操作描述):各种数据操作分布(select、update等)、查询和排序次数分布

  3、Cache:包括cache命中率、cache操作次数及比例(查询命中率、插入次数、修改次数的比例)

  4、表: 包括表锁次数、打开表文件个数、临时表类型分布、最大连接数等

  5、InnoDB相关:包括innodb 数据内容读写次数、数据页面创建/读写次数、数据行操作次数(增删改查语句分布)

  参考资料:

  

  

  监控工具――Mysqlsla

  mysqlreport可以协助我们了解MySQL的健康状况以及MySQL大部份时间在处理什么类型的Query,但我们在调查慢查询时,想知道MySQL 实际上到底是把 CPU 运算时间花在哪些 Query 上?这个问题必须从MySQL的Log才可知。

  Mysqlsla的数据来源为mysql提供的三类log:Binary Log、General Log和Slow Log。

  对于慢sql统计信息, 包括 平均执行时间, 等待锁时间, 结果行的总数, 扫描的行总数。提供结果格式如下:

  项目 说明

  Count sql的执行次数及占总的slow log数量的百分比

  Time 执行时间, 包括总时间, 平均时间, 最小, 最大时间, 时间占到总慢sql时间的百分比

  95% of Time 去除最快和最慢的sql, 覆盖率占95%的sql的执行时间.

  Lock Time 等待锁的时间

  95% of Lock 95%的慢sql等待锁时间

  Rows sent 结果行统计数量, 包括平均, 最小, 最大数量

  Rows examined 扫描的行数量

  Database 属于哪个数据库

  Users 哪个用户,IP, 占到所有用户执行的sql百分比

  Query abstract 抽象后的sql语句

  Query sample sql语句

  参考资料:

  监控工具――innotop

  innotop是一个针对innodb引擎的监控工具。

  与上诉的几个工具不同,,这是一个类似于top的工具,能够实时显示innodb的各种参数变化。

  更强悍的是,能够在执行过程中能够查看各个线程的执行状态、查看死锁信息;

  能够通过输入命令行参数,选取不同的模式,查看线程内部信息

  参考资料:

  

  监控工具――Mysql-mon

  Mysql-mon是百科开发的,内部应用的监控工具。采用C语言开发,对数据库负载几乎为0。可用于 :

  数据库系统状态监控分源连接数监控数据量、索引量监控字段范围监控数据库同步监控

  参考资料:

  表压缩工具――myisampack

  Myisampack是一个表压缩工具,可以使用很高的压缩率来对MyIsam存储引擎的表进行压缩,使得压缩后的表占用比压缩前小得多的磁盘空间。但是压缩后的表也将称为一个只读表,不能进行DML操作。

  参考资料:

  管理工具――mysqlamdin

  Mysqladmin是一个执行管理操作的客户端程序。可以用来检查服务器的配置和当前的状态,创建并删除数据库等。

  参考资料:

  日志管理工具――mysqlbinlog

  由于服务器生成的日志文件以二进制格式保存,所以如果要想检查这些文件的文本格式,就会用到mysqlbinlog日志管理工具。

  参考资料:

  表维护工具――mysqlcheck

  Mysqlcheck客户端工具可以检查和修复myisam表,还可以优化和分析表。实际上,它继承了mysql工具中check、repair、analyze、optimize的功能。

  参考资料:

  数据导出工具――mysqldump

  Mysqldump客户端工具用来备份数据库或在不同数据库之间进行数据迁移。备份内容包含创建表或装载表的sql语句。

  参考资料:

  数据导入工具――mysqlimport

  Mysqlimport是客户端导入工具,用于导入mysqldump加-T选项后导出的文本文件。

  参考资料:

  表热备份工具――mysqlhotcopy

  Mysqlhotcopy是一个perl脚本,它使用lock tables、flush tables、cp或scp来快速备份数据库。仅限于在linux/unix下热备份myisam数据表。

  参考资料:

  数据库对象查看工具――mysqlshow

  Mysqlshow是客户端对象查看工具,用来很快地查找存在哪些数据库、数据库中的表、表中的列或索引。

  参考资料:

  错误代码查看工具――perror

  在mysql使用过程中,可能会出现各种各样的error,这些error有些是由于操作系统引起的,有些是由于存储引擎使用不当引起的。这些error都有一个整型的错误代码。Perror的作用是解释这些错误代码的详细含义。

  参考资料:

  文本替换工具――replace

  Replace是mysql自带的一个对文件中的字符串进行替换的工具,类似于linux下的sed,不过他的使用更加简单灵活。

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn