mirror of
https://github.com/crmeb/CRMEB.git
synced 2026-01-20 07:20:24 +00:00
数据库备份
This commit is contained in:
parent
38c0a75409
commit
a391a923c8
@ -1,12 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
namespace app\admin\controller\system;
|
namespace app\admin\controller\system;
|
||||||
|
|
||||||
use app\admin\controller\AuthController;
|
use app\admin\controller\AuthController;
|
||||||
use service\FormBuilder as Form;
|
use service\FormBuilder as Form;
|
||||||
use think\Request;
|
use think\Request;
|
||||||
use service\JsonService as Json;
|
use service\JsonService as Json;
|
||||||
use \tp5er\Backup;
|
use \tp5er\Backup;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 文件校验控制器
|
* 文件校验控制器
|
||||||
* Class SystemDatabackup
|
* Class SystemDatabackup
|
||||||
@ -19,7 +17,7 @@ class SystemDatabackup extends AuthController
|
|||||||
public function _initialize()
|
public function _initialize()
|
||||||
{
|
{
|
||||||
$config = array(
|
$config = array(
|
||||||
'path' => './backup/data/',
|
'path' => PUBILC_PATH.'backup/data/',
|
||||||
//数据库备份路径
|
//数据库备份路径
|
||||||
'part' => 20971520,
|
'part' => 20971520,
|
||||||
//数据库备份卷大小
|
//数据库备份卷大小
|
||||||
@ -29,15 +27,12 @@ class SystemDatabackup extends AuthController
|
|||||||
);
|
);
|
||||||
$this->DB = new Backup($config);
|
$this->DB = new Backup($config);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据类表列表
|
* 数据类表列表
|
||||||
*/
|
*/
|
||||||
public function index(){
|
public function index(){
|
||||||
|
|
||||||
return $this->fetch();
|
return $this->fetch();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取数据库表
|
* 获取数据库表
|
||||||
* @param Request|null $request
|
* @param Request|null $request
|
||||||
@ -47,7 +42,6 @@ class SystemDatabackup extends AuthController
|
|||||||
$db= $this->DB;
|
$db= $this->DB;
|
||||||
return Json::result(0,'sucess',$db->dataList(),count($db->dataList()));
|
return Json::result(0,'sucess',$db->dataList(),count($db->dataList()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查看表结构
|
* 查看表结构
|
||||||
* @param Request|null $request
|
* @param Request|null $request
|
||||||
@ -56,7 +50,6 @@ class SystemDatabackup extends AuthController
|
|||||||
{
|
{
|
||||||
parent::__construct($request);
|
parent::__construct($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 优化表
|
* 优化表
|
||||||
* @param Request|null $request
|
* @param Request|null $request
|
||||||
@ -68,7 +61,6 @@ class SystemDatabackup extends AuthController
|
|||||||
$res = $db->optimize($tables);
|
$res = $db->optimize($tables);
|
||||||
return Json::successful($res ? '优化成功':'优化失败');
|
return Json::successful($res ? '优化成功':'优化失败');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**修复表
|
/**修复表
|
||||||
* @param Request|null $request
|
* @param Request|null $request
|
||||||
*/
|
*/
|
||||||
@ -109,18 +101,68 @@ class SystemDatabackup extends AuthController
|
|||||||
$data[$key]['compress'] = $t['compress'];
|
$data[$key]['compress'] = $t['compress'];
|
||||||
$data[$key]['time'] = date('Y-m-d H:i:s',$t['time']);
|
$data[$key]['time'] = date('Y-m-d H:i:s',$t['time']);
|
||||||
}
|
}
|
||||||
|
return Json::result(200,'sucess',$data,count($data));
|
||||||
return Json::result(0,'sucess',$data,count($data));
|
}
|
||||||
} /**删除备份记录表
|
/**删除备份记录表
|
||||||
* @param Request|null $request
|
* @param Request|null $request
|
||||||
*/
|
*/
|
||||||
public function delFile(Request $request = null)
|
public function delFile(Request $request = null)
|
||||||
{
|
{
|
||||||
$feilname = strtotime($request->post('feilname'));
|
$feilname = strtotime($request->post('feilname'));
|
||||||
echo $feilname;
|
|
||||||
|
|
||||||
|
|
||||||
$files = $this->DB->delFile($feilname);
|
$files = $this->DB->delFile($feilname);
|
||||||
// return Json::result(0,'sucess',$data,count($data));
|
return Json::result(200,'sucess');
|
||||||
|
}
|
||||||
|
/**倒入备份记录表
|
||||||
|
* @param Request|null $request
|
||||||
|
*/
|
||||||
|
public function import(Request $request = null)
|
||||||
|
{
|
||||||
|
$part = null; $start = null;
|
||||||
|
$time = strtotime($request->post('feilname'));
|
||||||
|
$db = $this->DB;
|
||||||
|
if(is_numeric($time) && is_null($part) && is_null($start)){
|
||||||
|
$list= $db->getFile('timeverif',$time);
|
||||||
|
if(is_array($list)){
|
||||||
|
session::set('backup_list',$list);
|
||||||
|
$this->success('初始化完成!','',array('part' =>1,'start'=>0));
|
||||||
|
}else{
|
||||||
|
$this->error('备份文件可能已经损坏,请检查!');
|
||||||
|
}
|
||||||
|
}else if(is_numeric($part)&&is_numeric($start)){
|
||||||
|
$list=session::get('backup_list');
|
||||||
|
$start=$db->setFile($list)->import($start);
|
||||||
|
if(false===$start){
|
||||||
|
$this->error('还原数据出错!');
|
||||||
|
}elseif(0===$start){
|
||||||
|
if(isset($list[++$part])){
|
||||||
|
$data=array('part'=>$part,'start'=>0);
|
||||||
|
$this->success("正在还原...#{$part}",'',$data);
|
||||||
|
}else{
|
||||||
|
session::delete('backup_list');
|
||||||
|
$this->success('还原完成!');
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
$data=array('part'=>$part,'start'=>$start[0]);
|
||||||
|
if($start[1]){
|
||||||
|
$rate=floor(100*($start[0]/$start[1]));
|
||||||
|
$this->success("正在还原...#{$part}({$rate}%)",'',$data);
|
||||||
|
}else{
|
||||||
|
$data['gz']=1;
|
||||||
|
$this->success("正在还原...#{$part}",'',$data);
|
||||||
|
}
|
||||||
|
$this->success("正在还原...#{$part}",'');
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
$this->error('参数错误!');
|
||||||
|
}
|
||||||
|
// return Json::result(0,'sucess',$data,count($data));
|
||||||
|
}
|
||||||
|
/**下载备份记录表
|
||||||
|
* @param Request|null $request
|
||||||
|
*/
|
||||||
|
public function downloadFile(Request $request = null)
|
||||||
|
{
|
||||||
|
$feilname = strtotime($request->post('feilname'));
|
||||||
|
$this->DB->downloadFile($feilname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -66,6 +66,32 @@
|
|||||||
//监听工具条
|
//监听工具条
|
||||||
fileList.on('tool(fileList)', function(obj){
|
fileList.on('tool(fileList)', function(obj){
|
||||||
var data = obj.data;
|
var data = obj.data;
|
||||||
|
var layEvent = obj.data;
|
||||||
|
switch (layEvent){
|
||||||
|
case 'import':
|
||||||
|
layer.confirm('真的倒入该备份吗?', function(index){
|
||||||
|
layList.basePost(layList.Url({a:'import'}),{feilname:data.time},function (res) {
|
||||||
|
layList.msg(res.msg);
|
||||||
|
buckdata.reload();
|
||||||
|
});
|
||||||
|
obj.del();
|
||||||
|
layer.close(index);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case 'delFile':
|
||||||
|
layer.confirm('真的删除该备份吗?', function(index){
|
||||||
|
layList.basePost(layList.Url({a:'delFile'}),{feilname:data.time},function (res) {
|
||||||
|
layList.msg(res.msg);
|
||||||
|
buckdata.reload();
|
||||||
|
});
|
||||||
|
obj.del();
|
||||||
|
layer.close(index);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case 'downloadFile':
|
||||||
|
$eb.createModalFrame('详情',layList.Url({a:'downloadFile',p:{feilname:data.name}}));
|
||||||
|
break;
|
||||||
|
}
|
||||||
if(obj.event === 'import'){
|
if(obj.event === 'import'){
|
||||||
layer.msg('ID:'+ data.id + ' 的查看操作');
|
layer.msg('ID:'+ data.id + ' 的查看操作');
|
||||||
} else if(obj.event === 'delFile'){
|
} else if(obj.event === 'delFile'){
|
||||||
@ -106,35 +132,26 @@
|
|||||||
$.each(data, function (name, value) {
|
$.each(data, function (name, value) {
|
||||||
if (value['name'] != undefined) tables.push(value['name']);
|
if (value['name'] != undefined) tables.push(value['name']);
|
||||||
});
|
});
|
||||||
|
if(tables.length < 1 || empty(tables)){
|
||||||
|
return;
|
||||||
|
}
|
||||||
switch(obj.event){
|
switch(obj.event){
|
||||||
case 'backup':
|
case 'backup':
|
||||||
if(tables.length){
|
layList.basePost(layList.Url({a:'backup'}),{tables:tables},function (res) {
|
||||||
layList.basePost(layList.Url({a:'backup'}),{tables:tables},function (res) {
|
layList.msg(res.msg,{icon:1,time:1000},function(){
|
||||||
layList.msg(res.msg,{icon:1,time:1000},function(){
|
buckdata.reload();
|
||||||
buckdata.reload();
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}else{
|
});
|
||||||
layList.msg('请选择表');
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 'optimize':
|
case 'optimize':
|
||||||
if(tables.length){
|
layList.basePost(layList.Url({a:'optimize'}),{tables:tables},function (res) {
|
||||||
layList.basePost(layList.Url({a:'optimize'}),{tables:tables},function (res) {
|
layList.msg(res.msg);
|
||||||
layList.msg(res.msg);
|
});
|
||||||
});
|
|
||||||
}else{
|
|
||||||
layList.msg('请选择表');
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 'repair':
|
case 'repair':
|
||||||
if(tables.length){
|
layList.basePost(layList.Url({a:'repair'}),{tables:tables},function (res) {
|
||||||
layList.basePost(layList.Url({a:'repair'}),{tables:tables},function (res) {
|
layList.msg(res.msg);
|
||||||
layList.msg(res.msg);
|
});
|
||||||
});
|
|
||||||
}else{
|
|
||||||
layList.msg('请选择表');
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user