CentOS7上pt-archiver工具进行数据库表归档——筑梦之路

pt-archiver 是一个用于 MySQL 数据归档和清理的强大工具。它可以将旧数据从原表移动到归档表,同时保持原表的性能不受影响。

前提条件

表有做分区或者有时间字段

在线安装

bash 复制代码
sudo yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm
sudo yum install percona-toolkit

创建归档表

bash 复制代码
# 原始表test_table  归档表test_table_archive

CREATE TABLE test_table_archive LIKE test_table;

# 这里创建一个结构和原始表一样的归档表,时间字段为create_ts

使用 pt-archiver 进行归档

bash 复制代码
可以归档到同一个库其他表,归档到文件里--file,归档到不同实例下的表

此处归档到同一个库的其他表

pt-archiver \
  --source h=192.168.200.157,P=3306,u=dba,D=test,t=test_table,p=***** \
  --charset=utf8mb4 \
  --dest h=192.168.200.157,P=3306,u=dba,D=test,t=test_table_archive,p=***** \
  --where "TO_DAYS(NOW()) - (TO_DAYS(create_ts)) > 90" \
  --progress=5000 \
  --txn-size=1000 \
  --purge

#############################

--source 参数指定了原始表的位置和连接信息。

h: 源数据库主机名或IP地址(这里是192.168.200.157)

P: 源数据库端口号(这里是3306)

u: 连接源数据库使用的用户名(这里是dba)

D: 源数据库名称(这里是test)

t: 要迁移数据的表名(这里是test_table)

p: 密码(这里以星号隐藏,实际操作时应替换为真实的密码)。


--dest 参数指定了归档表的位置,具体字参数和source类似。

--where 参数是一个 SQL 表达式,用于筛选需要归档的数据。在这个例子中,"TO_DAYS(NOW()) - (TO_DAYS(create_ts)) > 90" 当前日期减去create_ts字段(假设它表示数据创建时间)的天数大于90天的记录。只迁移超过90天的老数据。

--limit 参数指定了每次事务处理的数据行数。

--progress 参数用于每处理一定数量的行时打印进度信息。

--txn-size 参数定义了事务的大小,即每次提交的行数。

--no-delete 仅迁移数据,而不从源表中删除已迁移的记录

--purge 参数告诉pt-archiver在迁移数据后执行删除操作,建议先备份好。
相关推荐
可喜~可乐13 分钟前
C# SQLite高级功能示例
数据库·sql·sqlite·c#
cooldream20091 小时前
深入理解主从数据库架构与主从复制
数据库·oracle·数据库架构·系统架构师
Eternity......1 小时前
spark MySQL数据库配置
数据库·mysql·spark
Freedom℡1 小时前
使用scp命令拷贝hadoop100中文件到其他虚拟机中
数据库·hadoop·spark
Qdgr_1 小时前
电厂除灰系统优化:时序数据库如何降低粉尘排放
数据库·时序数据库
慧一居士2 小时前
Memcached 服务搭建和集成使用的详细步骤示例
数据库·架构·nosql·memcached
脑子慢且灵2 小时前
MySQL:关系模型的基本理论
数据库·sql·mysql
码农飞哥2 小时前
互联网大厂Java求职面试实战:Spring Boot与微服务场景深度解析
java·数据库·spring boot·安全·微服务·消息队列·互联网医疗
Ai 编码助手2 小时前
可视化+智能补全:用Database Tool重塑数据库工作流
数据库
敲上瘾2 小时前
MySQL基本查询
数据库·mysql·数据库开发·数据库架构·数据库系统