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在迁移数据后执行删除操作,建议先备份好。
相关推荐
x***r1519 分钟前
dbeaver-ce-24.1.3-x86_64-setup安装步骤详解(附DBeaver数据库管理与SQL编写教程)
数据库·sql
一只鹿鹿鹿11 分钟前
数据库运维与管理规范(WORD)
运维·数据库
todoitbo1 小时前
WHERE 子句中的函数执行顺序与副作用风险分析
数据库·时序数据库·函数
jiayong231 小时前
MySQL 8.0 Root 用户远程登录配置完整指南
数据库·mysql
数智化管理手记1 小时前
设备总停机?找准根源+TPM核心逻辑,筑牢零故障基础
数据库·人工智能·低代码·制造
zhangshuang-peta1 小时前
MCP + OpenClaw:执行框架如何被“约束成系统”
数据库·人工智能·ai·ai agent·mcp·peta
java1234_小锋2 小时前
说一下Spring的事务传播行为?
java·数据库·spring
苏三说技术2 小时前
美团二面:高并发下如何保证接口幂等性?
java·数据库
精益数智小屋2 小时前
设备维护方案核心功能拆解:一套好的设备维护方案如何解决设备突发故障
大数据·运维·网络·数据库·人工智能·面试·自动化
phltxy2 小时前
Redis 常见数据类型之全局通用命令详解
数据库·redis·bootstrap