前言

采用Anemometer将Mysql慢查询日志可视化,可以更便捷的查询慢查询日志,并根据时间戳进行历史查询。如下是单机版Anemometer部署的演示,实际应用中,为安全起见,建议把anemometer 分开到另外的机器上。

工作原理

Anemometer: 实现日志可视化

pt-query-digest :抽取慢查询日志

环境信息

Ip 功能 软件信息 安装路径 操作系统
192.168.9.11 http服务 httpd-2.2.15-54 yum缺省路径 centos6.9
慢查询日志抓取导入 pt-query-digest rpm缺省路径
慢查询日志切割 logrotate yum缺省路径
可视化展示 Anemometer /var/www/html

安装步骤

1.安装apache

  1. yum install httpd -y

2.安装pt-query-digest并设置抓取脚本

  1. yum install perl-DBI perl-DBD-MySQL perl-Time-HiRes perl-IO-Socket-SSL -y
  2.  
  3. #需要安装perl-TermReadKey否则会报错
  4. wget http://pkgs.repoforge.org/perl-TermReadKey/perl-TermReadKey-2.30-1.el3.rf.x86_64.rpm
  5. rpm -ivh perl-TermReadKey-2.30-.el3.rf.x86_64.rpm
  6.  
  7. wget https://www.percona.com/downloads/percona-toolkit/2.2.20/RPM/percona-toolkit-2.2.20-1.noarch.rpm
  8. rpm -ivh percona-toolkit-2.2.-.noarch.rpm
  9.  
  10. vim /home/shell_script/slow_db_export.sh
  11. #!/bin/bash
  12. /usr/bin/pt-query-digest --user=anemometer --password= --review h=192.168.9.11,D=slow_query_log,t=global_query_review --history h=192.168.9.11,
  13. D=slow_query_log,t=global_query_review_history --no-report --limit=% --filter=" \$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$HOSTNAME\"" /usr/local/mysql/data/mysql.slow
  14.  
  15. chmod -R /home/shell_script/slow_db_export.sh

3.安装logrotate并配置每日切割mysql慢查询日志

  1. yum install logrotate -y
  2. vim /etc/logrotate.d/mysql
  3. /usr/local/mysql/data/mysql.slow {
  4. create mysql mysql
  5. dateext
  6. notifempty
  7. daily
  8. maxage
  9. rotate
  10. missingok
  11. compress
  12. olddir /usr/local/mysql/old_log
  13. postrotate
  14. ##########run if mysqld is running
  15. if /usr/local/mysql/bin/mysqladmin ping -h172.27.127. -uroot -p'Hs!hs8989' -S /usr/local/mysql/mysql.sock &>/dev/null; then
  16. /usr/local/mysql/bin/mysqladmin flush-logs -h172.27.127. -uroot -p'Hs!hs8989' -S /usr/local/mysql/mysql.sock
  17.  
  18. fi
  19. endscript
  20. }
  21. chmod -R /etc/logrotate.d/mysql

4.将pt-query-digest脚本和logrotate切割脚本放入crontab中

  1. #############23点55分-分割导入当天的慢查询数据#####################
  2. * * * /home/shell_script/slow_db_export.sh
  3. ###############23点59分-切割慢查询日志#############
  4. * * * root ( /usr/sbin/logrotate -f /etc/logrotate.d/mysql)

5.安装Anemometer

  1. cd /var/www/html
  2. git clone https://github.com/box/Anemometer.git anemometer&&cd anemometer
  3.  
  4. #创建表和用户名
  5. # mysql -uroot -proot < install.sql
  6. # mysql-uroot -proot -e "grant ALL ON slow_query_log.* to 'anemometer'@'localhost' IDENTIFIED BY '123456';"
  7. # mysql -uroot -proot -e "grant SELECT ON *.* to 'anemometer'@'localhost' IDENTIFIED BY '123456';"
  8. # mysql -uroot -proot -e "flush privileges;"

6.导入日志并打开页面测试(http://192.168.9.11/amemometer

  1. #执行刚刚编辑的slow_db_export.sh脚本
  2. ./home/shell_script/slow_db_export.sh
  3.  
  4. #重启apache
  5. service httpd restart

至此,已经通过Anemometer实现了mysql慢查询日志可视化功能。

十分钟部署Anemometer作为Mysql慢查询可视化系统的更多相关文章

  1. 【转载】 使用Anemometer基于pt-query-digest将MySQL慢查询可视化

    原文地址:使用Anemometer基于pt-query-digest将MySQL慢查询可视化 作者:84223932 本文主要介绍使用Anemometer基于pt-query-digest将MySQL ...

  2. 使用Anemometer基于pt-query-digest将MySQL慢查询可视化

    最近玩MySQL,发现了一个很不错的工具,可以把MySQL慢查询可视化,方便我们去找出和分析慢询语句,搭建的步骤不多,但网上详细教程比较少,说得也不够详细,一不小心,估计得蛋痛一会,哈哈 Percon ...

  3. 使用Anemometer分析MySQL慢查询记录

    数据库管理员一般是用percona的toolkit工具来分析MySQL慢查询记录,但是不够直观. 下面介绍一款比较直观的工具来统计分析MySQL慢查询记录anemometer. 在使用之前需要安装pe ...

  4. Kubernetes笔记(一):十分钟部署一套K8s环境

    Kubernetes是Goole开源的一个容器编排引擎,它支持自动化部署.大规模可伸缩.应用容器化管理 -- 百度百科. 接触K8s也有半年多了,也基于阿里云平台搭建了包含多级服务.目前运行较为稳定的 ...

  5. Docker 版 3分钟部署 .net core 开源在线客服系统,他来了

    我在博客园发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程. 前些天又应朋友的要求,发了一篇 CentOS 版本的安装部署教程:https://www.cnblogs.com ...

  6. mysql数据库查询过程探究和优化建议

    查询过程探究 我们先看一下向mysql发送一个查询请求时,mysql做了什么? 如上图所示,查询执行的过程大概可分为6个步骤: 客户端向MySQL服务器发送一条查询请求 服务器首先检查查询缓存,如果命 ...

  7. (转)十分钟了结MySQL information_schema

    十分钟了结MySQL information_schema  原文:http://www.cnblogs.com/shengdimaya/p/6920677.html information_sche ...

  8. oracle查询十分钟之前的数据

    select * from TABLE as of timestamp sysdate - 10/1440 t WHERE ColName='1111'; TABLE:表名 WHERE:查询子句 sy ...

  9. 十四、MySQL UPDATE 查询

    MySQL UPDATE 查询 如果我们需要修改或更新 MySQL 中的数据,我们可以使用 SQL UPDATE 命令来操作.. 语法 以下是 UPDATE 命令修改 MySQL 数据表数据的通用 S ...

随机推荐

  1. VMware安装VMware tool后mount /dev/cdrom /mnt成功挂载含rpm包的镜像

    安装虚拟机后如果不安装vmware tool使用mount /dev/cdrom /mnt可以成功挂在含rpm包的镜像,但是安装VMware tool后挂在后/mnt中是错误的内容.查了半天后无果,自 ...

  2. linux普通用户使用root权限执行命令的脚本

    上一篇有说到普通用户使用免密登录并使用root权限: http://www.cnblogs.com/01-single/p/8919254.html 现在使用脚本批量实现部署系统任务操作步骤: #!/ ...

  3. ADFUtils

    import java.text.SimpleDateFormat; import java.util.Map; import javax.el.ELContext;import javax.el.E ...

  4. 20165322 第九周 实现mypwd

    实现mypwd 学习pwd man pwd 该命令用来显示目前所在的工作目录 参数 -P显示当前目录的物理路径 -L显示当前目录的连接路径 man -k dir | grep 2 由图可知,可以用ge ...

  5. cin,get,getline

    一.cin 1.cin使用空白(空格.制表符和换行符)来确定字符串结束的位置,并且对于换行符,cin会把换行符留在输入队列.cin读取字符串放到数组中,并自动在结尾添加空字符. 例如: ]; cin& ...

  6. MyBatis(8)延迟加载&缓存

    什么是延迟加载? resultMap可以实现高级映射,association,collection具有延迟加载的功能.   当我们需要查询某个信息的时候,再去查询,达到按需查询,就是延迟加载   可以 ...

  7. Linux.开关机&登出&用户管理

    关机重启: shutdown:         shutdown –h now 立该进行关机         shudown -h 1 "hello, 1 分钟后会关机了"    ...

  8. 【翻译】Django Channels 官方文档 -- Tutorial

    Django Channels 官方文档 https://channels.readthedocs.io/en/latest/index.html 前言: 最近课程设计需要用到 WebSocket,而 ...

  9. Spring自定义注解(验证身份证+性别+地区)

    第一步:定义注解 PersonFormId: package com.wbg.maven1128.demo_formatter; import java.lang.annotation.*; @Doc ...

  10. HDU 2030 汉字统计(汉字Asics码为负,占两个char)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2030 汉字统计 Time Limit: 2000/1000 MS (Java/Others)    M ...