欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

常用mysql数据库工具简介

程序员文章站 2022-05-05 19:30:48
...

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,不过他的使用更加简单灵活。