Prerequisites
1. Backup File: Ensure you have a valid full backup of the database you want to restore. I used AdventureWorks2019.bak for my test.
2. Availability Group Configuration: Ensure the SQL Server instances are configured in an Always On Availability Group.
data:image/s3,"s3://crabby-images/b0f54/b0f54ce6018d9efe64abff65fb93b70c6276054b" alt="sql sql"
3. Permissions: Ensure you have the necessary permissions to perform the restore operations.
Steps to Restore the Database
1. Restore the Database on the Primary Replica: First connect to the Primary Replica using SSMS, then right-click on the databases and click Restore Database
data:image/s3,"s3://crabby-images/2a172/2a172aafa86243862a608c7e7a179fd1a2259c1f" alt="sql2 sql2"
Then select the backup file for doing the restore operation.
data:image/s3,"s3://crabby-images/a61a8/a61a82fa7995539ecb58ecfa327b1298666137de" alt="sql3 sql3"
If you want to relocate the restored file to another path use the File tab in the restore database.
data:image/s3,"s3://crabby-images/5e29b/5e29b5bcae7b953bcfbc6c0cdcaebbd8fb6b0c84" alt="sql4 sql4"
In the options select “RESTORE WITH RECOVERY”
data:image/s3,"s3://crabby-images/342ac/342ac02eee033067cbfc07a0aaf3308a0dc38d30" alt="sql5 sql5"
Click “OK”
data:image/s3,"s3://crabby-images/7237e/7237effd90a34068cffdda9b9c2d2a0905b77765" alt="sql6 sql6"
2. Take a full backup from this restored database in the primary replica: Right-click on the database AdventureWorks2019 => Task => Back Up
data:image/s3,"s3://crabby-images/a5cd4/a5cd49811519d2f066aefd7abef94a6a3af49349" alt="sql7 sql7"
Select the Full backup type, specify the path for the backup file, and click “OK.”
data:image/s3,"s3://crabby-images/fd2cd/fd2cdf8418ce425ca44a46bf5ad7858ea26ad779" alt="sql8 sql8"
3. Take Transaction Log backup from the Primary Database: Right-click on the database AdventureWorks2019 => Task => Back Up
data:image/s3,"s3://crabby-images/ddf74/ddf7477582f595b7c1615de40a2e59ca600ea02f" alt="sql9 sql9"
Select the Transaction log backup type, specify the path for the backup file, and click “OK.”
data:image/s3,"s3://crabby-images/648fc/648fc9ff33930684abc76e9e00add65de1846706" alt="sql10 sql10"
Now, we have the following files and should copy them to the Secondary Replica.
data:image/s3,"s3://crabby-images/432dc/432dc0e12634b6ebe7c6614498719ec9a38986a9" alt="sql11 sql11"
4. Restore all the backups (Full and Transaction Log) in the Secondary Replica: Right-click on the databases and choose Restore Database
data:image/s3,"s3://crabby-images/87237/87237f9435795b9d0e928aecc413e77429822ee2" alt="sql12 sql12"
Select both files (Full and Transaction Log) for doing the restore operation
data:image/s3,"s3://crabby-images/af094/af094861ca4e6f48bf9bd1fa209d7b1cc835a235" alt="sql13 sql13"
data:image/s3,"s3://crabby-images/9c0a2/9c0a256a68ab7e44a0fa8a697762038c9ff0236f" alt="sql14 sql14"
NOTE: In the secondary replica you must “RESTORE WITH NORECOVERY” to put your database in a recovery state for adding it to the availability group.
data:image/s3,"s3://crabby-images/27178/271789d1f0e7d71400efa9c8dc954bbe0199a593" alt="sql15 sql15"
Click “OK”
data:image/s3,"s3://crabby-images/e51c7/e51c72f4713e76197c87038fc76e201068e1813b" alt="sql16 sql16"
Now if we connect to the secondary replica we can see that the AdventureWorks2019 database is restored.
data:image/s3,"s3://crabby-images/e8645/e864593bfd8f75ebf0bf05158cbe0a90e320e2f0" alt="sql17 sql17"
5. Adding the Database to the Availability Group: Once the restore is complete on the primary and secondary replicas, we can add the database to the Availability Group.
In the primary replica right-click on the Availability Database => Add Database.
data:image/s3,"s3://crabby-images/5dea6/5dea625582eeb5fd01175a83ad4dbd6596845372" alt="sql18 sql18"
Now, you can see that we cannot add the AdventureWorks2019 to the Availability databases because the database is not in the Full Recovery Model.
data:image/s3,"s3://crabby-images/98305/9830568b6b50c0955f0d3c104ef791ba1821e11d" alt="sql19 sql19"
Therefore, we must put the database (on primary replica) in full recovery mode.
Right-click on the AdventureWorks2019 database and select the properties.
data:image/s3,"s3://crabby-images/d7a9d/d7a9d7fb7fb0504d96ea36aeb46a358b10360cc0" alt="sql20 sql20"
Go to options and change Recovery Model to Full.
data:image/s3,"s3://crabby-images/2b498/2b498e3d5eac8a3acf7425c3d6f8c01fb7c8513e" alt="sql21 sql21"
Now we can add this DB to the Availability Group
data:image/s3,"s3://crabby-images/d7c2c/d7c2ce3c9f3c30eac114986f29f19731f7869385" alt="sql22 sql22"
Connect to the Second Node
data:image/s3,"s3://crabby-images/e1a88/e1a88762a327195a035b234be77ba4eb17ebc670" alt="sql23 sql23"
Because we already restored the database on other replicas, I selected the join-only option.
data:image/s3,"s3://crabby-images/0aac5/0aac5d19424e94daff9215e16d4976664ec54d75" alt="sql24 sql24"
Click “Next”
data:image/s3,"s3://crabby-images/56a8e/56a8e77cb3a0a729c539c88583fbf7d0e444a751" alt="sql25 sql25"
Click “Finish”
data:image/s3,"s3://crabby-images/a6554/a65544a6a415a107d639b407f2ae94c0dcf4759d" alt="sql26 sql26"
Click “Close”
data:image/s3,"s3://crabby-images/aef4b/aef4bdf9cfcd5f3c4472e15d3f4fb610e36dfd8b" alt="sql27 sql27"
6. Verify the Database Synchronization: Check the synchronization state of the database on all replicas to ensure everything is working correctly.
You can see that this database exists in both primary and secondary replica availability databases.
data:image/s3,"s3://crabby-images/5e40a/5e40abf325ffc9d7b6d184fe67e2a0f9a6b41ce5" alt="sql28 sql28"
TO Verify the Database Synchronization you can right-click on the availability group and select Show Dashboard.
data:image/s3,"s3://crabby-images/363f7/363f7b7ae547cb89f403372c4ada39cb172428bc" alt="sql29 sql29"
OR you can use the following query.
SELECT ag.name AS AvailabilityGroupName,
ar.replica_server_name AS ReplicaServerName,
drs.database_id,
db.name AS DatabaseName,
drs.synchronization_state_desc AS SynchronizationState
FROM sys.availability_groups ag
JOIN sys.availability_replicas ar ON ag.group_id = ar.group_id
JOIN sys.dm_hadr_availability_replica_states ars ON ar.replica_id = ars.replica_id
JOIN sys.dm_hadr_database_replica_states drs ON ar.replica_id = drs.replica_id
JOIN sys.databases db ON drs.database_id = db.database_id
WHERE db.name = 'AdventureWorks2019';
data:image/s3,"s3://crabby-images/f3726/f37264ce95c7900c81d84e004085e33f220f9612" alt="sql30 sql30"