I have, however, encountered a notable problem, on a reasonable sized database restore (this will depend on infrastructure but I've seen this above 100Gb) progress sits at 0% for what seems like at eternity.
In fact the timing before progress starts getting logged has seemed to be to be about how long it would take to create the file and space required and do almost all of the restore process.
I have now discovered more detail that might be useful next time I encounter the "problem" because it appears that recovery is split into 5 phases :
- Copy of data from the backup to database pages.
- Discovery
- Analysis
- Redo
- Undo
I think I will find that SQL is reporting 0% while the data is being copied back to the data files and given that this will be happening as a transaction it remains 0% until completed which explaims the behaviour being seen.
It seems that the view sys.dm_tran_database_transactions will give further detail during the undo phase and where the database_transaction_log_bytes_reserved column will show decreasing volumes for the given database.
Further, where there are several transactions to undo the database_transaction_next_undo_lsn column will provide additional detail.
 
 
No comments:
Post a Comment