zoukankan      html  css  js  c++  java
  • pt-online-schema-change使用详解

    一、pt-online介绍

    pt-online-schema-change是percona公司开发的一个工具,在percona-toolkit包里面可以找到这个功能,它可以在线修改表结构

    原理:

    • 首先它会新建一张一模一样的表,表名一般是_new后缀

    • 然后在这个新表执行更改字段操作

    • 然后在原表上加三个触发器,DELETE/UPDATE/INSERT,将原表中要执行的语句也在新表中执行

    • 最后将原表的数据拷贝到新表中,然后替换掉原表

    使用pt-online-schema-change执行SQL的日志 SQL语句:

    ALTER TABLE `tmp_task_user` ADD support tinyint(1) unsigned NOT NULL DEFAULT '1';
    ​
    sh pt.sh tmp_task_user "ADD COLUMN support tinyint(1) unsigned NOT NULL DEFAULT '1'"

    日志输出:

    tmp_task_user
    ADD COLUMN support tinyint(1) unsigned NOT NULL DEFAULT '1'
    No slaves found.  See --recursion-method if host h=127.0.0.1,P=3306 has slaves.
    Not checking slave lag because no slaves were found and --check-slave-lag was not specified.
    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 `test_db`.`tmp_task_user`...
    Creating new table...
    Created new table test_db._tmp_task_user_new OK.
    Altering new table...
    Altered `test_db`.`_tmp_task_user_new` OK.
    2018-05-14T18:14:21 Creating triggers...
    2018-05-14T18:14:21 Created triggers OK.
    2018-05-14T18:14:21 Copying approximately 6 rows...
    2018-05-14T18:14:21 Copied rows OK.
    2018-05-14T18:14:21 Analyzing new table...
    2018-05-14T18:14:21 Swapping tables...
    2018-05-14T18:14:21 Swapped original and new tables OK.
    2018-05-14T18:14:21 Dropping old table...
    2018-05-14T18:14:21 Dropped old table `test_db`.`_tmp_task_user_old` OK.
    2018-05-14T18:14:21 Dropping triggers...
    2018-05-14T18:14:21 Dropped triggers OK.
    Successfully altered `test_db`.`tmp_task_user`.

    好处:

    • 降低主从延时的风险

    • 可以限速、限资源,避免操作时MySQL负载过高

    建议:

    • 在业务低峰期做,将影响降到最低

    二、pt-online安装

    1.去官网下载对应的版本,官网下载地址:https://www.percona.com/downl...

    2.下载解压之后就可以看到pt-online-schema-change

    3.该工具需要一些依赖包,直接执行不成功时一般会有提示,这里可以提前yum安装

    yum install perl-DBI
    yum install perl-DBD-MySQL
    yum install perl-Time-HiRes
    yum install perl-IO-Socket-SSL

     

    三、pt-online-schema-change使用

    1.参数 ./bin/pt-online-schema-change --help 可以查看参数的使用,我们只是要修改个表结构,只需要知道几个简单的参数就可以了

    --user=        连接mysql的用户名
    --password=   连接mysql的密码
    --host=       连接mysql的地址
    P=3306         连接mysql的端口号
    D=             连接mysql的库名
    t=             连接mysql的表名
    --alter       修改表结构的语句
    --execute     执行修改表结构
    --charset=utf8 使用utf8编码,避免中文乱码
    --no-version-check 不检查版本,在阿里云服务器中一般加入此参数,否则会报错

    2.为避免每次都要输入一堆参数,写个脚本复用一下,pt.sh

    #!/bin/bash
    table=$1
    alter_conment=$2
    ​
    cnn_host='127.0.0.1'
    cnn_user='user'
    cnn_pwd='password'
    cnn_db='database_name'echo "$table"
    echo "$alter_conment"
    /root/percona-toolkit-2.2.19/bin/pt-online-schema-change --charset=utf8 --no-version-check --user=${cnn_user} --password=${cnn_pwd} --host=${cnn_host}  P=3306,D=${cnn_db},t=$table --alter 
    "${alter_conment}" --execute

    3.添加表字段 如添加表字段SQL语句为:

    ALTER TABLE `tb_test` ADD COLUMN `column1` tinyint(4) DEFAULT NULL;

     

    那么使用pt-online-schema-change则可以这样写

    sh pt.sh tb_test "ADD COLUMN column1 tinyint(4) DEFAULT NULL"

     

    4.修改表字段 SQL语句:

    ALTER TABLE `tb_test` MODIFY COLUMN `num` int(11) unsigned NOT NULL DEFAULT '0';

    pt-online-schema-change工具:

    sh pt.sh tb_test "MODIFY COLUMN num int(11) unsigned NOT NULL DEFAULT '0'"

    5.修改表字段名 SQL语句:

    ALTER TABLE `tb_test` CHANGE COLUMN age adress varchar(30);

     

    pt-online-schema-change工具:

    sh pt.sh tb_test "CHANGE COLUMN age address varchar(30)"

    6.添加索引 SQL语句:

    ALTER TABLE `tb_test` ADD INDEX idx_address(address);

    pt-online-schema-change工具:

    sh pt.sh tb_test "ADD INDEX idx_address(address)"

     

    四、其他

    • pt-online-schema-change工具还有很多其他的参数,可以有很多限制,比如限制CPU、线程数量、从库状态等等,不过我做过一个超过6000W表的结构修改,发现几乎不影响性能,很稳定很流畅的就修改了表结构,所以,对以上常规参数的使用基本能满足业务

    • 一定要在业务低峰期做,这样才能确保万无一失

  • 相关阅读:
    SOJ 2785_Binary Partitions
    Codeforces Round #328 (Div. 2)
    C++ fill 和memset
    SOJ 2749_The Fewest Coins
    Codeforces Round #327 (Div. 2)
    TYVJ P1013 找啊找啊找GF Label:动态规划
    TYVJ 1014 乘法游戏
    TYVJ 1011 NOIP 2008&&NOIP 2000 传纸条&&方格取数 Label:多线程dp
    错误集合
    TYVJ P1038/P1039 忠诚 标签:线段树
  • 原文地址:https://www.cnblogs.com/lkj371/p/11430265.html
Copyright © 2011-2022 走看看