This will be a short one, but last night I realized that it was VVV not Vagrant that was making wonderful backups of mysql databases each time I did a vagrant halt
Of course, I realized this after I did a vagrant provision
on a local development site that wasn't set up with VVV and realized the whole Craft CMS project database was gone.
A few hours (yeesh) later, I have a better sense of how VVV uses vagrant-triggers to do a mysqldump of all the databases and tables and I'm halfway towards having that working with the puphpet config.yaml
Particularly helpful references:
- the VVV homebin directory which is pretty much what should be happening: vagrant-triggers on up, halt, and destroy that call a bash script that loops through mysql databases and dumps them out.
In this case, to work with Craft a little more cleanly, I made a bin
directory in my webroot and mapped it to /var/vagrant/bin with config.yaml
:
vagrantfile:
vm:
synced_folder:
vflwf_iq3ozcalwiv4:
source: ./bin
target: /var/vagrant/bin
sync_type: default
smb:
smb_host: ''
smb_username: ''
smb_password: ''
rsync:
args:
- '--verbose'
- '--archive'
- '-z'
exclude:
- .vagrant/
- .git/
auto: 'true'
owner: vagrant
group: vagrant
and a mysql user mysqldumpuser
with SELECT
privileges on all tables.
user: mysqldumpuser
table: '*.*'
privileges:
- SELECT, LOCK TABLES
The biggest hurdle was misunderstanding a permissions error. Even though I'd added mysqldumpuser
to the config.yaml
, it wasn't actually added to the database. Once I checked in Sequel Pro and saw that (and added it) this worked much better.
This is my db_backup
script:
#!/bin/bash
#
# Create individual SQL files for each database. These files
# are imported automatically during an initial provision if
# the databases exist per the import-sql.sh process.
mysql -e 'show databases' | \
grep -v -F "information_schema" | \
grep -v -F "performance_schema" | \
grep -v -F "mysql" | \
grep -v -F "test" | \
grep -v -F "Database" | \
while read dbname; do mysqldump -u mysqldumpuser -p "$dbname" > /var/www/db_backups/local/"$dbname".sql && echo "Database $dbname backed up..."; done
…which is still asking for a password at the prompt, so I have to figure out how to store that as a Vagrant ENV variable or something. Ok.
Edit: This seems to work. .my.cnf
file on the Vagrant side with the mysqldumpuser
info and then remove the -p
part of db_backup