pt-osc 文档使用说明

2024-05-04 01:18
文章标签 文档 使用 说明 pt osc

本文主要是介绍pt-osc 文档使用说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

pt-osc 文档使用说明

  • pt-osc 文档使用说明
      • 功能介绍:
      • 工作原理:
      • 用法介绍
      • 举例

功能介绍:

在 alter 操作更改表结构的时候不⽤锁表,也就是说执⾏ alter 的时候不会阻塞
读写的操作

工作原理:

创建一个你要执alter操作的表⼀样的空表结构,执行表结构的修改,然后从
原表中 COPY 原始数据到表结构修改后的表,当数据 copy 完成以后就会将原表移
走,用新表代替原表, 默认动作是将原表删除。在 copy 数据的过程中,任何在原
表的更新操作都会更新到新表,因为这个⼯具会在原表上创建触发器,触发器会将
元彪上更新的内容更新到新表中。如果表中已经定义了触发器这个⼯具不能工作了。

用法介绍

pt-online-schema-change [OPTIONS] DSN 
主要介绍常⽤参
数必带参数,其他参数可自动options 可以自行查看help
1、 DNS: 为你要操作的数据库和表
2、 –dry-run: 这个参数不建⽴触发器,不拷贝数据,也不会替换原表,只是创建和
更改新表。
3、 –execute:会创建筹触发器,来保证最新的变更数据会影响到新表。 注意:如
果不加这个参数,这个⼯具在执⾏会再制造一些检查后退出。这一举措是为了充分
分析这个工具原理。
4、 –max-log:默认为 1s 每个 chunks 拷⻉完成后,会查看 check-slave-log 参
数所指定的从库的延迟信息,如果超过了 max-log 的阀值则暂停复制数据,直到复制延迟⼩于 max-log 的阀值。检查复制延迟信息依赖于 show slave status 返回中
的 seconds_behind_master 列的值
5、 check-interval:当出现复制延迟暂停复制数据后,按照 check-interval 指定时间周期来检查复
制延迟,直至延迟时间低于 max-log 阀值然后进⾏拷⻉数据。
6、 –check_size: 用于每次控制每次拷呗数据的大小,默认 1000
7、 –chunk_time: 默认 0.5 动态调整块的⼤⼩以便每个数据副本花费很长时间执
行。该工作跟踪复制速度,并在每个数据副本查询之后调整块的大小,所以是由于
服务的负载情况来进⾏动态调整。 [将此参数设置为 0,或者指定 chunk-size,都可
以禁止动态调整]
8、 chunk_size_limit:默认值 4.0; 当需要复制的块大于设置的 chunk_size 大小,就不复制
9、 –critical-load: default thread_runing = 50
该参数在 copy 每个块后检查 show global status,如果负载过⾼则终⽌,如果
不给出, 则⼯具检查启动当前值来确定阀值。
10、 –max-load: default threads_running=25
该参数用于拷贝数据每个数据块的时候进⾏检查 show global status,如果任何
状态变量高于阀值会暂停,如果不设置,该⼯具会在检测到的当前值上再加 20%来
确定阀值(方式 Threads_connected:100 或者 Thread_connected:110)该选项
主要目的是为了防⽌给服务器添加太多的负载,导致锁等待以及其他干扰⾏为。
12、 –[no]drop-new-table
13、 –[no]drop-old-table
默认为 YES,如果复制失败后,删除新表。注意: 执⾏该参数需指定—
nodrop-new-table 复制的新表很⼤, 新的数据都会缓存在 buffer pool 内。
Mysql 在删除表的过程中 innodb 会将⽂件在 buffer pool 中对应的⻚⾯清
楚。如果这设置 buffer pool 的值过大的话,或者 buffer pool 里面有很
多需要被 flush 的页面, 那么此时要遍历扫描页面就会占用笔较大的时间,
导致其他事物在⽤到 buffer pool 实例时就会阻塞,从⽽影响到整个数据

举例

pt-online-schema-change
–execute
–no-version-check
–charset=utf8
–user=admin
–nodrop-old-table
–nodrop-new-table
–max-load Threads_running=50 –critical-load Threads_running=100#
把限制增⼤⼀倍。 需要根据机器负载情况来调整
–alter “add column foo int(11) default null” D=test,t=t1,h=127.0.0.1
注意:以下参数是⽤于复制延迟的参数,具体解释参考⽂档,需要适当调整。
check_interval
chunk_size
chunk_size_limit
chunk_time

这篇关于pt-osc 文档使用说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/958051

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W