最近在改造开发MySQL时要使用pt-query-digest工具分析性能问题,一路遇到了一些问题,记录下来便于日后翻看。
系统: #45~20.04.1-Ubuntu SMP Mon Apr 4 09:38:31 UTC 2022 x86_64 x86_64 x86_64 GNU/Linux
在安装过程中遇到了很多的问题,官网给的直接安装失败,不再贴图,下面是安装成功的过程:
Ubuntu下安装pt-query-digest的过程:
(1)、安装percona-toolkit
sudo apt install percona-toolkit
xx$ sudo apt install percona-toolkit
正在读取软件包列表... 完成
正在分析软件包的依赖关系树
正在读取状态信息... 完成
将会同时安装下列软件:
libdbd-mysql-perl libdbi-perl libterm-readkey-perl
建议安装:
libclone-perl libmldbm-perl libnet-daemon-perl libsql-statement-perl
下列【新】软件包将被安装:
libdbd-mysql-perl libdbi-perl libterm-readkey-perl percona-toolkit
升级了 0 个软件包,新安装了 4 个软件包,要卸载 0 个软件包,有 324 个软件包未被升级。
需要下载 1,732 kB 的归档。
解压缩后会消耗 10.3 MB 的额外空间。
您希望继续执行吗? [Y/n] y
获取:1 http://cn.archive.ubuntu.com/ubuntu focal-updates/main amd64 libdbi-perl amd64 1.643-1ubuntu0.1 [730 kB]
获取:2 http://cn.archive.ubuntu.com/ubuntu focal/universe amd64 libdbd-mysql-perl amd64 4.050-3 [82.8 kB]
获取:3 http://cn.archive.ubuntu.com/ubuntu focal/main amd64 libterm-readkey-perl amd64 2.38-1build1 [24.6 kB]
获取:4 http://cn.archive.ubuntu.com/ubuntu focal/universe amd64 percona-toolkit all 3.1+dfsg-1.1 [895 kB]
已下载 1,732 kB,耗时 3秒 (620 kB/s)
正在选中未选择的软件包 libdbi-perl:amd64。
(正在读取数据库 ... 系统当前共安装有 258397 个文件和目录。)
准备解压 .../libdbi-perl_1.643-1ubuntu0.1_amd64.deb ...
正在解压 libdbi-perl:amd64 (1.643-1ubuntu0.1) ...
正在选中未选择的软件包 libdbd-mysql-perl:amd64。
准备解压 .../libdbd-mysql-perl_4.050-3_amd64.deb ...
正在解压 libdbd-mysql-perl:amd64 (4.050-3) ...
正在选中未选择的软件包 libterm-readkey-perl。
准备解压 .../libterm-readkey-perl_2.38-1build1_amd64.deb ...
正在解压 libterm-readkey-perl (2.38-1build1) ...
正在选中未选择的软件包 percona-toolkit。
准备解压 .../percona-toolkit_3.1+dfsg-1.1_all.deb ...
正在解压 percona-toolkit (3.1+dfsg-1.1) ...
正在设置 libterm-readkey-perl (2.38-1build1) ...
正在设置 libdbi-perl:amd64 (1.643-1ubuntu0.1) ...
正在设置 libdbd-mysql-perl:amd64 (4.050-3) ...
正在设置 percona-toolkit (3.1+dfsg-1.1) ...
正在处理用于 man-db (2.9.1-1) 的触发器 ...
(2)、安装pt-summary
xxx$ pt-summary
# Percona Toolkit System Summary Report ######################
Date | 2022-05-11 03:41:24 UTC (local TZ: CST +0800)
Hostname | zgq-OptiPlex-5070
Uptime | 11 days, 16:38, 1 user, load average: 1.11, 0.93, 0.76
Platform | Linux
Release | Ubuntu 20.04 LTS (focal)
Kernel | 5.13.0-40-generic
Architecture | CPU = 64-bit, OS = 64-bit
Threading | NPTL 2.31
SELinux | No SELinux detected
Virtualized | QEmu
# Processor ##################################################
Processors | physical = 1, cores = 8, virtual = 8, hyperthreading = no
Speeds | 1x1214.679, 6x3000.000, 1x800.045
Models | 8xIntel(R) Core(TM) i7-9700 CPU @ 3.00GHz
Caches | 8x12288 KB
# Memory #####################################################
/usr/bin/pt-summary: 1443: arithmetic expression: expecting primary: " + "
Total | 1.00
Free | 1.00
Used | physical = 1.00, swap allocated = 1.00, swap used = 1.00, virtual =
Shared | 1.00
Buffers | 1.00
Caches | 1.00
Dirty | 50552 kB
UsedRSS | 9.3G
Swappiness | 60
DirtyPolicy | 20, 10
DirtyStatus | 0, 0
Locator Size Speed Form Factor Type Type Detail
========= ======== ================= ============= ============= ===========
........
........
........
# Simplified and fuzzy rounded vmstat (wait please) ##########
procs ---swap-- -----io---- ---system---- --------cpu--------
r b si so bi bo ir cs us sy il wa st
1 0 0 1 175 80 0 2 2 1 96 0 0
1 0 0 0 150 350 3500 7000 8 3 89 0 0
0 0 0 0 0 0 3000 6000 6 1 93 0 0
0 0 0 0 0 0 3000 5000 5 1 94 0 0
0 0 0 0 0 0 3000 6000 6 1 93 0 0
# Memory mamagement ##########################################
Transparent huge pages are enabled.
# The End ####################################################
查看pt-quey-digest的版本:
$ pt-query-digest --version
pt-query-digest 3.1.0
安装成功,然后使用该命令分析MySQL的慢查询日志:
例如:
pt-query-digest /home/ddd/slow_query/slow3306_small.log
|