未命名 发表于 2022-10-21 12:38:05

laravel备份组件安装

第一步:
$ 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/此文




页: [1]
查看完整版本: laravel备份组件安装