IT is all about configuring and maintaining computer hardware and software to support business needs. That means you need to utilize, maximize, and capitalize on the fastest and most powerful hardware and software available. However, Murphy’s Law states, “Anything that can go wrong will go wrong.” So, to minimize downtime and impact to the business, you need a high availability (HA)/disaster recovery (DR) plan in place for the hardware and software.
In my initial series of posts for the SQL Server Pro IdeaXchange, I’ll be focusing on high availability/disaster recovery solutions for Microsoft SQL Server. I’ll explore each implementation and its pros and cons. Over the following weeks, I’ll discuss popular HA/DR solutions for SQL Server, including:
Failover Clustering
Failover clustering solution is built on Windows Server Failover Cluster (WSFC) (or Microsoft Cluster Service (MSCS)) to provide high-availability protection for SQL Server at the instance level. A failover cluster is a combination of one or more servers, either residing in the same subnet or across multiple subnets. An instance of SQL Server is installed on all nodes in the cluster group but only one server can be active at any one time. The active server takes ownership of the single shared copy of the data. If the active server experiences failure, a passive node takes over the ownership of the data and becomes active.
AlwaysOn Availability Groups
Availability Groups is a super-charged database mirroring solution where a set of user databases, known as availability databases, fail over together as a single entity. Availability Groups consist of a primary replica, where the primary databases are available for read-write from the clients; and one to eight secondary replicas, which optionally can be configured for read-only from the clients. Availability Groups requires a Windows Server Failover Clustering (WSFC) cluster and fails over at the level of an availability replica.
Database Mirroring
Database mirroring provides high availability and protection for a single user database. Database mirroring provides database availability by mirroring the transaction streams from the principal server to a mirror server.
Database mirroring operates in the following modes:
High safety mode with automatic failover – synchronous operation in which a transaction is committed on both partners, including a witness partner to coordinate automatic failover. Highly susceptible to transaction latency.
High safety mode without automatic failover – synchronous operation without a witness partner.
High performance mode – asynchronous operation in which a transaction commits without waiting for the mirror partner to write the log to disk.
Log Shipping
Log shipping is a low-cost solution that operates at the database level. A log shipping configuration includes one primary server and one or more secondary servers. Log shipping does not provide automatic failover, but involves a user-configurable interval between a transaction log backup of the primary server and when the secondary server restores the transaction log backup.
Replication
Replication is a publish-subscribe model. A replication configuration includes a primary server, referred to as the publisher, which distributes data to one or more secondary servers, referred to as subscribers.
Source:http://sqlmag.com/database-high-availability/application-high-availability-and-disaster-recovery-sql-server-part-1