需实施冷热数据自动分离:一、用MySQL分区表+事件调度器定时归档旧数据;二、用宝塔计划任务调Shell脚本mysqldump导出后清空;三、用Python等ETL工具将冷数据同步至独立归档库。

如果您在宝塔面板中运行高写入量或长期积累型数据库应用,表中数据量持续增长导致查询变慢、备份耗时增加、磁盘占用过高,则需实施冷热数据自动分离。以下是实现该目标的多种技术路径:
一、基于MySQL事件调度器与分区表的自动分离
利用MySQL原生分区功能(RANGE/LIST)结合事件调度器定时迁移旧数据至归档表,主业务表仅保留近期热数据,降低单表体积并提升索引效率。
1、登录宝塔面板,进入【数据库】→ 选择目标MySQL实例 → 点击【phpMyAdmin】。
2、执行SQL启用事件调度器:SET GLOBAL event_scheduler = ON;
3、为业务表添加按时间字段(如create_time)的RANGE分区,例如按月划分,当前月及前两月为热区,其余为冷区。
4、创建归档表结构与原表一致,仅引擎可设为MyISAM或压缩InnoDB以节省空间。
5、编写事件SQL:每月1日凌晨执行,将create_time早于90天的数据INSERT INTO归档表后DELETE FROM原表对应行。
二、通过宝塔计划任务调用Shell脚本执行mysqldump+TRUNCATE分离
借助宝塔内置计划任务系统,定时触发Shell脚本导出指定时间范围外的历史数据为SQL文件并存储至独立目录,再清空原表对应记录,适用于无法使用分区的旧版本MySQL或MyISAM引擎。
1、在宝塔【计划任务】中新建任务,类型选择【Shell脚本】。
2、脚本内容中定义导出路径、数据库名、表名、时间阈值(如DATE_SUB(NOW(), INTERVAL 180 DAY))。
3、使用mysqldump配合--where参数导出冷数据:mysqldump -u用户名 -p密码 数据库名 表名 --where="create_time /www/backup/cold_2023.sql
4、执行DELETE语句清除已导出数据,确保WHERE条件与导出一致,避免误删。
5、将导出文件移至NAS或对象存储挂载目录,并设置宝塔备份策略定期同步该目录。
三、部署独立归档服务中间件对接宝塔MySQL
引入轻量级ETL工具(如DBeaver自动化任务、自研Python脚本或Logstash JDBC插件),连接宝塔MySQL主库,按预设规则抽取冷数据写入另一台低配MySQL实例或SQLite文件,实现物理隔离。
1、在宝塔服务器上安装Python3及pymysql、schedule库:pip3 install pymysql schedule
2、编写Python脚本:建立双数据库连接,SELECT热区间外数据,逐批INSERT至归档库,成功后标记原表对应行archive_status=1。
3、使用宝塔【计划任务】以每6小时周期运行该脚本,避免单次长事务阻塞业务。
4、在业务SQL中添加WHERE archive_status = 0条件,确保只查热数据,无需修改现有应用逻辑。
5、为归档库单独配置宝塔数据库权限,仅授予归档脚本用户SELECT和INSERT权限,禁止DROP或ALTER操作。










