我是靠谱客的博主 小巧小懒猪,最近开发中收集的这篇文章主要介绍pt-online-schema-change,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

pt-online-schema-change 是什么?

pt-online-schema-change是Percona工具包的一员,用于修改表而不会造成读锁或者写锁;

pt-online-schema-change详细描述:

pt-online-schema-change工作在一个副本上,所以原表没有被lock,client可以继续进行read和write操作;pt-online-schema-change会创建一个空表,然后根据需要对空表进行modify,之后将原表数据复制到新表,复制完成后就用RENAME将新表替换原表,完成后 drop 原表;

pt-online-schema-change修改以块为单位,修改中根据情况自行调整块大小(类似checksum) 

为了安全,如果没执行--execute,则不会发生修改;工具会有多种措施,防止不必要的负载,如:

1, 多数情况下,如果没有PRIMARY KEY或者UNIQUE KEY,则拒绝操作(--alter)

2, 如果检测到replication filters,则拒绝操作(--[no]check-replication-filters)

3, 如果有较大的延时,则暂停操作("--max-lag")

4, 如果有较大的负载则暂停或放弃操作("--max-load" and "--critical-load)

5, 工具会设置自己会话的锁超时时间"innodb_lock_wait_timeout=1"lock_wait_timeout=60,所以会更少 地影响其他事物(修改时间"--set-vars")

6, 默认如果有外键约束则拒绝修改(忽略约束"--alter-foreign-keys-method")

7, 不支持Percona XtraDB Cluster(Percona高可用解决方案)

工具会忽略mysql 5.7+版本的"GENERATED"列,因为它根据表达式计算列值

输出信息:

    复制表的时候会显示进度, 如果要显示额外信息,则--print, 如果指定--statistics 最后会显示计数信息

选项OPTIONS

--alter

     不需要加alter table关键字,如pt-online-schema-change  --alter "ADD COLUMN c2 INT" D=apple,t=a 

     限制: 

     1, 必须要有PRIMARY KEY或者UNIQUE KEY,因为它会在程序进行的时候创建DELETE 触发器,来保证新表跟着老表一起更新;

     2, RENAME不会被采用去RENAME TABLE

     3, 如果增加列的时候指定NOT NULL,并且未提供默认值,则失败;

     4, 如果要删除外键,需要指定 "_constraint_name"而不是 "constraint_name"

     5, 如果要将MYISAM表修改为Innodb会报错

--[no]analyze-before-swap  当新表与原表交换的前执行analyze table;

--ask-pass 连接的时候会要求提供密码

--charset 默认字符集

--[no]check-alter   对于危险的操作会产生告警,如删除主键或者重命名列;

--check-interval   当主从延时为--max-lag 秒的时候,检查sleep的时间;例如设置为10的时候,主从延时产生,则暂停10秒,再检查延时,如果依然有有延时,停止10s再检查; 默认1s

--[no]check-plan   是否在执行前用EXPLAIN检查语句

--[no]check-replication-filters  是否检查过滤器,如果有任何过滤器的时候,操作都会被放弃;(如:binlog_ignore_db  replicate_do_db)

--check-slave-lag  如果slave的时间戳低于"--max-lag"的时候则暂停操作

--chunk-index  指定chunk的索引,工具默认会选择最合适的索引,当然你也可以手动指定

--chunk-index-columns 有复合索引的时候,指定索引列

--chunk-size   chunk的行数,默认1000

 --chunk-size-limit   默认4,chunk超过应有值的4倍大小则跳过。如果没有唯一索引,则chunk 大小是不精确的,工具会用EXPLAIN评估大小,如果超过需要chunk大小的n倍,则跳过该chunk;

--chunk-time 默认0.5, 工具会根据每次复制数据花费的时间自动调整chunk大小,尽可能使每次时间都相同;=0则不调节

--config  读取配置文件,多个文件逗号分隔;如果指定则必须是第一个参数

--critical-load  默认Threads_running=50;  每次chunk执行后会自动用SHOW GLOBAL STATUS检查负载情况,如果超过阈值则放弃;

--database -D 指定库

--default-engine 该选项将导致新表使用系统默认引擎;   而不是原有表一致的引擎

--data-dir  v 5.6+ 在不同的分区上创建新表

--remove-data-dir 如果原表已通过--data-dir 创建,该参数会删除它并在默认datadir下创建新表

--defaults-file   从文件中读取选项

 --[no]drop-new-table 如果复制原表失败则删除新表; 也可以no-xxx来保留新表

 --[no]drop-old-table  rename新表后drop旧表,可以no-xxx来保留旧表

--[no]drop-triggers  删除旧表的触发器;"--no-drop-triggers" forces "--no-drop-old-table".

--dry-run 创建并修改新表,但不创建触发器,也不复制表,或者替换原表,与--execute互斥

--execute 执行操作 与 --dry-run互斥

--[no]check-unique-key-change  如果--alter尝试增加唯一索引的的话,则工具不会运行; 因为增加唯一索引如果列有重复值,会发生丢失数据的情况;因为INSERT的时候默认采用"INSERT IGNORE"

--force  强制运行,可能打破外键约束

--help 帮助
--host | -h  指定host

--max-lag 默认1s, 如果主从延时的时间超过这个值,则复制会暂停"--check-interval"秒时间;然后再检查,直到主从延时小于该值;如果指定了 "--check-slave-lag",则只会检查指定slave延时,而不是检查所有slave;如果有任何SLAVE stop了,那么工具会一直等待下去;每次停止的时候都会打印报告

--max-load 默认 : Threads_running=25 

        每次复制chunk后检查负载,如果超过该值则暂停;类似--critical-load

--preserve-triggers     保留原表的触发器,不删除

--new-table-name   指定新表的名字,默认是 tablename_new

--null-to-not-null  修改允许null值为not null

--password 指定密码

--pause-file 改参数指定的文件存在的时,操作将会暂停

--pid 新建pid文件

--port 指定连接端口

--print  将会显示工具执行的命令

--progress 显示进度,默认:  time,30

       两部分组成,第一部分percentage,time或者iterations;  第二部分多久更新一次

--quiet    -q

  不打印消息到屏幕; 禁用--progress,  ERROR和告警还是会打印

--recurse   

    当发现有slave的时候,指定递归的层数 , int值

--recursion-method     查找Slave的递归方法

                METHOD       USES
             ===========  ==================
             processlist  SHOW PROCESSLIST
             hosts        SHOW SLAVE HOSTS
             dsn=DSN      DSNs from a table
             none         Do not find slaves  

--skip-check-slave-lag  检查SLAVE的时候,指定该SLAVE跳过;

--slave-user    设置连接slave的用户;可以指定用更少权限的用户连接SLAVE,但是所有slave都必须有该账户

--slave-password    --slave-user 的密码

--set-vars  默认:

              wait_timeout=10000
              innodb_lock_wait_timeout=1
              lock_wait_timeout=60

--sleep  复制每个chunk的时候暂停多少s,默认0

--socket 指定连接socket

--statistics   打印计数器的数据,当有告警的时候这个参数比较有用

-[no]swap-tables  指定是否替换旧表

--tries  重试次数;

--user 连接用户名

--version  版本

--[no]version-check 检查Percona Toolkit的最新版本

[root@localhost tmp]# pt-online-schema-change
--alter "ADD COLUMN c3 INT" D=apple,t=a -u root -h localhost -p password --execute
No slaves found.
See --recursion-method if host localhost.localdomain has slaves.
Not checking slave lag because no slaves were found and --check-slave-lag was not specified.
# A software update is available:
Operation, tries, wait:
analyze_table, 10, 1
copy_rows, 10, 0.25
create_triggers, 10, 1
drop_triggers, 10, 1
swap_tables, 10, 1
update_foreign_keys, 10, 1
Altering `apple`.`a`...
Creating new table...
Created new table apple._a_new OK.
Altering new table...
Altered `apple`.`_a_new` OK.
2018-09-05T12:57:33 Creating triggers...
2018-09-05T12:57:33 Created triggers OK.
2018-09-05T12:57:33 Copying approximately 2 rows...
2018-09-05T12:57:33 Copied rows OK.
2018-09-05T12:57:33 Analyzing new table...
2018-09-05T12:57:33 Swapping tables...
2018-09-05T12:57:34 Swapped original and new tables OK.
2018-09-05T12:57:34 Dropping old table...
2018-09-05T12:57:34 Dropped old table `apple`.`_a_old` OK.
2018-09-05T12:57:34 Dropping triggers...
2018-09-05T12:57:34 Dropped triggers OK.
Successfully altered `apple`.`a`.

 

最后

以上就是小巧小懒猪为你收集整理的pt-online-schema-change的全部内容,希望文章能够帮你解决pt-online-schema-change所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部