第一步:
- $ composer require laravel-admin-ext/backup -vvv
复制代码 添加provider
- // config/app.php
- 'providers' => [
- // ...
- Spatie\Backup\BackupServiceProvider::class,
- ];
复制代码
第二部
- php artisan admin:import backup
复制代码
第三部:在数据库配置文件中加上如下代码(config/database.php)参照修改
- 'mysql' => [
- 'driver' => 'mysql',
- 'host' => env('DB_HOST', 'localhost'),
- 'database' => env('DB_DATABASE', 'forge'),
- 'username' => env('DB_USERNAME', 'forge'),
- 'password' => env('DB_PASSWORD', ''),
- 'charset' => 'utf8',
- 'collation' => 'utf8_unicode_ci',
- 'prefix' => '',
- 'strict' => false,
- 'engine' => null,
- 'dump' => [
- 'dump_binary_path' => '/path/to/directory/', // only the path, without `mysqldump` or `pg_dump`
- // 'dump_binary_path' => '/Applications/MAMP/Library/bin/', // works for MAMP on Mac OS
- // 'dump_binary_path' => '/opt/homebrew/bin/', // works for Laravel Valet on Mac OS
- 'use_single_transaction',
- 'timeout' => 60 * 5, // 5 minute timeout
- // 'exclude_tables' => ['table1', 'table2'],
- // 'add_extra_option' => '--optionname=optionvalue',
- ]
- ],
复制代码 主要是dump备份路径位置
第四部:发布配置文件
- php artisan vendor:publish --provider="Spatie\Backup\BackupServiceProvider"
复制代码 第五步:config/bacpup.php内容如下:
- return [
- 'backup' => [
- /*
- * The name of this application. You can use this name to monitor
- * the backups.
- */
- 'name' => env('APP_URL'),
- 'source' => [
- 'files' => [
- /*
- * The list of directories and files that will be included in the backup.
- */
- 'include' => [
- base_path(),
- ],
- /*
- * These directories and files will be excluded from the backup.
- *
- * Directories used by the backup process will automatically be excluded.
- */
- 'exclude' => [
- base_path('vendor'),
- base_path('node_modules'),
- ],
- /*
- * Determines if symlinks should be followed.
- */
- 'followLinks' => false,
- ],
- /*
- * The names of the connections to the databases that should be backed up
- * Only MySQL and PostgreSQL databases are supported.
- */
- 'databases' => [
- 'mysql',
- ],
- ],
- 'destination' => [
- /*
- * The filename prefix used for the backup zip file.
- */
- 'filename_prefix' => '',
- /*
- * The disk names on which the backups will be stored.
- */
- 'disks' => [
- 'local',
- ],
- ],
- ],
- /*
- * You can get notified when specific events occur. Out of the box you can use 'mail' and 'slack'.
- * For Slack you need to install guzzlehttp/guzzle.
- *
- * You can also use your own notification classes, just make sure the class is named after one of
- * the `Spatie\Backup\Events` classes.
- */
- 'notifications' => [
- 'notifications' => [
- \Spatie\Backup\Notifications\Notifications\BackupHasFailed::class => ['mail'],
- \Spatie\Backup\Notifications\Notifications\UnhealthyBackupWasFound::class => ['mail'],
- \Spatie\Backup\Notifications\Notifications\CleanupHasFailed::class => ['mail'],
- \Spatie\Backup\Notifications\Notifications\BackupWasSuccessful::class => ['mail'],
- \Spatie\Backup\Notifications\Notifications\HealthyBackupWasFound::class => ['mail'],
- \Spatie\Backup\Notifications\Notifications\CleanupWasSuccessful::class => ['mail'],
- ],
- /*
- * Here you can specify the notifiable to which the notifications should be sent. The default
- * notifiable will use the variables specified in this config file.
- */
- 'notifiable' => \Spatie\Backup\Notifications\Notifiable::class,
- 'mail' => [
- 'to' => 'your@email.com',
- ],
- 'slack' => [
- 'webhook_url' => '',
- ],
- ],
- /*
- * Here you can specify which backups should be monitored.
- * If a backup does not meet the specified requirements the
- * UnHealthyBackupWasFound event will be fired.
- */
- 'monitorBackups' => [
- [
- 'name' => env('APP_URL'),
- 'disks' => ['local'],
- 'newestBackupsShouldNotBeOlderThanDays' => 1,
- 'storageUsedMayNotBeHigherThanMegabytes' => 5000,
- ],
- /*
- [
- 'name' => 'name of the second app',
- 'disks' => ['local', 's3'],
- 'newestBackupsShouldNotBeOlderThanDays' => 1,
- 'storageUsedMayNotBeHigherThanMegabytes' => 5000,
- ],
- */
- ],
- 'cleanup' => [
- /*
- * The strategy that will be used to cleanup old backups. The default strategy
- * will keep all backups for a certain amount of days. After that period only
- * a daily backup will be kept. After that period only weekly backups will
- * be kept and so on.
- *
- * No matter how you configure it the default strategy will never
- * delete the newest backup.
- */
- 'strategy' => \Spatie\Backup\Tasks\Cleanup\Strategies\DefaultStrategy::class,
- 'defaultStrategy' => [
- /*
- * The number of days for which backups must be kept.
- */
- 'keepAllBackupsForDays' => 7,
- /*
- * The number of days for which daily backups must be kept.
- */
- 'keepDailyBackupsForDays' => 16,
- /*
- * The number of weeks for which one weekly backup must be kept.
- */
- 'keepWeeklyBackupsForWeeks' => 8,
- /*
- * The number of months for which one monthly backup must be kept.
- */
- 'keepMonthlyBackupsForMonths' => 4,
- /*
- * The number of years for which one yearly backup must be kept.
- */
- 'keepYearlyBackupsForYears' => 2,
- /*
- * After cleaning up the backups remove the oldest backup until
- * this amount of megabytes has been reached.
- */
- 'deleteOldestBackupsWhenUsingMoreMegabytesThan' => 5000,
- ],
- ],
- ];
复制代码
备份不能下载和删除,需要修改D:\WWW\syfw\vendor\laravel-admin-ext\backup\resources\views 里面的视图文件
详情可以看:https://www.yaanbbs.net/study/yaan30017/此文
|