文章目录

  • 安装
  • 下载
  • 安装服务端
  • 安装客户端
  • 使用
  • 概览(overview)
  • 事件(event)
  • 指标(metrics)
  • 查询分析(Query Analyzer)


MySQL在企业版里的有个工具MySQL Enterprise Monitor,可以用于监控MySQL实例和主机性能。现实验如下:

安装

下载

到https://edelivery.oracle.com/ 网站下软件:

mysql线程监控工具 mysql官方监控工具_数据库

安装服务端

unzip mysql_monitor.zip 
 ./mysqlmonitor-8.0.20.1237-linux-x86_64-installer.bin scutech@scutech:~/install$ ll
total 2819608
drwxrwxr-x  2 scutech scutech       4096 Jun  1 23:45 ./
drwxr-xr-x 30 scutech scutech       4096 Jun  1 23:43 ../
-rw-r-xr--  1 scutech scutech        975 Apr 23 05:50 README_en.txt*
-rw-r-xr--  1 scutech scutech        975 Apr 23 05:51 READ_ME_ja.txt*
-rw-r--r--  1 scutech scutech    6370627 Apr 22 08:14 monitor.a4.pdf
-rw-r--r--  1 scutech scutech    6377434 Apr 22 08:13 monitor.pdf
-rw-r--r--  1 scutech scutech    5277767 Apr 22 08:12 mysql-monitor-html.tar.gz
-rw-r--r--  1 scutech scutech    5302202 Apr 22 08:12 mysql-monitor-html.zip
-rw-r--r--  1 scutech scutech 1297382933 Jun  1 23:44 mysql_monitor.zip
-rw-r--r--  1 scutech scutech  270694162 Jun  1 23:44 mysql_monitor_agent.zip
-rwxrwxr-x  1 scutech scutech  647902090 Apr 22 12:26 mysqlmonitor-8.0.20.1237-linux-x86_64-installer.bin*
-rwxrwxr-x  1 scutech scutech  647923832 Apr 22 12:35 mysqlmonitor-8.0.20.1237-linux-x86_64-update-installer.bin*

 ./mysqlmonitor-8.0.20.1237-linux-x86_64-installer.bin

运行上面的命令后出现下面的画面:

mysql线程监控工具 mysql官方监控工具_Enterprise_02


选择小型模式

mysql线程监控工具 mysql官方监控工具_数据库_03


使用安装软件自带的MySQL数据库作为repository数据库

mysql线程监控工具 mysql官方监控工具_Enterprise_04


这个用户(service_manager)和密码等相关信息要记录下来。

mysql线程监控工具 mysql官方监控工具_mysql线程监控工具_05


提示下面的信息,其中提到的root用户是OS的用户,不是mysql的用户:

You have not installed the MySQL Enterprise Monitor as the root user. Therefore it could not be configured to auto-start on reboot. See the Installation section of the MySQL Enterprise Monitor documentation for instructions on how to do this manually.

开始安装:

mysql线程监控工具 mysql官方监控工具_Enterprise_06


安装完成提示:

Setup has completed installing the MySQL Enterprise Monitor files on your computer
Uninstalling the MySQL Enterprise Monitor files can be done by invoking:
/home/scutech/mysql/enterprise/monitor/uninstall
To complete the installation, launch the MySQL Enterprise Monitor UI and complete the initial setup. Refer to the readme file for additional information and a list of known issues.
Please press next to launch the Monitor UI.

管理脚本

usage: ./mysqlmonitorctl.sh help
       ./mysqlmonitorctl.sh (start|stop|status|restart)
       ./mysqlmonitorctl.sh (start|stop|status|restart) mysql
       ./mysqlmonitorctl.sh (start|stop|status|restart) tomcat

help       - this screen
start      - start the service(s)
stop       - stop  the service(s)
restart    - restart or start the service(s)
status     - report the status of the service(s)

使用下面的链接可以访问MySQL Enterprise Monitor https://192.168.???.???:18443
用户 sc_manager

安装客户端

客户端分两种,第一种是在客户端安装被监控的机器上(The architecture of a typical MySQL Enterprise Monitor installation),架构见下图:

mysql线程监控工具 mysql官方监控工具_MySQL_07


第二种是不在被监控的机器上安装任何软件(Agentless Architecture),架构见下图:

mysql线程监控工具 mysql官方监控工具_mysql_08


这两者的对比:

  1. 从架构上看二者区别非常明显,一个有agent,另一个没有agent;
  2. 没有agent的方式用起来方便,配置IP地址,用户,密码等连接方式后直接就可以用了;
  3. 没有agent的方式不能监控主机上非MySQL的信息,而有agent的方式可以;
  4. 从性能的角度考虑,推荐使用有agent的方式。
    下面是安装一个没有agent的客户端的例子:

mysql线程监控工具 mysql官方监控工具_mysql线程监控工具_09

使用

概览(overview)

mysql线程监控工具 mysql官方监控工具_MySQL_10


从overview中可以看到被监控对象的大概情况,设置是点击右上角的齿轮。这是有agent的监控概览,包括了主机的信息,例如磁盘读写,内存使用等。没有agent的监控只有数据库的信息,如下图:

mysql线程监控工具 mysql官方监控工具_mysql_11

事件(event)

超过阀值的事件会在这里列出,阀值的配置在configuration->advisor里面,可以关闭的事件点击最右边action下面的叉叉符合即可关闭。

mysql线程监控工具 mysql官方监控工具_MySQL_12

指标(metrics)

这里有很多衡量被监控对象的指标,这里列举比较有用的几例:

mysql线程监控工具 mysql官方监控工具_Enterprise_13

mysql线程监控工具 mysql官方监控工具_MySQL_14

查询分析(Query Analyzer)

查询分析的数据来自 Performance Schema Statement Digests 特性Performance Schema Statement Digests and Sampling,早于MySQL 5.6.14的版本不支持这个特性。
被分析的语句的长度不能超过下面的参数,否则截断

$ mysqladmin variables|grep max_digest_leng
| max_digest_length                                        | 1024                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| performance_schema_max_digest_length                     | 1024                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

注意:第一个参数max_digest_length是session级别的,而第二个performance_schema_max_digest_length是语句级别的,只对performance_schema起作用。
MySQL Enterprise Monitor Agent每分钟收集一次表performance_schema.events_statements_summary_by_digest,这个表由下面的参数statements_digest 决定是否激活,默认是激活的:

mysql> SELECT * FROM performance_schema.setup_consumers WHERE name = 'statements_digest';
+-------------------+---------+
| NAME              | ENABLED |
+-------------------+---------+
| statements_digest | YES     |
+-------------------+---------+
1 row in set (0.00 sec)

监控的样图如下:

mysql线程监控工具 mysql官方监控工具_Enterprise_15


在每个SQL statement后面有细节选项,点击进入可看这个SQL statement的细节:

mysql线程监控工具 mysql官方监控工具_MySQL_16


当看这个SQL statement的例子的时候,可能因为配置的原因没有显示,这时会有下面的提示:

mysql线程监控工具 mysql官方监控工具_MySQL_17


设置正确后会出现下面的画面:

mysql线程监控工具 mysql官方监控工具_MySQL_18