`
zhb8015
  • 浏览: 397820 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
Group-logo
Spring Roo杂谈
浏览量:0
社区版块
存档分类
最新评论

mysqlreport

阅读更多



1、MySQLReport 简介
MySQLReport 是一个用perl语言编写的MySQL数据库监控脚本,是一个自由软件,它把MySQL数据库的运行状态值(showstatus)以更友好的方式显示出来,通过它可以更方便的查看MySQL数据库的运行状况。目前该脚本的版本是3.5,下载网址是:http://hackmysql.com/scripts/mysqlreport.zip 。
2、MySQLReport安装方法
       MySQLReport 是用perl语言编写,所以想要运行它首先需要安装perl环境;它还要与MySQL数据库连接,所以还需要安装数据库接口 DBI 和 数据库驱动 DBD-MySQL 。
       不同的平台配置环境、安装软件的方式也有所差别,最通用的方式当然是分别下载三个软件包,分别编译、安装。
我使用的操作系统是CentOS3 Update9,要连接的数据库是mysql-5.1.26-rc-linux-i686-glibc23.tar.gz 。CentOS 其实就是 Redhat,所以它本身也提供相应的三个软件包,当然是以RPM形式的提供的。系统安装的时候一般默认为安装 perl 和 数据库接口 DBI,也可以在定制安装的过程中,选择软件包的 “服务器” -> “MySQL数据库” 选项,选中“perl - DB - MySQL”,如果系统已经安装完成,同样也可以很方便的安装:以XWindow形式登录系统,利用 “主菜单” -> “系统设置” ->“添加/删除应用程序” 可以手工的修改软件包,在“添加/删除应用程序”窗口中找到 “服务器” -> “MySQL数据库”选项,点击“细节”按钮,选中的“额外软件包”选中“perl - DB - MySQL”,点击“关闭”按钮关闭当前窗口
,最后点击“更新”,即可安装MySQL的数据库驱动。
       根据 mysql 压缩包中提供 INSTALL-BINARY 文档安装MySQL,安装完成后,默认的配置文件需要修改一下,否则运行 MySQLReport 会报错,操作如下:
用MySQL提供的示例文件覆盖默认的配置文件(注意 # 为提示符)
# cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf
编辑 /etc/my.cnf 文件,修改 socket = /temp/mysql.sock 为 socket = /var/lib/mysql/mysql.sock
解压 mysqlreport.zip 包,建议将 mysqlreport 执行文件复制到 /usr/local/mysql/bin 目录下,并修改文件属性 #chmod +x mysqlreport
如果MySQL数据库没有设置root用户密码,可以在 /usr/local/mysql/bin 目录直接执行以下命令:
#./mysqlreport
如果MySQL数据库设置了root用户密码,需要加入用户名和密码参数:
#./mysqlreport --user root --password 1 
如果监控的是远程主机上的MySQL数据库,还要加上主机选项:
#./mysqlreport --host 172.20.16.117 --user admin --password 1 

如果需要查看mysqlreport的所有选项,执行命令 
#./mysqlreport --help 



MySQLReport使用说明

MySQLReport 以很友好的方式显示 MySQL状态。事实上,它几乎报告了所有的状态。不像 SHOW STATUS 只是在显示了100多个状态值,MySQLReport 则以人性化的方式阐释和格式化了这些状态值,大大增加了其可读性。

MySQLReport的好处是可以快速的查看各种状态参数组,从而了解服务器的运行状态情况,而无需从 SHOW STATUS的结果中人工计算。例如索引读取比率是个重要的参数,但是 SHOW STATUS 中并没有显示;它是一个推断值(key_reads 和key_read_requests 的比值)。

本文档描述了 MySQLReport 的所有命令行选项,大部分是用于控制如何显示结果的。本文并没有解释这些推断值是怎么计算得到的,可以点击 理解MySQLReport 查看具体的计算方法。 

注意:命令行选项的格式是 --选项,不过 -选项 的格式也可以。所有的选项都有其缩写,只要是唯一的。例如,选项 --host 可以缩写成 --ho,不过不能写成 --h,因为 --h 有歧义,可能是 --host 或者 --help。 

选项列表:

--user USER

--password 从 2.3 版本开始,--password 可以在后面加上参数,如 "--password FOO"。如果命令行中只指定了选项 --password,则会提示输入密码。

--host ADDRESS

--port PORT

--socket SOCKET

--no-mycnf 告诉 MySQLReport 不要读取 ~/.my.cnf,默认会去读取这个文件。--user 和 --password 总是覆盖从 ~/.my.cnf 中取得的结果。  

--infileFILE 直接从文件中读取状态文件,而不是从MySQL的 SHOW STATUS 中读取。文件内容通常是从 SHOW STATUS的结果中取得,并且包含格式化字符(|, +, -)。MySQLReport 认为这样的文件"状态名 数值"格式的,状态包含字符和下划线(A-Z和 _),数值则是非负整数。在状态名和数值之间的任何内容都会被忽略。MySQLReport也需要以下MySQL服务器系统变量:version, table_cache, max_connections,key_buffer_size, query_cache_size, thread_cache_size。INFILE 的格式也可以是 "名字= 数值"这样的,名字可以使是上面提到的各种变量名,数值是非负整数,可能后面带有M或者其他单位(根据版本不同而定)。例如,想要指定 18M 的key_buffer_size:key_buffer_size = 18M。或者,256 个 table_cache:table_cache= 256。M 指兆字节,而非百万。因此 18M 是 18,874,368,而非18,000,000。如果这些服务器变量没有指定,则使用默认以下默认值:0.0.0, 64, 100, 8M, 0,0,就可能会让报告结果看起来很奇怪。 

注意:MySQL 服务器版本在 5.1.3 或更新时,尽管系统变量 table_cache 改成了 table_open_cache,但是读取本地文件时仍采用 table_cache。 

--outfileFILE 在屏幕显示完报告结果后,将结果写入文件中。MySQLReport的内部机制总是先将结果写入临时文件中。然后将该临时文件里的内容打印到屏幕上。然后,如果指定了 --outfile 选项,则将临时文件拷贝成OUTFILE。如果指定选项 --email,则会删除临时文件。 

--email ADDRESS在屏幕显示完结果后,将结果发送到邮件地址 ADDRESS 中去。欲该选项,需要在 /usr/sbin/ 目录下有 sendmail程序,因此无法在 windows 平台下使用。/usr/sbin/sendmail 可以符号链接到 qmail,或者任何其他能模拟sendmail -t 方式的 MTA 程序。邮件来源是:MySQLReport,主题是:MySQL status report onHOST,HOST 是 MySQLReport 所在的主机名,可能是读取到的 --host 值,默认是 localhost。 

--flush-status  显示完报告后,执行 "FLUSH STATUS;" 语句。如果没有权限,则 DBD::mysql 会显示返回值。  

--relative(-r) X MySQLReport 通常情况下报告的是自从 MySQL 服务器启动以来的状态信息。--relative 选项则是令MySQLReport 产生一份自从上次报告以来的相关报告。如果 --relative X 的 X 值是一个整数,则 MySQLReport会在隔 X 秒后再次产生一份 MySQL 服务器的状态报告。产生报告的次数是由 --report-count 选项来控制的。默认是产生 1份相关的报告。例如,指定 --relative 的值为 60,则会产生 2 份报告:第一份会马上生成,第二份会在 60秒后再次生成。第二份报告中的数值会和前面的那份相关。例如,前面那份中总共有 10.00k 次查询,在这 60 秒的间隔时间里接受了新的1.00k 次查询,则第二份的报告中的总查询次数是 1.00k 而非 11.00k 次。如果 --relative选项的值也可以是本地文件(类似 --infile 选项的用法),那么 MySQLReport会按照参数值中文件的顺序来依次产生状态报告。因此,根据这些文件产生的时间来指定选项的值非常重要:较早产生的文件放在参数的前面。第一个文件中必须有手工添加的系统变量,例如:key_buffer_size、table_cache 等。每个文件中可以有多组 "SHOW STATUS"的结果。注意:通过 "mysqladmin -r -i N extended" 产生的状态文件无法使用,因为 mysqladmin 的 -r参数已经令其产生了具有相对性的状态值了。由于 MySQLReport 首先会把状态报告写到临时文件中,如果 --relative 的值是整数(而非 本地文件)时,MySQLReport 会显示它把文件写到哪了。那么就可以直接通过查看这些文件内容来观察服务器的状况了。 

--report-count (-c) N  生成 N 份相关的报告。本选项只有在同时启用 --relative 选项后才有效。MySQLReport 会自动产生 N+1 份报告:第一份基本报告,以及后面的 N 份相关报告。  

---help  显示帮助信息。

-detach若指定本选项,则 MySQLReport 会派生出进程来,不只是在屏幕显示结果,还会转入后台继续运行。派生新进程后,MySQLReport会报告它把结果写入哪个临时文件了。本选项还可以指定 --outfile 或 --email 的一个。如果没有指定 --outfile 或--email 的值,则产生的临时文件会被删除,因为 MySQLReport 派生出新进程后,无法再将结果打印到终端屏幕上了。本选项如果和--relative 一起使用的话就更有意义了,这样 MySQLReport就能定时报告信息,而无需人工登录等方式在中断执行了。使用如下的命令,就能让 mysqlrepot隔一个小时再次产生一次报告,并将结果发送到自己的信箱中去:MySQLReport -r 3600 -detach [email=-%3Ca%20href=]emailhost@domain.com[/email]">-emailhost@domain.com ,一个小时候后,MySQLReport 通过email发送报告,删除临时文件,并且干净地终止。 

--debug  显示调试信息。 

分享到:
评论

相关推荐

    mysqlreport源码安装包三件套

    MySQLreport是一款实用的工具,它能生成详细的MySQL服务器性能报告,包括各种关键指标,如查询效率、表状态、缓存利用率等。这个源码安装包包含三个主要组件:DBI(Database Interface)、DBD(Database Driver for ...

    mysqlreport-3.5.rar

    MySQLreport 是一个强大的工具,主要用于收集和报告 MySQL 数据库服务器的关键性能指标。这个工具的版本是3.5,被封装在“mysqlreport-3.5.rar”压缩文件中,其后缀名错误地标记为“rar”,但实际上应该是“zip”。...

    mysqlreport安装三件套

    mysqlreport安装三件套mysqlreport安装三件套mysqlreport安装三件套mysqlreport安装三件套mysqlreport安装三件套mysqlreport安装三件套mysqlreport安装三件套

    使用开源工具mysqlreport监控Mysql数据库-简易使用方法分享.pdf

    MySQLreport 是一个基于命令行的开源工具,用于监控 MySQL 数据库的状态和性能。它通过收集并格式化 MySQL 的系统变量和状态信息,提供了一个简洁的报告,帮助管理员了解数据库的运行情况。虽然不支持实时刷新,但...

    mysqlreport-3.5

    MySQLreport 是一个强大的工具,主要用于生成关于 MySQL 数据库服务器的详细报告。这个工具的主要目标是提供一种简单且直观的方式来查看数据库的性能指标、状态和配置信息。MySQLreport v3.5 版本提供了更完善的报告...

    mysqlreport-3.5.tar.gz

    MySQLreport是一款强大的命令行工具,专门用于收集和报告MySQL服务器的各种状态信息,便于数据库管理员进行性能分析和故障排查。在“mysqlreport-3.5.tar.gz”这个压缩包中,包含的是MySQLreport的3.5版本。下面我们...

    mysqlreport报告分析记录

    MySQLreport 是一个强大的工具,它能提供 MySQL 服务器的详细状态报告,包括各种性能指标、配置参数以及系统资源使用情况。对于数据库管理员来说,理解并分析这些报告是优化数据库性能的关键步骤。本篇文章将深入...

    使用开源工具mysqlreport监控Mysql数据库-简易使用方法.pdf

    MySQLreport 是一个基于命令行的开源工具,用于监控 MySQL 数据库的状态和性能。它通过收集和格式化 MySQL 的系统变量和状态信息,提供了一个简洁的报告,帮助管理员了解数据库的健康状况、性能瓶颈以及资源使用情况...

    mysqlreport.tar

    mysqlReport

    mysql性能分析工具mysqlreport)

    mysqlreport是由hackmysql.com 的站长所撰写的 Perl Scritps,旨在协助 MySQL DBA 搜集与分析 MySQL 的运作状况。用着感觉不错。 官方网站: http://hackmysql.com/ 软件下载: http://hackmysql.com/mysqlreport

    mysqlreport显示Com_中change_db占用比例高的问题的解决方法

    标题中的“mysqlreport显示Com_中change_db占用比例高的问题的解决方法”指的是在使用mysqlreport工具分析MySQL服务器性能时,发现`Com_change_db`操作的频率异常高,这可能是导致服务器频繁出现阻塞和重启的原因之...

    MySQL 效能监控工具

    ### MySQL效能监控工具—mysqlreport #### 一、引言 在MySQL数据库管理过程中,确保服务器性能稳定且高效运行是一项重要任务。面对大量的系统变量数据,手动收集与分析变得异常繁琐且低效。为此,mysqlreport...

    javaeye Robbin 论缓存技术

    - 对于数据库缓存,可以通过MySQL的`show status`命令、mysqlreport脚本、MySQL Administrator工具或者专门的innotop工具来监控和分析缓存的使用情况,进行性能调优。 总结来说,缓存技术在现代软件系统中扮演着至...

    jasperreports 与 iReport

    - `mysqlreport2.html` 和 `mysqlreport2.jasper` 代表另一个基于MySQL数据的报表。 - `report1.html`, `report1.jasper`, `kanshu4.jasper`, `kanshu2.jasper`, `subreport3.jasper` 分别代表不同的报表和可能的子...

    Linux下的MySQL调优

    3. **其他辅助工具**:`mysqlreport`生成易于理解的数据库报告,`profiling`分析查询执行步骤,还有各种第三方监控工具。 **调优策略** 1. **硬件、网络和软件优化**:升级硬件(如CPU、内存、磁盘和网络),使用...

    MySQL监控工具小集合[归纳].pdf

    2. **MysqlReport**:这是一个Perl脚本,提供直观的监控数据。它可以作为Cacti的数据来源,但其局限在于只能进行实时监控,不具备图表展示和历史数据记录功能。 3. **phpMyAdmin**:虽然主要作为一个Web模式的MySQL...

    JavaEye的Boss分享关于缓存的理解

    监控缓存状态至关重要,MySQL提供了一系列的监控工具,如`show status like 'Qcache%'`、`show innodb status\G`和mysqlreport等,帮助开发者了解Query Cache和InnoDB Buffer Pool的使用情况,以便进行优化。...

    非常棒的缓存技术教程

    监控工具如`show status`命令和mysqlreport脚本可以帮助我们了解缓存的使用情况和性能瓶颈。 Web服务器缓存主要应用于减少对应用服务器的请求,例如Apache或Nginx的缓存模块,可以缓存静态文件,减少服务器计算压力...

Global site tag (gtag.js) - Google Analytics