This document guides you on how to back up a MySQL clustered and standalone databases hosted on VMware using the Enterprise Workloads data protection solution. You can leverage VMware Tools utility to run custom pre-post backup scripts, ensuring database consistent snapshots.
π Note
Ensure VMware Tools are installed on the MySQL Server VM.
Procedure
Create the backupScripts.d folder under the /etc/vmware-tools on the MySQL Server VM. For more information, refer to the VMware KB article.
SSH into the MySQL Server VM as a non-root sudo user.
Run the following command:
sudo mkdir /etc/vmware-tools/backupScripts.dβ
Create pre and post script files in the /etc/vmware-tools/backupScripts.d folder and you must name them starting with a number to ensure sequential execution of IO freeze and IO thaw tasks by VMware tools, where lower number has higher priority during script execution. In our example, the 10-pre-freeze-script.sh script will be executed prior to the 20-post-thaw-script.sh script.
Pre-backup script: 10-pre-freeze-script.sh
Post-backup script: 20-post-thaw-script.sh
β
Ensure scripts are executable with appropriate privileges.
SSH into the MySQL Server VM.
Run the following commands:
sudo chmod +x /etc/vmware-tools/backupScripts.d/10-pre-freeze-script.shsudo chmod +x /etc/vmware-tools/backupScripts.d/20-post-thaw-script.shsudo chown root:root /etc/vmware-tools/backupScripts.d/10-pre-freeze-script.shsudo chown root:root /etc/vmware-tools/backupScripts.d/20-post-thaw-script.shβ
Deploy a backup proxy to back up your VM.
Download the VMware Proxy Deployer on your local system and deploy the backup proxy using steps listed in Deploy VMware proxy using VMware Proxy Deployer.
Configure VM for backup by creating a backup policy on the Enterprise Workloads Management Console.
Enable Changed Block Tracking (CBT) and VMware tools quiescing in the backup policy configuration.
β
Perform a manual VM backup on the Enterprise Workloads Management Console for a quick validation.
Sample Pre-script: 10-pre-freeze-script.sh
#!/bin/bashtimeout=60lock_file=/tmp/mysql_tables_read_locksleep_time=$((timeout+10))rm -f $lock_fileecho "FLUSH TABLES WITH READ LOCK" | logger -t $(basename $0)mysql -uroot -p'my_password' -e "FLUSH TABLES WITH READ LOCK; system touch $lock_file; system nohup sleep $sleep_time; system echo \"Lock released\"|logger -t $(basename $0); " > /dev/null &mysql_freeze_pid=$!echo "child pid $mysql_freeze_pid" | logger -t $(basename $0)c=0while [ ! -f $lock_file ]do if ! ps -p $mysql_freeze_pid 1>/dev/null ; then echo "Mysql command has failed (bad credentials?)" | logger -t $(basename $0) exit 1 fi sleep 1 c=$((c+1)) if [ $c -gt $timeout ]; then echo "Timed out waiting for lock" | logger -t $(basename $0) touch $lock_file kill $mysql_freeze_pid fidoneecho $mysql_freeze_pid > $lock_fileexit 0
Sample Post-script: 20-post-thaw-script.sh
#!/bin/bashlock_file=/tmp/mysql_tables_read_lockmysql_freeze_pid=$(cat $lock_file)echo "Sending sigterm to $mysql_freeze_pid" | logger -t $(basename $0)pkill -9 -P $mysql_freeze_pidrm -f $lock_fileexit 0