Percona Toolkit 神器全攻略(配置类)
Percona Toolkit 神器全攻略系列共八篇,前文回顾:
前文回顾Percona Toolkit 神器全攻略Percona Toolkit 神器全攻略(实用类)全文约定:$为下令提示符、greatsql>为GreatSQL数据库提示符。在后续阅读中,依据此约定进行理解与操纵
配置类
在Percona Toolkit中配置类共有以下工具
- pt-config-diff:比较数据库配置文件和参数
- pt-mysql-summary:对GreatSQL/MySQL配置和status进行汇总
- pt-variable-advisor:分析参数,并提出建议
pt-config-diff
概要
比较 GreatSQL/MySQL 配置文件和服务器变量
用法
- pt-config-diff [OPTIONS] CONFIG CONFIG [CONFIG...]
选项
该工具所有选项如下
参数含义--ask-pass毗连 GreatSQL/MySQL 时提示输入密码--charset字符集--config读取这个逗号分隔的配置文件列表,如果指定,这必须是下令行上的第一个选项--database毗连到该数据库--defaults-file只从给定文件中读取 GreatSQL/MySQL 选项--help显示帮助--host毗连到主机--[no]ignore-case比较变量时不区分巨细写--ignore-variables忽略、不比较这些变量--password用于毗连的密码--pid创建给定的 PID 文件--port用于毗连的端口号--[no]report将 GreatSQL/MySQL 配置差异报告打印到 STDOUT--report-width将报告行截断为设定的字符--set-vars在这个以逗号分隔的 variable=value 对列表中设置 GreatSQL/MySQL 变量--socket用于毗连的套接字文件--user登录的用户--version显示版本--[no]version-check版本检查最佳实践
首先创建两个配置文件(这里为了示范方便配置文件内容较少)- # 以下创建test_my_1.cnf配置文件
- $ vim test_my_1.cnf
- [client]
- socket = /data/GreatSQL/mysql.sock
- [mysql]
- loose-skip-binary-as-hex
- no-auto-rehash
- [mysqld]
- user = mysql
- port = 3306
- server_id = 3306
- innodb_buffer_pool_size = 16G
- loose-group_replication_group_seeds = '172.16.16.10:33061,172.16.16.12:33061,172.16.16.12:33061'
- loose-group_replication_group_name = "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa1"
- # 以下创建test_my_2.cnf配置文件
- $ vim test_my_2.cnf
- [client]
- socket = /data/greatsql/greatsql.sock
- [mysql]
- loose-skip-binary-as-hex
- no-auto-rehash
- [mysqld]
- user = greatsql
- port = 3308
- server_id = 3308
- innodb_buffer_pool_size = 8G
- loose-group_replication_group_seeds = '172.16.10:33081,172.16.10:33081,172.16.10:33081'
- loose-group_replication_group_name = "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaab1"
复制代码因为在配置MGR的时间,需要集群中的my.cnf部分配置同等,以是这个配置文件对比还是很有效处的
配置文件对比
不同等才会输出,如果完全同等不会输出- $ pt-config-diff /data/test_my_1.cnf /data/test_my_2.cnf
- 6 config differences
- Variable /data/test_my_1.cnf /data/test_my_2.cnf
- ========================= ========================= =========================
- innodb_buffer_pool_size 17179869184 8589934592
- loose_group_replicatio... aaaaaaaa-aaaa-aaaa-aaa... aaaaaaaa-aaaa-aaaa-aaa...
- loose_group_replicatio... 172.16.16.10:33061,172... 172.16.10:33081,172.16...
- port 3306 3308
- server_id 3306 3308
- user mysql greatsql
复制代码 但是上面的输出不够完整,有的输出被省略,此时可以加上--report-width 200,便可完整输出- $ pt-config-diff /data/test_my_1.cnf /data/test_my_2.cnf --report-width 200
- 6 config differences
- Variable /data/test_my_1.cnf /data/test_my_2.cnf
- ========================== ======================================================== ===============================================
- innodb_buffer_pool_size 17179869184 8589934592
- loose_group_replication... aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa1 aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaab1
- loose_group_replication... 172.16.16.10:33061,172.16.16.12:33061,172.16.16.12:33061 172.16.10:33081,172.16.10:33081,172.16.10:33081
- port 3306 3308
- server_id 3306 3308
- user mysql greatsql
复制代码 配置文件和体系变量对比
配置文件与本机GreatSQL体系变量对比,如果完全同等,则不输出- $ pt-config-diff --report-width=200 /etc/my.cnf u=root,p=
- 1 config difference
- Variable /etc/my.cnf myarch
- ========================= =========== ================================
- slow_query_log_file slow.log /data/GreatSQL/myarch.log.000001
复制代码 体系变量之间的对比
两台差别的数据库实例之间的体系变量对比- $ pt-config-diff --report-width=200 h=192.168.6.55,P=3306,u=GreatSQL,p= h=192.168.6.129,P=3306,u=test,p='test'
- 104 config differences
- Variable myarch hy
- ========================== ==================================================================== ====================================================================
- admin_tls_version TLSv1.2,TLSv1.3 TLSv1.2
- back_log 1024 151
- basedir /usr/local/GreatSQL-8.0.32-25-Linux-glibc2.28-x86_64/ /usr/local/GreatSQL-8.0.32-25-Linux-glibc2.17-x86_64/
- binlog_cache_size 4194304 32768
- binlog_expire_logs_seconds 604800 2592000
- binlog_rows_query_log_e... ON OFF
- ......下方省略
复制代码 pt-mysql-summary
概要
打印出来GreatSQL/MySQL的描述信息,包括:版本信息,数据目次,下令的统计,用户,数据库以及复制等信息还包括各个变量(status、variables)信息和各个变量的比例信息,还有配置文件等信息。
用法
- pt-mysql-summary [OPTIONS]
选项
该工具所有选项如下
参数含义--all-databasesmysqldump 并汇总所有数据库--ask-pass毗连 GreatSQL/MySQL 时提示输入密码--config读取这个逗号分隔的配置文件列表,如果指定,这必须是下令行上的第一个选项--databasesmysqldump 并总结这个以逗号分隔的数据库列表。如果要转储和汇总所有数据库,请指定 --all-databases--defaults-file只从给定文件中读取 GreatSQL/MySQL 选项--help显示帮助--host要毗连的主机--list-encrypted-tables包括所有数据库中加密表的列表。这大概会导致速度变慢,因为查询信息模式表大概会很慢。--password毗连时使用的密码--port用于毗连的端口号--read-samples从此目次中找到的文件创建报告--save-samples将用于天生摘要的数据文件保存在此目次中--sleep网络状态计数器时休眠的秒数--socket用于毗连的套接字文件--user登录的用户--version显示版本最佳实践
- $ pt-mysql-summary --user=root --password=greatsql --host=localhost --port=3306
复制代码此时会输出所有关于GreatSQL的信息,但是要注意许多输出都是做了四舍五入,并不是精确的数据
不建议此工具远程毗连其它数据库,因为大概导致输出数据混乱
接下来将此工具输出结果分成各个模块介绍- # Percona Toolkit MySQL Summary Report #######################
- System time | 2024-03-14 08:19:45 UTC (local TZ: CST +0800)
- # Instances ##################################################
- Port Data Directory Nice OOM Socket
- ===== ========================== ==== === ======
- # MySQL Executable ###########################################
- Path to executable | /usr/local/GreatSQL-8.0.32-25-Linux-glibc2.28-x86_64/bin/mysqld
- Has symbols | Yes
- # Slave Hosts ################################################
- No slaves found
复制代码 这四个部分显示报告是在哪台服务器上天生的以及该服务器上正在运行哪些 GreatSQL 实例,这是从 ps 的输出中检测到的,并不总是检测所有实例和参数。- # Report On Port 3306 ########################################
- User | root@localhost
- Time | 2024-03-14 16:19:45 (+08:00)
- Hostname | myarch
- Version | 8.0.32-25 GreatSQL, Release 25, Revision 79f57097e3f
- Built On | Linux x86_64
- Started | 2024-03-08 09:50 (up 6+06:29:24)
- Databases | 9
- Datadir | /data/GreatSQL/
- Processes | 2 connected, 2 running
- Replication | Is not a slave, has 0 slaves connected
- Pidfile | mysql.pid (does not exist)
复制代码 本节是 GreatSQL 实例的快速摘要:版本、正常运行时间和其他非常基本的参数。时间输出是从 GreatSQL 服务器天生的,大概与之前打印的体系日期和时间差别,如果差别的话可以检查下数据库和操纵体系的时间是否匹配- # Processlist ################################################
- Command COUNT(*) Working SUM(Time) MAX(Time)
- ------------------------------ -------- ------- --------- ---------
- Daemon 1 1 500000 500000
- Query 1 1 0 0
- Sleep 1 0 450 450
- ......中间省略
- State COUNT(*) Working SUM(Time) MAX(Time)
- ------------------------------ -------- ------- --------- ---------
- 1 0 0 0
- init 1 1 0 0
- Waiting on empty queue 1 1 500000 500000
复制代码 本节是 SHOW PROCESSLIST 输出的摘要,这里的数字会四舍五入,不是最精确的- # Status Counters (Wait 10 Seconds) ##########################
- Variable Per day Per second 10 secs
- Aborted_clients 10
- Aborted_connects 2
- Binlog_snapshot_position 100
- .......中间省略
- Table_open_cache_overflows 30
- Threadpool_idle_threads 2
- Threadpool_threads 2
- Threads_created 25
- Uptime 90000 1 1
复制代码 此部分显示从 SHOW GLOBAL STATUS 的两个快照中选择的计数器,这些快照间隔约莫 10 秒网络并进行模糊舍入。
- 第一列是变量名称。
- 第二列是第一个快照的计数器除以 86400(一天的秒数),因此您可以看到计数器每天的变化幅度。 86400 次模糊轮换到 90000,因此正常运行时间计数器应始终约为 90000。
- 第三列是第一个快照的值,除以正常运行时间,然后进行模糊舍入,因此它大致表示计数器在服务器正常运行时间内每秒增长的速度。
- 第四列是第一个和第二个快照的增量差异,除以正常运行时间的差异,然后进行模糊舍入。因此,它显示了天生报告时计数器每秒增长的速度。
- # Table cache ################################################
- Size | 1024
- Usage | 70%
复制代码 此部分显示表缓存的巨细,后面是表缓存的使用百分比。- # Key Percona Server features ################################
- Table & Index Stats | Disabled
- Multiple I/O Threads | Enabled
- Corruption Resilient | Enabled
- Durable Replication | Not Supported
- Import InnoDB Tables | Not Supported
- Fast Server Restarts | Not Supported
- Enhanced Logging | Disabled
- Replica Perf Logging | Enabled
- Response Time Hist. | Not Supported
- Smooth Flushing | Not Supported
- HandlerSocket NoSQL | Not Supported
- Fast Hash UDFs | Unknown
复制代码 本节显示 Percona Server 中可用的特性和启用情况。- # Plugins ####################################################
- InnoDB compression | ACTIVE
复制代码 本节显示特定插件以及它们是否已启用
该工具只检测少数几个Plugin,并不是所有的插件都检测
- # Schema #####################################################
- Specify --databases or --all-databases to dump and summarize schemas
- # 如果没指定--databases or --all-databases 则不会打印
- # Schema #####################################################
- Database Tables Views SPs Trigs Funcs FKs Partn
- mysql 38
- aptest 7
- db2 1
- sys_audit 1
- test_db 11
- tpch 8
- Database InnoDB CSV
- aptest 7
- db2 1
- mysql 2 2
- sys_audit 1
- test_db 11
- tpch 8
- Database BTREE
- aptest 7
- db2 1
- mysql 45
- sys_audit 1
- test_db 19
- tpch 17
-
- # 下方部分输出为了紧凑显示,作者将这些列标题设置为垂直输出
- # 需要您从顶部向下阅读,第一列是 char ,第二列是 timestamp
- c t s i t e v f t b s j b m m t d d d d
- h i e n e n a l i i m s l e e i a o a e
- a m t t x u r o n g a o o d d m t u t c
- r e t m c a y i l n b i i e e b e i
- s h t i n l u u t l m
- t a n t i m m i e a
- a r t n t b m l
- m t e l e
- p x o
- t b
- Database === === === === === === === === === === === === === === === === === === === ===
- aptest 23 1 58 19 9 3 2
- db2 1 1
- mysql 64 10 4 46 31 61 25 5 15 23 6 2 4 2 2 2
- sys_audit 11 1
- test_db 3 2 33 2 29 4 3 1 7 2 5
- tpch 16 19 13 4 9
复制代码 如果您指定 --databases 或 --all-databases ,该工具将打印以上部分
本节显示了数据库中对象的数量和范例,它是通过运行 mysqldump --no-data 天生的,而不是通过查询INFORMATION_SCHEMA天生
本节中的第一个子报告是每个数据库中按范例划分的对象计数:表、视图等。第二个显示每个数据库中有多少表使用差别的存储引擎。第三个子报告显示每个数据库中每种范例索引的数量。
最后一部分显示每个数据库中各种数据范例的列数。为了紧凑显示,列标题的格式是垂直的,因此您需要从顶部向下阅读。在此示例中,第一列是 char ,第二列是 timestamp
这部分输出的数字都是精确的,不是四舍五入的
- # Noteworthy Technologies ####################################
- SSL | No
- Explicit LOCK TABLES | No
- Delayed Insert | No
- XA Transactions | No
- NDB Cluster | No
- Prepared Statements | No
- Prepared statement count | 0
复制代码 此部分显示该服务器上使用的一些特定技术。- # InnoDB #####################################################
- Version | 8.0.32-8.0.32
- Buffer Pool Size | 2.0G
- Buffer Pool Fill | 70%
- Buffer Pool Dirty | 0%
- ......中间省略
- Pending I/O Flushes | 7 buf pool, 0 log
- Transaction States | 3xnot started
复制代码 此部分显示InnoDB 存储引擎的重要配置变量。缓冲池添补百分比和脏百分比是模糊舍入的。最后几行来自 SHOW INNODB STATUS 的输出。- # MyISAM #####################################################
- Key Cache | 32.0M
- Pct Used | 20%
- Unflushed | 0%
复制代码 此部分显示 MyISAM 键缓存的巨细,后面是正在使用的缓存百分比和未刷新百分比(四舍五入)- # Security ###################################################
- Users | 2 users, 0 anon, 0 w/o pw, 2 old pw
- Old Passwords |
复制代码 此部分显示根据对 GreatSQL 体系数据库中的表的查询天生的。它显示了存在多少用户,以及各种潜在的安全风险,例如旧式密码和无密码的用户。- # Binary Logging #############################################
- Binlogs | 8
- Zero-Sized | 0
- Total Size | 10.6G
- binlog_format | ROW
- expire_logs_days | 0
- sync_binlog | 1
- server_id | 3306
- binlog_do_db |
- binlog_ignore_db |
复制代码 此部分显示二进制日记的配置和状态。如果存在巨细为0的二进制日记,则大概是二进制日记索引与磁盘上实际存在的二进制日记差别步。- # Noteworthy Variables #######################################
- Auto-Inc Incr/Offset | 1/1
- default_storage_engine | InnoDB
- flush_time | 0
- init_connect |
- init_file |
- sql_mode |
- ......中间省略
- log_queries_not_using_indexes | ON
- log_slave_updates | ON
复制代码 此部分显示几个值得注意的服务器配置变量,在使用该服务器时了解这些变量大概很重要。- # Configuration File #########################################
- Config File | /etc/my.cnf
复制代码 最后部分显示 my.cnf 文件的精美打印版本,其中删除了解释并添加了空格以对齐内容以便于阅读。
pt-variable-advisor
概要
这是一款分析参数,而且给出参数设置建议的工具
用法
- pt-variable-advisor [OPTIONS] [DSN]
选项
该工具所有选项如下
参数含义--ask-pass毗连 GreatSQL/MySQL 时提示输入密码--charset字符集--config读取这个逗号分隔的配置文件列表,如果指定,这必须是下令行上的第一个选项--daemonize背景运行--database毗连到该数据库--defaults-file只从给定文件中读取 GreatSQL/MySQL 选项--help显示帮助--host要毗连的主机--ignore-rules忽略这些规则 ID--password毗连时使用的密码--pid创建给定的 PID 文件--port毗连时使用的端口号--set-vars在这个以逗号分隔的 variable=value 对列表中设置 GreatSQL/MySQL 变量--socket用于毗连的套接字文件--source-of-variables从此源读取 SHOW VARIABLES--user登录的用户--verbose增长输出的具体程度--version显示版本--[no]version-check版本检查最佳实践
分析本地GreatSQL数据库参数的一些建议- $ pt-variable-advisor localhost
- # WARN delay_key_write: MyISAM index blocks are never flushed until necessary.
- # WARN innodb_log_buffer_size: The InnoDB log buffer size generally should not be set larger than 16MB.
- # NOTE read_buffer_size-1: The read_buffer_size variable should generally be left at its default unless an expert determines it is necessary to change it.
- # NOTE read_rnd_buffer_size-1: The read_rnd_buffer_size variable should generally be left at its default unless an expert determines it is necessary to change it.
- # NOTE sort_buffer_size-1: The sort_buffer_size variable should generally be left at its default unless an expert determines it is necessary to change it.
- # WARN expire_logs_days: Binary logs are enabled, but automatic purging is not enabled.
- # NOTE innodb_data_file_path: Auto-extending InnoDB files can consume a lot of disk space that is very difficult to reclaim later.
- # WARN myisam_recover_options: myisam_recover_options should be set to some value such as BACKUP,FORCE to ensure that table corruption is noticed.
复制代码 当然也可以把SHOW VARIABLES输出的结果保存在pt_va.txt文件中,然后再用工具分析- $ pt-variable-advisor localhost --source-of-variables pt_va.txt
复制代码个人觉得除了非常明显的错误,否则这个建议没有太多的意义。
这里也推荐一个网页版的GreatSQL/MySQL状态诊断工具,由叶老师出品➡https://imysql.com/my-state-diag.html
本文完
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |