基于thinkphp5的数据库备份与还原扩展

技术知识
0 1591
小师傅 小师傅2018-01-19
积分:2397

使用composer进行安装

composer require tp5er/tp5-databackup dev-master

使用composer update进行安装

"require": {
     "tp5er/tp5-databackup": "dev-master"
},

引入类文件

use \tp5er\Backup;

配置文件

$config=array(
    'path'     => './Data/',//数据库备份路径
    'part'     => 20971520,//数据库备份卷大小
    'compress' => 0,//数据库备份文件是否启用压缩 0不压缩 1 压缩
    'level'    => 9 //数据库备份文件压缩级别 1普通 4 一般  9最高
);

实例化

 $db= new Backup($config);

文件命名规则,请严格遵守(温馨提示)

$file=['name'=>date('Ymd-His'),'part'=>1]

数据类表列表

return $this->fetch('index',['list'=>$db->dataList()]);

备份文件列表

 return $this->fetch('importlist',['list'=>$db->fileList()]);

备份表

$tables="数据库表1";
 $start= $db->setFile($file)->backup($tables[$id], 0);
 当$start返回0的时候就表示备份成功

导入表

$start=0;
 $start= $db->setFile($file)->import($start);

删除备份文件

 $db->delFile($time);

下载备份文件

$db->downloadFile($time);

修复表

 $db->repair($tables)

优化表

 $db->optimize($tables)

大数据备份采取措施1

如果备份数据比较大的情况下,需要修改如下参数
//默认php代码能够申请到的最大内存字节数就是134217728 bytes,如果代码执行的时候再需要更多的内存,根据情况定义指定字节数
memory_limit = 1024M
//默认php代码申请到的超时时间是20s,如果代码执行需要更长的时间,根据代码执行的超时时间定义版本运行超时时间
max_execution_time =1000

大数据备份采取措施2

    自由设置超时时间。支持连贯操作,该方法主要使用在表备份和还原中,防止备份还原和备份不完整
    //备份
    $time=0//表示不限制超时时间,直到程序结束,(慎用)
    $db->setTimeout($time)->setFile($file)->backup($tables[$id], 0);
    //还原
    $db->setTimeout($time)->setFile($file)->import($start);


精选帖子
Android 可可影视 v3.3.6无广告纯净版 2714
Android QQ音乐 v11.3.7 定制版解锁免费听歌无广告版 3226
Android 草图大师SKP v1.5 解锁会员版 8611
Android OmoFun追漫神器 v4.2.1 无广告绿色版 5626
AdobeGenP Adobe全家桶系列激活工具 v3.5.0/3.4.14.1 绿色版 6210
Android 七猫免费听书 v1.4 解锁高级版 4671
超良心的抢票神器——Bypass1.16 4329
Android 玲珑加速器 v6.10.9.40 解锁无限时间 3024
Android 大师兄影视 v3.3.8 去广告会员版 2144
热门帖子
上班族闭眼搞!多多虚拟类目机器人发货,被动收入,月入 1‑5W! 60
最佳机场梯子推荐︱两款手机PC稳定的机场节点和魔法上外网科学梯子 55
当天做,当天见收益,全流程挂机操作,单账号轻松日入500+ 53
电脑搬砖,用AI自动写文章,每月稳赚1-2W,免费提供接单渠道,小白可做! 51
最强手机挂机项目,每天十几分钟,轻松日入500+ 49
海外武侠小说挂机,单张号日赚 3 美金,看武侠小说赚美金,网文阅读项目,长期稳定收益… 47
小红书虚拟项目训练营8.0:跑通AI全流程,从养号到开店发货,打造高利润虚拟店铺 44
AI赋能短视频创作:从工具入门到项目实战,一次学透豆包Deepseek即梦全攻略 44
AI矩阵智能体实战:100个数字员工批量生产内容,文本知识库+工作流自动化全搞定 43