https://www.percona.com/downloads/percona-toolkit/LATEST/
https://www.percona.com/downloads/percona-toolkit/2.2.14/RPM/ 这里可以下载
原文出自:http://www.cnblogs.com/zping/p/5678652.html
percona-toolkit是个很实用的工具集,之前只使用了它的部分功能,后来有机会深入接触,才发现它的功能很全面,从管理、开发到监控都有对应的工具。
1.检查和安装与Perl相关的模块
PT工具是使用Perl语言编写和执行的,所以需要系统中有Perl环境。
依赖包检查命令为:rpm -qa perl-DBI perl-DBD-MySQL perl-Time-HiRes perl-IO-Socket-SSL
如果有依赖包确实,可以使用下面的命令安装:
yum install perl-DBI
yum install perl-DBD-MySQL
yum install perl-Time-HiRes
yum install perl-IO-Socket-SSL
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
如果不能下载: 直接进入页面下载rpm包:
1,https://centos.pkgs.org/ 搜索: perl-TermReadKey 下载
2,https://www.percona.com/downloads/ 进入下载页面下载
注意:需要安装Term::ReadKey 包,否则会报perl(Term::ReadKey) is needed by percona-toolkit-2.2.14-1.noarch
2:下载和安装percona toolkit的包
http://pkgs.repoforge.org/perl-TermReadKey/(key)
https://www.percona.com/downloads/percona-toolkit/ (tool)
安装后,可以通过下面的命令确认是否安装成功:
# pt-query-digest --help
# pt-table-checksum --help
如果命令提示可以正常显示,则说明pt工具已经正常安装和使用了。
有的32个命令,可以分为7大类:




上面是pt工具各个命令的基本功能介绍,可以使用 command --help 来查看每个命令的具体作用和使用方法;
有的命令也可以使用 man command 命令查询相关命令详细信息。
目前使用的比较多的命令是: pt-query-digest ,pt-kill等命令。
加字段:
pt-online-schema-change --alter "add column attribute3 varchar(100)" h=192.168.1.142,P=3306,p=cc.123,u=root,D=orabenlai,t=oraesb --no-check-replication-filters --execute
说明: 1, 如果有 binlog_ignore_db = mysql 选型会报check-replication-filters 错误,必须加上 --no-check-replication-filters
2,--execute 前面是有2个"-"
列出重复的索引和主键,并打印出删除语句:
pt-duplicate-key-checker -h 172.16.59.99 -u dba_huzj -p 123456 -P 43306 -d eifta
pt-heartbeat 检查主从延迟
创建心跳检测表:
pt-heartbeat --check -h 172.16.59.99 -u dba_huzj -p 123456 -P 43306 --database=eifta --create-table --master-server-id=16059099
在主库上启动更新表:
pt-heartbeat -D eifta --update -h 172.16.59.99 -u dba_huzj -p 123456 -P 43306 --daemonize
监控从的延迟情况:
pt-heartbeat --check -D eifta -h 172.16.59.100 -u dba_huzj -p 123456 -P 43306
pt-table-checksum一致性校验:
pt-table-checksum --nocheck-replication-filters --no-check-binlog-format --replicate=172.16.59.100 --databases=eifta -h 172.16.59.99 -u dba_huzj -p 123456
来自 https://www.cnblogs.com/janehoo/p/8969739.html
1.检查和安装与Perl相关的模块
PT工具是使用Perl语言编写和执行的,所以需要系统中有Perl环境。
依赖包检查命令为:
rpm -qa perl-DBI perl-DBD-MySQL perl-Time-HiRes perl-IO-Socket-SSL
如果有依赖包确实,可以使用下面的命令安装:
yum install perl-DBI
yum install perl-DBD-MySQL
yum install perl-Time-HiRes
yum install perl-IO-Socket-SSL
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
如果不能下载: 直接进入页面下载rpm包:
1,https://centos.pkgs.org/ 搜索: perl-TermReadKey 下载
2,https://www.percona.com/downloads/ 进入下载页面下载
注意:需要安装Term::ReadKey 包,否则会报perl(Term::ReadKey) is needed by percona-toolkit-2.2.14-1.noarch
2:下载和安装percona toolkit的包
http://pkgs.repoforge.org/perl-TermReadKey/(key)
https://www.percona.com/downloads/percona-toolkit/ (tool)
安装后,可以通过下面的命令确认是否安装成功:
# pt-query-digest --help
# pt-table-checksum --help
如果命令提示可以正常显示,则说明pt工具已经正常安装和使用了。
有的32个命令,可以分为7大类:
工具类别 | 工具命令 | 工具作用 | 备注 |
开发类 | pt-duplicate-key-checker | 列出并删除重复的索引和外键 |
|
pt-online-schema-change | 在线修改表结构 |
|
pt-query-advisor | 分析查询语句,并给出建议,有bug | 已废弃 |
pt-show-grants | 规范化和打印权限 |
|
pt-upgrade | 在多个服务器上执行查询,并比较不同 |
|
性能类 | pt-index-usage | 分析日志中索引使用情况,并出报告 |
|
pt-pmp | 为查询结果跟踪,并汇总跟踪结果 |
|
pt-visual-explain | 格式化执行计划 |
|
pt-table-usage | 分析日志中查询并分析表使用情况 | pt 2.2新增命令 |
配置类 | pt-config-diff | 比较配置文件和参数 |
|
pt-mysql-summary | 对mysql配置和status进行汇总 |
|
pt-variable-advisor | 分析参数,并提出建议 |
|
监控类 | pt-deadlock-logger | 提取和记录mysql死锁信息 |
|
pt-fk-error-logger | 提取和记录外键信息 |
|
pt-mext | 并行查看status样本信息 |
|
pt-query-digest | 分析查询日志,并产生报告 | 常用命令 |
pt-trend | 按照时间段读取slow日志信息 | 已废弃 |
复制类 | pt-heartbeat | 监控mysql复制延迟 |
|
pt-slave-delay | 设定从落后主的时间 |
|
pt-slave-find | 查找和打印所有mysql复制层级关系 |
|
pt-slave-restart | 监控salve错误,并尝试重启salve |
|
pt-table-checksum | 校验主从复制一致性 |
|
pt-table-sync | 高效同步表数据 |
|
系统类 | pt-diskstats | 查看系统磁盘状态 |
|
pt-fifo-split | 模拟切割文件并输出 |
|
pt-summary | 收集和显示系统概况 |
|
pt-stalk | 出现问题时,收集诊断数据 |
|
pt-sift | 浏览由pt-stalk创建的文件 | pt 2.2新增命令 |
pt-ioprofile | 查询进程IO并打印一个IO活动表 | pt 2.2新增命令 |
实用类 | pt-archiver | 将表数据归档到另一个表或文件中 |
|
pt-find | 查找表并执行命令 |
|
pt-kill | Kill掉符合条件的sql | 常用命令 |
pt-align | 对齐其他工具的输出 | pt 2.2新增命令 |
pt-fingerprint | 将查询转成密文 | pt 2.2新增命令 |
上面是pt工具各个命令的基本功能介绍,可以使用 command --help 来查看每个命令的具体作用和使用方法;
有的命令也可以使用 man command 命令查询相关命令详细信息。
目前使用的比较多的命令是: pt-query-digest ,pt-kill等命令。
加字段例子:
pt-online-schema-change --alter "add column attribute3 varchar(100)" h=192.168.1.142,P=3306,p=cc.123,u=root,D=orabenlai,t=oraesb --no-check-replication-filters --execute
说明: 1, 如果有 binlog_ignore_db = mysql 选型会报check-replication-filters 错误,必须加上 --no-check-replication-filters
2,--execute 前面是有2个"-"
3,加多个字段可以使用: "add column attribute1 varchar(100),add column attribute2 varchar(100)"
分类: MySQL
来自 https://www.cnblogs.com/zping/p/5678652.html