Recovering and Validating Data After Unexpected SQL Server Failovers by info.odysseyx@gmail.com August 12, 2024 written by info.odysseyx@gmail.com August 12, 2024 0 comment 3 views 3 In SQL Server environments, including on-premises, Azure SQL Database, or SQL Managed Instance, an unexpected failover can cause Availability Group roles to become out of sync. In such cases, if the original primary replica encounters an issue while the new primary replica takes over and transactions are in progress or uncommitted, data inconsistencies can occur. To recover or verify data loss, it is essential to resynchronize or verify the new primary replica with the old primary replica as soon as it comes back online. This ensures that any lost transactions are reconciled. If critical data is missing during the failover, it must be recovered and merged to maintain database consistency. This blog explains the steps to recover or verify data loss using SQL Server Database Compare Utility. To simulate this situation with a SQL Server Box product, I set up two SQL Server VMs in the same subnet, turned on Always-On HA for both instances, restored a simplified WideWorldImportersDW (WWIDW) database, and put it in full recovery mode. After creating the necessary certificates and logins/users for a domain-less availability group (AG), I created an asynchronous commit AG (it had to be asynchronous, as a synchronous AG cannot simulate transaction loss). Using a trading simulator, many trades per second were performed on the underlying database. During this activity, the primary instance was stopped, resulting in a group of committed transactions that were not replicated to the secondary instance. The goal of this post is to recover the missing transactions. After stopping sql1, SSMS can no longer connect to sql1 to update its status, so you need to open the dashboard on sql2. When you open the Failover Wizard, you will be warned about data loss. The wizard wants to inform the user that data loss may occur. Click to see results: The sql2 dashboard displays the current cluster status. To capture a new default state: Create a database snapshot immediatelyIdeally, before opening a new application connection: (In this case, the transaction is not logged to sql2 because we used sql1 instead of sqlistener in the transaction simulator.) Restart the sql1 instance. If you refresh, you will see that the old primary instance is now in an Out of Sync/Recovering state. Create a database snapshot on the previous primary (sql1). ~ before Making the existing basics secondary (Otherwise, the missing transactions will be lost when the previous primary transaction is synchronized to the secondary transaction.🙁 At this point, you can resume data movement to make the former primary database a secondary database. It takes one minute for the old primary node to roll back the lost transactions and resynchronize with the new primary node, which must now become a sync secondary node. SQL Server Database Compare is now available.SSDC (Threaded Code)) Application to check if transactions are lost between snapshots of new primary (sql2 – source) and snapshots of old primary (sql1 – target). See SSDBC documentation for setup instructions. In this case, there are 313 hash differences (updates) and 423 missing (inserts) rows. Note that there are no unreplicated deletes due to the timing of the simulated transaction cascade deletes (when the configured percentage is exceeded, deletes stop until inserts/updates catch up): If you look in the SSDBC folder in My Documents, there is a SQL script file for each table in the database, with a number in front of it to indicate the order in which they are executed (based on foreign key references). If your database has DRI configured, you may need to combine the scripts if the referenced table has an identity column and the Capture Identity Values option is turned on. In the same folder, there is a log file with more details about the comparison. When you open one of the files, you will see update and insert statements. The update statement is written as safely as possible by checking (using additional conditions in the where clause) that the column values have not been changed subsequently in the new primary. If you run all the change scripts for WWIDW on sql2, then re-run the SSDBC on WWIDW on sql2 (not a snapshot) and the sql1 snapshot, you will see that the databases are now identical (this only works on a static new primary). We can also use: tablediff utility or SSDT Generate a difference script. The SSDBC download package includes a PowerShell script that makes it easy to run comparison operations on multiple servers/databases, built from an Excel workbook. You can list the source and target servers and databases in the provided Servers.xlsx workbook and run the BulkDatabaseRecovery.ps1 script. Please contact us if you have any feedback or suggestions to improve this team asset. Azure Databases SQL Customer Success Engineering Team. Thank you for your support! Source link Share 0 FacebookTwitterPinterestEmail info.odysseyx@gmail.com previous post Exciting Junior Research Fellow Opportunities at Government Engineering College Thrissur, Thrissur next post Introducing Drag and Drop to Reorder Items in Microsoft Lists You may also like Azure API Management Circuit Breaker and Load Balancing September 10, 2024 Microsoft at Open Source Summit Europe 2024 September 9, 2024 LLM Load Testing on Azure (Serverless or Managed-Compute) September 9, 2024 Day zero support for iOS/iPadOS 18 and macOS 15 September 9, 2024 Oracle Database@Azure, Microsoft Fabric, GoldenGate, Oracle September 9, 2024 Oracle Database@Azure, Australia east, Oracle, Azure, Data, AI September 9, 2024 Leave a Comment Cancel Reply Save my name, email, and website in this browser for the next time I comment.