title: "Script Hooks: How to Protect MySQL with Retrospect"
created_at: 2017.05.18
updated_at: 2017.09.05
category: Hooks
---

 
MySQL is a freely available open source Relational Database Management System (RDBMS) that uses Structured Query Language (SQL). With its proven performance, reliability and ease-of-use, MySQL has become the leading database choice for web-based applications, used by high profile web properties including Facebook, Twitter, YouTube, Yahoo! and many more.
 
With Retrospect, you can protect your live, running MySQL instance with no downtime. We’ll walk through how to do it.
 
By default, MySQL stores data at /var/lib/mysqlC:\ProgramData\MySQL\MySQL Server 5.6\datamy.ini
 
To protect the underlying data while your MySQL instance is running, we will use Retrospect’s Script Hooks to lock the database from writes before the backup using the StartSourceEndSource
 
Backup Steps
To protect MySQL, Retrospect or Retrospect Client needs to be running on the same system.
 
- 
Download Retrospect_for_Windows_External_Scripts.zip and place the MySQL script hook at the appropriate location: 
- 
Retrospect for Windows: C:\ProgramData\Retrospect
 
- 
Retrospect for Mac: /Library/Application Support/Retrospect
 
- 
Retrospect Client for Windows: C:\Program Files\Retrospect\Retrospect Client
 
- 
Retrospect Client for Mac: /Library/Application Support/Retrospect Client/retroeventhandler
 
 
 
- 
In the RetroEventHandler
 
function StartSource {
    /bin/rm -f /tmp/retrospectmysqlpipe
    /usr/bin/mkfifo /tmp/retrospectmysqlpipe
    # Note that we use 3598 to be a unique number to search for when we kill the sleep during cleanup.
    /bin/sleep 3598 > /tmp/retrospectmysqlpipe &
    /usr/local/bin/mysql -B -h HOSTNAME -u USERNAME -pPASSWORD &>/dev/null < /tmp/retrospectmysqlpipe &
    echo "FLUSH TABLES WITH READ LOCK;" > /tmp/retrospectmysqlpipe
    echo
}
function EndSource {
    /bin/ps -ef | /usr/bin/awk '/[s]leep 3598/{print $2}' | /usr/bin/xargs kill
    /bin/rm -f /tmp/retrospectmysqlpipe
    echo
}
 
 
- 
Start a backup of the system where MySQL is running. You do not need to restart Retrospect for the updated file to be used. 
 
 
Restore Steps
- 
Stop your MySQL instance. 
- 
Restore the Retrospect backup containing the MySQL data store. 
- 
Start your MySQL instance. The instance will utilize the restored data. 
 
 
		
	 
	Last Update: 05. September 2017