The purpose of this script is to backup and optionally --sanitize
the database
of your Backdrop CMS website.
- Linux server
- Backdrop CMS website
- PHP CLI
Clone this directory down to your filesystem. Perhaps to your home directory.
git clone git@github.com:serundeputy/sql-dump-sanitize.git
cd sql-dump-sanitize
Copy the config.ini.example
file to config.ini
-
cp config.ini.exaple config.ini
-
Set the config variables in
config.ini
to values appropriate for your server and Backdrop database. -
Required configuration variables. Copy the config.ini.example file to config.ini and replace with values for your server.
; This user must have access to create and drop databases to use `--sanitize`
DB_USER = root
; Password of the above user
DB_PASSWORD = pass
; Database to perform backups and optional `--sanitize`
DB_NAME = backdrop
; Host of the Database usually localhost, but could be an external name or IP
DB_HOST = localhost
; Root directory of the Backdrop installation
BACKDROP_ROOT = /var/www/html
; Directory where you would like the backups to be stored
BACKUP_DESTINATION = /home/user/me/backups
php path/to/sql-dump-sanitize.php
- This will create a backup of the database written to the
BACKUP_DESTINATION
specified inconfig.ini
.
- This will create a backup of the database written to the
- Options
--quiet
(-q
alias) suppress standard output (good for running as cron job)--sanitize
(-s
alias) sanitize user email addresses for the backup. Sanitized backups are placed inBACKUP_DESTINATION
/sanitized subdirectory.--rollover
(-r
alias) remove stale backups where stale is defined by theNUM_KEEP
config variable.
php path/to/files-backup.php
- This will create a backup of the files directory written to the
BACKKUP_DESTINATION/files_backups
specified inconfig.ini
- This will create a backup of the files directory written to the
- Options
--rollover_files
(rf
alias) remove stale files dierectory backups where stale is defined by theNUM_KEEP
config variable.
- Set a server cron task to run the script on a schedule (daily, weekly, monthly or any and/or combination). For example a weekly on 8.05am Saturday morning; the cron job would look like this:
# 1. Entry: Minute when the process will be started [0-60]
# 2. Entry: Hour when the process will be started [0-23]
# 3. Entry: Day of the month when the process will be started [1-28/29/30/31]
# 4. Entry: Month of the year when the process will be started [1-12]
# 5. Entry: Weekday when the process will be started [0-6] [0 is Sunday]
# Database backup #
###################
5 8 * * 6 {/absolute/path/to/php} {/path/to/script/}sql-dump-sanitize.php --quiet
# files directory backup #
##########################
5 10 * * 6 {/absolute/path/to/php} {/path/to/script/}files-backup.php --rollover_files
Happy backups ;)