Friday, June 19, 2009
SQL Server Backing up and Maintence Plan....how to delete those old .bak files
One of the task I need to do was have a suitable backup plan on several MS SQL 2008 databases. What seemed a straight forward excerise took for ever to work out a complete workable solution. However in the end I got there following was some of the pitfalls I fell into and some of the solutions I found out along the way. I hope this helps other people just starting to work with SQL Server 2008.
STEP 1: Planning
There was four things I took into account when making a backup plan:
1. Useage
2. Time Taken for Backup
3. How far back would I need a backup.
4. Should I use log files.
1.Useage was the most important factor. A database which is used daily should be backed up daily end of story. A Database used weekly should be backed up weekly....I think you get my point.
2. Time taken for a backup suprisingly is usually alot less than what most people might think I had a 30GB database which took 5 minutes to do a full backup. Unless your looking at a database that is in excess of 100GB your not going to be worried about running this on a schedule at 1am in the morning every day.
3. This was the most important thing for me to consider. Errors unfortunetly creep into databases no matter how many precautions are taken. Big banks having the most robust database make many errors over time. You just need to accept this is part and parcel of the database world unless your in denial ofcourse. Recently some software changes caused one of our databases to have errors since November 2008 hence over 7 months. Although it was eailsy fixed with a simply query this may not have been the case if the software bug was more major. Anyway back to the point, I break up the backup procedure into three parts Daily or Weekly , Monthly, Yearly.
a) Schedule once Daily/Weekly: Files 3 days old will be removed only if the last backup was successful. (hence 2 backups are kept in same directory.) Directory file://dbserver/SQL.2008/Archives/DB/Daily If your database is used weekly then change the directory to a weekly one instead of daily.
b) Schedule once Monthly: Files 35 days old will be removed only if the last backup was successful. (hence 2 backups kept in same directory.) Directory file://dbserver/SQL.2008/Archives/DB/Monthly
c) Schedule once a year: Files 11 months old will be removed only if last backup was successful. (hence 1 backup kept in same directory) Directory file://dbserver/SQL.2008/Archives/DB/Yearly
Make sure you create these directories in windows explorer beforehand.
4. Log files, if the harddrive goes I need the daily backup. If the database is running 24/7 and transactions are being done daily then record the log files so you can update the database with the appropriate changes from the backup and then run the log files afterwards. If the database just get's updated once daily then you won't need log files especially if the data is stored in another file format such as XML to text files which are easy to import.
Monthly backup's are important if integrity is lost and a program needs to be re-run. I would save the last two months. anything after this will just take up disk space. A yearly backup is always handy if you think there may have been some major issue that has caused database data error over the course of the year. If you haven't noticed it by a year then clearly you need to look at your operations firstly.
STEP 2: Email reports.
When you do a backup you will want to know how it went and looking at Maintence reports although good for solving don't beat getting an email saying there is something wrong. To setup Database Mail you need to do two things first:
1. You need to create an operator. To send emails you will need to specify who to send it and SQL uses Operator which you can find in Management Studio. Just add Name and E-mail name. Net Send is for sending messages via the network. I think this would be quite annoying after a while so not worth adding.
2. Configure your Database Mail Client - Go to Database Mail under Management Studio and run the wizard. Unless you can easily setup another email account on your domain I suggest use a pre-existing one with a different email address and Display name. At the end of the day you really don't care who sends the email as long as it's sent and you can distinguish it from others.
STEP 3: Creating Maintence Plans in MSSQL Mang. Studio.
The first place to start is in Microsoft SQL Server Management Studio is "Maintence Plans". Use Maintence Plan Wizard. I would use a different plan for a different database, each database is different from each other so the maintence should be different. Select a name for your plan hence "YourDatabase Backup", I select Single schedule for the entire plan or no schedule for the moment, you can always change this later. Select Next.
In this screen I select just one item "Back Up Database (Full)" the reason is I want to extend this later with Success and Failure Constraints linked between each task. Press Next, Next to come to Define your Backup Database (Full) Task. This backup will be for Daily backup select your database you need again I recommend doing one database at a time.
For Daily backups I make the database expire after 3 days. Really I only want to keep two daily backups, if you have a 30-40GB database you don't want too many of these otherwise it won't be too long before you run out of space. I select "Create a backup file for every database" however I don't use sub directories, I want to keep this simple as possible. In the folder part use file://dbserver/SQL.2008/Archives/DB/Daily
The backup file extension should be "bak".
I always click "Verify backup integrity" it doesn't take long to run. Depending on your version of SQL you maybe able to change the compression however untill your sorted and using your first plan I would just leave this as a default.
Always create a report which you should email to your operator you sepcified. There is host of information in these reports so definietly keep them and send them to yourself. This is different to the notfiy reports that you will be sending later.
STEP 4: Adding additional functionality to your Plan
Once done the plan should appear under the Maintence Plans folder. Right click and then select Modify. Here is when you start changing things, firstly change the name "SubPlan_1" to something meaningful like "YourDatabase_Daily_Backup_Plan". Also click the schedule or the calender to specify when to run it. Since it's daily backup once a day during non-peek times is the best. For database that change a few times only in a week you need to think when you want to have copy. Remember if something goes wrong you want the easiest process to get the latest backup.
Once you have done this you want cleanup old backup files. You can easily add this by adding the "Maintence Cleanup Task" on the left and drag it to the right. You will need to modify it so it deletes only files from the daily directory and is 3 days old. *** I had huge problems at this part, in the end I realized that the NTService didn't have premission to delete the file from the directory. So make sure you have premission..I was able to test this by doing the following command to delete the file directly:
EXECUTE master.dbo.xp_delete_file 0,N'D:\SQL.2008\Archives\Db\Daily\Db1_backup_2009_06_16_191120_2202108.bak'
GO
Initially I was getting Access Denied Error 5 message. It was only solved when I allowed the permission for the profile to have full access to that directory in Windows Explorer, then everything fell in place after that.
Now you should link these together, you will notice a green arrow these are called "Constraints" . You should extend this so if Backup was successful it will then delete old backup files. You don't want to be deleting old backup if a new backups are not working. Now you want to notify a person by email if anything has gone wrong so drag "Notify Operator Task" on to the screen. You should then modify this to include an operator to email. Then select the Backup again and a new small green arrow should appear out of the box extend this to point to the new Notify Operator Task you have just done. If you right click the line you will see a few options: Success, Failure and Completion. What you would like to do is change this to Failure and the arrow should turn red. You can extend this to include several other opertaions. Below a sample of what the plan should look like if you have done it correctly:
STEP 5:
You can add some additional items to keep your database in good order, Shrink Database, Rebuild Index Task, Update Statistics Task, History Cleanup Task. All these help the smooth running of your database. I suggest trying them out and seeing what effect it has on your system.
Your pretty much done for the daily backup.
STEP 6: Monthly and Yearly backups
To do this I recommend keeping it in the same plan, everything in the same place makes sense. To do this easily just simply add an another sub_plan by clicking "Add Subplan" at the top left hand corner. Name this "Monthly_Backup_Plan" and it should appear as new row below "Daily_Backup_Plan". You could just drag the "Back Up Database Task" from the left and reconfigure everything but I cheat by copying the Daily one and then just paste it on the Monthly one. You will need to edit some of the options such as when Backup will expire to 35 days and the directory to ..\Monthly.
The rest is pretty much repeated from Step 4. for both Monthly and Yearly.
Subscribe to:
Posts (Atom)