Percona Toolkit 是一组高级的命令行工具集,用来管理 MySQL 和系统任务,主要包括: 1、主从状态检测及修复 2、检测从库复制的延迟 3、慢查询、日志分析 4、检测MySQL 服务器状态 5、从日志和 tcpdump 中检测


1、安装perl相关模块

yum install perl-DBI

yum install perl-DBD-MySQL

yum install perl-Time-HiRes

yum install perl-IO-Socket-SSL

2、下载和安装per依赖包、percona toolkit的包

wget http://pkgs.repoforge.org/perl-TermReadKey/perl-TermReadKey-2.30-1.el3.rf.x86_64.rpm

rpm -ivh perl-TermReadKey-2.30-1.el3.rf.x86_64.rpm

wget https://www.percona.com/downloads/percona-toolkit/2.2.14/RPM/percona-toolkit-2.2.14-1.noarch.rpm  

rpm -ivh percona-toolkit-2.2.14-1.noarch.rpm  

使用 服务器摘要 pt-summary


** 服务器磁盘监测** pt-diskstats


** mysql服务状态摘要** pt-mysql-summary -- --user=root --password=root


** 慢查询日志分析统计** pt-query-digest /data/logs/mysql/mysql-slow.log

表同步工具,和mk-tables-sync功能一样, 用法上 稍有不一样 ,–print的结果更详细 pt-table-sync --execute --print --no-check-slave --database=world h='127.0.0.1' --user=root --password=123456 h='192.168.0.212' --user=root --password=123456


主从状态监测,提供给它一台mysql服务器的IP用户名密码,就可以分析出整个主从架构中每台服务器的信息,包括但不限于mysql版本,IP地址,server ID,mysql服务的启动时间,角色(主/从),Slave Status(落后于主服务器多少秒,有没有错误,slave有没有在运行)。


[root@RHCE6 ~]# pt-slave-find --host=localhost --user=rhce6 --password=rhce6

localhost

Version 5.5.23-log

Server ID 1

Uptime 05:16:10 (started 2012-08-08T09:32:03)

Replication Is not a slave, has 1 slaves connected, is not read_only

Filters

Binary logging STATEMENT

Slave status

Slave mode STRICT

Auto-increment increment 1, offset 1

InnoDB version 1.1.8

+- 192.168.0.168

Version 5.5.23-log

Server ID 10

Uptime 38:19 (started 2012-08-08T14:09:54)

Replication Is a slave, has 0 slaves connected, is not read_only

Filters

Binary logging STATEMENT

Slave status 0 seconds behind, running, no errors

Slave mode STRICT

Auto-increment increment 1, offset 1

InnoDB version 1.1.8


mysql死锁监测 pt-deadlock-logger h='127.0.0.1' --user=root --password=123456


主键冲突检查 pt-duplicate-key-checker --database=world h='127.0.0.1' --user=root --password=123456


监测从库的复制延迟   ###经过测试 运行这个命令会使从库上的sql线程异常挂掉 pt-slave-delay --host 192.168.0.206 --user=root --password=123456