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在迁移数据后执行删除操作,建议先备份好。
相关推荐
树谷-胡老师10 分钟前
公元前3400年至公元2024年全球国家地理边界演变数据集
数据库·arcgis·信息可视化
疯狂的Alex11 分钟前
2010-2022 同等学力申硕国考:软件工程简答题真题汇总
数据库·oracle·软件工程
Qlittleboy16 分钟前
tp5的tbmember表闭包查询 openid=‘abc‘ 并且(wx_unionid=null或者wx_unionid=‘‘)
数据库·sql·php
躲在云朵里`1 小时前
Spring Scheduler定时任务实战:从零掌握任务调度
java·数据库·mybatis
小白不想白a1 小时前
【MySQL】常用SQL语句
数据库·sql·mysql
RestCloud1 小时前
从MySQL到StarRocks:全量与增量同步的最佳实践
数据库·mysql·api
Databend1 小时前
Databend 八月月报:向量检索重磅上线,性能飞跃几十倍
数据库
路弥行至2 小时前
从0°到180°,STM32玩转MG996R舵机
c语言·数据库·stm32·单片机·嵌入式硬件·mcu·mongodb
软测进阶2 小时前
【超详细图文教程】2025年最新Win10 系统安装 MySQL 教程
数据库·mysql
Anthony_2312 小时前
MySQL的常用命令
运维·数据库·mysql·adb·docker