Laravel 文件备份和数据库备份工具(spatie - laravel - backup)

发布时间:2018-05-06 编辑:小张个人博客 查看次数:3083

spatie/laravel-backup这个应用程序包创建laravel备份。备份是一个zip文件包含所有的文件目录中指定和转储你的数据库。可以将备份存储在任何的文件系统你已经配置laravel 5。

感觉担心备份?别!你可以同时向多个文件系统应用程序的备份。

一旦安装,使您的文件和数据库备份是很容易的。只要运行该命令:php artisan backup:run

获取地址:https://github.com/spatie/laravel-backup

注意事项:

  • 这种备份包需要PHP 7或更高ZIP模块Laravel 5.5或更高。这不是兼容Windows服务器。

  • 如果您使用的是旧版本的Laravel v3v4 Laravel备份支持Laravel 5.1.20

  • 这个包需要空闲磁盘空间,它可以创建备份。确保你至少尽可能多的自由空间,你想备份文件的总大小。

  • 确保 mysqldump安装在您的系统上,如果你想备份MySQL数据库

  • 确保 pg_dump安装在您的系统上,如果你想备份PostgreSQL数据库

  • 确保 mongodump安装在您的系统上,如果你想备份Mongo数据库

使用composer安装spatie/laravel-backup

composer require "spatie/laravel-backup:^3.0.0"

注册服务提供者(config/app.php):

'providers' => [
    // ...
    Spatie\Backup\BackupServiceProvider::class,
];

发布配置文件config/laravel-backup.php

php artisan vendor:publish --provider="Spatie\Backup\BackupServiceProvider"

如果你的数据库需要很长的时间,你会撞到默认超时60秒。你可以设置一个更高(或低)提供了一个限制dump_command_timeout配置密钥设置多长的命令可以运行在秒。

以MySQL为例(config/databases.php):

'connections' => [
'mysql' => [
	'dump_command_path' => '/path/to/the/binary', // only the path, so without 'mysqldump' or 'pg_dump'
	'dump_command_timeout' => 60 * 5, // 5 minute timeout
	'dump_using_single_transaction' => true, // perform dump using a single transaction
	'driver'    => 'mysql',
	...
],

PostgreSQL数据库的你也可以设置一个配置关键命名dump_use_inserts使用inserts而不是copy在数据库转储文件。

spatie/laravel-backup - MySQL数据备份

备份应用程序包括数据库:

php artisan backup:run

spatie/laravel-backup - MySQL数据备份

spatie/laravel-backup - MySQL数据备份

备份的数据库运行:

php artisan backup:run --only-db

如果你只需要备份的文件,想跳过数据库,运行:

php artisan backup:run --only-files

提示: `--only-db `和` --only-files`。当监控备份包不会区分完整备份和备份只有文件数据库


确定备份的目的地

备份可以复制到一个或多个文件系统。这是配置的一部分,您可以指定这些目标文件系统。

'destination' => [
  /*
  * The disk names on which the backups will be stored. 
  */
  'disks' => [
      'local'
  ],
],

备份的目的地默认值 config('laravel-backup.destination.filesytems)是一个数组只有一个关键: local。如果您只使用本地磁盘备份磁盘崩溃你会只留下眼泪。

我们强烈推荐配置一些额外的磁盘 app/config/filesystems.php并添加自己的名字作为一个目标文件系统的备份。这些磁盘应该使用外部服务器或服务(如S3)。

spatie/laravel-backup - 清除旧的MySQL数据备份

随着时间的推移,备份量和存储需要保持增长。有时你会想清理旧的备份。


清理备份数据运行:

默认最后一次的备份数据是不会被删除的

php artisan backup:clean

确定要删除的备份

这是配置的一部分,将决定哪些备份应该删除。

//config/laravel-backup.php

'cleanup' => [
/*
 * The strategy that will be used to cleanup old backups.
 * The youngest backup wil never be deleted.
 */
'strategy' => \Spatie\Backup\Tasks\Cleanup\Strategies\DefaultStrategy::class,

"defaultStrategy" =
	/*
	* 所有每日备份必须保留的天数。
	*/
	"keepAllBackupsForDays" = > 7

	/*
	* 必须保留每日备份的天数。
	*/
	"keepDailyBackupsForDays" = > 16

	/*
	* 必须保留每周一次的备份的时间。
	*/
	"keepWeeklyBackupsForWeeks" = > 8

	/*
	* 每月必须保存一个月的备份量。
	*/
	"keepMonthlyBackupsForMonths" = > 4

	/*
	* 每年必须保持一年的备份量
	*/
	"keepYearlyBackupsForYears" = > 2

	/*
	* 清理完备份后删除最旧的备份, 直到
	* 达到了这一数量的兆字节。
	*/
	"deleteOldestBackupsWhenUsingMoreMegabytesThan" = > 5000
	]
],


此包提供了一种有意义的方法来确定应删除哪些旧备份。我们称之为“缺省策略”。这是它的工作原理:


规则# 1: 不会删除最近一次的备份

规则# 2:它将使所有备份的日子中指定 keepAllBackupsForDays

规则# 3:它只会保持每日备份的日子中指定 keepDailyBackupsForDays以上的所有备份那些规则#2负责

规则# 4:它只会保持每周备份中指定的几个月 keepMonthlyBackupsForMonths以上的所有备份那些规则#3负责

规则# 5:它只会保持每年备份指定的年 keepYearlyBackupsForYears以上的所有备份那些规则#4负责

规则# 6:它将开始删除旧的备份,直到所使用的存储空间低于指定的数字indeleteOldestBackupsWhenUsingMoreMegabytesThan


当然缺省配置中使用的数字可以调整自己的喜欢。


创建您自己的策略

如果你不满意 DefaultStrategy,您可以创建自己的自定义策略。可以通过扩展抽象类 Spatie\Backup\Tasks\Cleanup\CleanupStrategy。你只需要实现这个方法:

use Spatie\Backup\BackupDestination\BackupCollection;

public function deleteOldBackups(BackupCollection $backupCollection)

BackupCollection类是扩展的 Illuminate\Support\Collection,包含 Spatie\Backup\BackupDestination\Backup对象按时间排序。最后一次备份是第一个集合中。

使用集合,您可以手动删除最老的备份:

// Retrieve an instance of `Spatie\Backup\BackupDestination\Backup`
$backup = $backups->oldestBackup();

// Bye bye backup
$backup->delete()


别忘了您的自定义策略指定完整的类名 cleanup.strategy的关键 laravel-backup配置文件。

更多操作请查阅官方文档:https://docs.spatie.be/laravel-backup/v5/introduction



出处:小张个人博客

网址:http://blog.023xs.cn/

您的支持是对博主最大的鼓励,感谢您的认真阅读。欢迎转载,但请保留该声明。

顶部

Copyright © 小张个人博客 All Rights Reserved 渝ICP备15006773号-1

联系方式:[email protected] | 本站文章仅供学习和参考

渝公网安备 50024102500267号