A simple database backup manager for Symfony2 with support for S3, Rackspace, Dropbox, FTP, SFTP.

Maintainers

πŸ‘ ShawnMcCool

Package info

github.com/backup-manager/symfony

Type:symfony-bundle

pkg:composer/backup-manager/symfony

Statistics

Installs: 298 564

Dependents: 4

Suggesters: 1

Stars: 119

Open Issues: 6

3.2.1 2021-10-17 19:59 UTC

Requires

Suggests

Provides

None

Conflicts

None

Replaces

None

MIT 8766033884fa7782ea2568ad11a15e3210c3f2bb

  • Tobias Nyholm <tobias.nyholm.woop@gmail.com>
  • Luiz Henrique Gomes PalΓ‘cio <lhpalacio.woop@outlook.com>

databasesymfonys3backupsftprackspaceftpdropbox

This package is auto-updated.

Last update: 2026-06-24 16:08:06 UTC


README

πŸ‘ Latest Stable Version
πŸ‘ License
πŸ‘ Build Status
πŸ‘ Total Downloads

A simple database backup manager for Symfony with support for S3, Rackspace, Dropbox, FTP, SFTP.

This package pulls in the framework agnostic Backup Manager and provides seamless integration with Symfony.

Installation

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

$ composer require backup-manager/symfony

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2 (with Flex): Enable the Bundle

You do not need to do anything more. The bundle is enabled automatically and you have some nice default config in config/packages/bm_backup_manager.yml.

Step 2 (no Flex): Enable the Bundle

If you are not using Symfony Flex, you need to enable the bundle by adding it to the list of registered bundles in the app/AppKernel.php file of your project.

// config/bundles.php

return [
 BM\BackupManagerBundle\BMBackupManagerBundle::class => ['all' => true],
 // ...
];

Step 3: Configure your databases and filesystems

# config/packages/bm_backup_manager.yml

bm_backup_manager:
 database:
 development:
 type: mysql
 host: localhost
 port: 3306
 user: root
 pass: password
 database: test
 ignoreTables: ['foo', 'bar']

 # If DSN is specified, it will override other values
 dsn: 'mysql://root:root_pass@127.0.0.1:3306/test_db'
 production:
 type: postgresql
 host: localhost
 port: 5432
 user: postgres
 pass: password
 database: test

 # You could also use a environment variable
 dsn: '%env(resolve:DATABASE_URL)%'
 storage:
 local:
 type: Local
 root: /path/to/working/directory
 s3:
 type: AwsS3
 key:
 secret:
 region: us-east-1
 version: latest
 bucket:
 root:
 b2:
 type: B2
 key:
 accountId:
 bucket:
 rackspace:
 type: Rackspace
 username:
 password:
 container:
 dropbox:
 type: DropboxV2
 token:
 key:
 secret:
 app:
 root:
 ftp:
 type: Ftp
 host:
 username:
 password:
 root:
 port: 21
 passive: true
 ssl: true
 timeout: 30
 sftp:
 type: Sftp
 host:
 username:
 password:
 root:
 port: 21
 timeout: 10
 privateKey:

Usage

To backup from any configured database.

Backup the development database to Amazon S3. The S3 backup path will be test/backup.sql.gz in the end, when gzip is done with it.

class Foo {
 private $backupManager;

 public function __construct(BackupManager $backupManager) {
 $this->backupManager = $backupManager;
 }

 public function bar() {
 $this->backupManager->makeBackup()->run('development', [new Destination('s3', 'test/backup.sql')], 'gzip');
 }
}

Or with a command:

php bin/console backup-manager:backup development s3 -c gzip --filename test/backup.sql

To restore from any configured filesystem.

Restore the database file test/backup.sql.gz from Amazon S3 to the development database.

class Foo {
 private $backupManager;

 public function __construct(BackupManager $backupManager) {
 $this->backupManager = $backupManager;
 }

 public function bar() {
 $this->backupManager->makeRestore()->run('s3', 'test/backup.sql.gz', 'development', 'gzip');
 }
}

Or with a command:

php bin/console backup-manager:restore development s3 test/backup.sql.gz -c gzip

This package does not allow you to backup from one database type and restore to another. A MySQL dump is not compatible with PostgreSQL.

Requirements

  • PHP 7.3
  • MySQL support requires mysqldump and mysql command-line binaries
  • PostgreSQL support requires pg_dump and psql command-line binaries
  • Gzip support requires gzip and gunzip command-line binaries