1:接口工具
接口工具可以帮助运行查询,创建表和用户,以及执行其它日常任务等。
MySQL Workbench
MySQL Workbench是一个一站式的工具,可以完成例如:管理服务器,写查询,开发存储过程,以及Schema设计图相关的工作。可以通过一个插件接口来编写自己的工具并集成到这个工作平台上,有一些Python脚本和库就使用了这个插件接口。MySQL Workbench有社区版和商业版两个版本,商业版只是增加了其它一些高级特性。免费版对于大部分需要已经足够了。参考:http://www.mysql.com/products/workbench/
SQLyog
SQLyog是MySQL最流行的可视化工具之一,有许多很好的特性。它与MySQL Workbench是同级别的工具,但两个工具都有一些对方没有的特性。SQLyog只能在Windows下使用,拥有全部特性的版本需要付费。参考:https://www.webyog.com/
phpMyAdmin
phpMyAdmin是一个流行的管理工具,运行在Web服务器上,并且提供基于浏览器的MySQL服务器访问接口。尽管基于浏览器的访问有时很好,但phpMyAdmin是一个大而复杂的工具,曾被指责有许多安全的问题。对此要格外小心。建议不要安装在任何可以从互联网访问的地方。参考:http://sourceforge.net/projects/phpmyadmin/
Adminer
Adminer是个基于浏览器的安全的轻量级管理工具,它与phpMyAdmin同类。其开发者将其定位为phpMyAdmin的更好的替代品。尽管它看起来更安全,但仍建议安装在任何可公开访问的地方时要谨慎。参考:http://www.adminer.org/
2:命令行工具集
MySQL包含了一些命令行工具集,例如mysqladmin和mysqlcheck。这些在MySQL手册上都有提及和记录。MySQL社区同样创建了大量高质量的工具包,并有很好的文档支撑这些实用工具集。
Percona Toolkit
Percona Toolkit是MySQL管理员必备的工具包。其包括许多针对类似日志分析,复制完整性,数据同步,模式和索引分析,查询建议和数据归档目的的工具。如果刚开始接触MySQL,建议首先学习这些关键的工具:pt-mysql-summary,pt-table-checksum,pt-table-sync和pt-query-digest。参考:http://www.percona.com/software/
The openark kit
Shlomi Noach的openark kit(http://code.openark.org/forge/openark-kit)包含了可以用来做一系列管理任务的Python脚本。
Innotop
它展示了服务器正在发生事情的实时更新视图。可显示事务列表,正在运行的查询,当前锁和锁等待的列表,服务器状态和变量的汇总等等。极具可配置性和可扩展性。
3:SQL实用集
服务器本身也内置有一系列免费的附加组件和实用集可以使用;其中一些确实相当强大。
common_schema
Shlomi Noach的common_schema项目(http://code.openark.org/forge/common_schema)是一套针对服务器脚本化和管理的强大的代码和视图。common_schema对于MySQL好比jQuery对于JavaScript。
mysql-sr-lib
Giuseppe Maxia为MySQL创建了一个存储过程的代码库。参考:http://www.nongnu.org/mysql-sr-lib/
MySQL UDF仓库
Roland Bouman建立了一个MySQL自定义函数的收藏库。参考:http://www.mysqludf.org
MySQL Forge
在MySQL Forge上(http://forge.mysql.com),可以找到上百个社区贡献的程序,脚本,代码片段,实用集和技巧以及陷阱。
4:监测工具
两种类型的监测工具:1):健康监测工具(监测到异常时告警)
2):为趋势,诊断,问题排查,容量规划等记录指标的工具
大多数系统仅在这些任务中的一个方面做得很好,而不能两者兼顾。
4.1:开源的监控工具
Nagios
Nagios(http://www.nagios.org)也许是开源世界中最流行的问题检测和告警系统。
Zabbix
Zabbix是一个同时支持监控和指标收集的完整系统。例如:它将所有配置和其它数据存储到数据库而不是配置文件中。它存储了比Nagios更多的数据类型,因而可以得到更好的趋势和历史报表。其网络画图和可视能力也比Nagios更强,配置更简单,更灵活,且更具有可扩展性。参考:http://www.zabbix.com
Zenoss
Zenoss是用Python写的,拥有一个基于浏览器的用户界面,使用Ajax,这使它更快,更高效。它可以自动发现网络上的资源,并将监控,告警,趋势,绘图和记录历史数据整合到了一个统一的工具中。Zenoss默认使用SNMP来从远程服务器上收集数据,但也可以使用SSH,并且支持Nagios插件。参考:http://www.zenoss.com
Hyperic HQ
Hyperic HQ是一个基于java的监控系统,比起同级别的其它的大部分系统,它更称的上市企业级监控。参考:http://www.hyperic.com
OpenNMS
OpenNMS 也是java开发,有一个活跃的开发社区。它拥有常规的特性,例如监控和告警,但同样也增加了绘图和趋势功能。它的目标是:高性能,可扩展,自动化和灵活。参考:http://www.opennms.org
Groundwork Open Source
Groundwork Open Source用一个可移植的接口把Nagios和其它几个工具整合到一个系统中。参考:
http://www.gwos.com
相比于集所有功能于一身的系统,还有一系列的软件专注于收集指标和画图以及可视化,而不是进行性能监控检查。他们中有很多是建立在RRDTool(http://www.rrdtool.org)之上,存储时序数据到轮询数据库(RRD)文件中。RRD文件自动聚集输入数据,对没有预期传送的输入值进行插值,并有强大的绘图工具可以生成漂亮又特色的图。
MRTG
MRTG是典型的基于RRDTool对的系统。最初是为记录网络流量设计的,但同样可以扩展到用于对其它指标进行记录和绘图。参考:http://oss.oetiker.ch/mrtg/
Cacti
Cacti可能是最流行的基于RRDTool的系统。它采用PHP网页来与RRDTool进行交互,并使用MySQL数据库来定义服务器,插件,图像等。因为是模板驱动,故而可以定义模板然后应用到系统上。Baron为MySQL和其它系统写了一组非常流行的模板;更多信息请参考:http://code.google.com/p/mysql-cacti-templates/。这些也已经一直到OpenNMS,Zabbix,Munin.
Munin
Munin收集数据并存入RRDTool中,然后以几个不同级别的粒度生成数据图。参考:http://munin.projects.linpro.no
4.2:商业监控系统
MySQL Enterprise Monitor
它将监控,指标和画图,咨询服务和查询分析等特性整合到了一个工具中。通过在服务器上使用agent来检测状态计数器。参考:http://www.mysql.com/products/enterprise/monitor.html。
MoNyog
是一个运行在桌面上的基于浏览器且无agent的监控系统。它会启动一个HTTP服务器,然后就可以通过浏览器来使用此工具。参考:http://www.webyog.com。
Splunk
是一个日志聚集器和搜索引擎,可以帮助获得环境中所有机器生产的数据并进行运营分析。参考:
http://www.splunk.com。
Pingdom
是一个从世界的多个位置来监控网站的可用性和性能。实际上有许多像Pingdom一样的服务,我们并不需要特别推荐一个这样的服务,但是我们确实建议使用一些外部的监控服务,以便你在网站不可用时能够及时得到通知。参考:http://www.pingdom.com。
等等