HADR_DB_COMMAND SQL Server Wait Type

Wait Type HADR_DB_COMMAND

The wait type HADR_DB_COMMAND is ranked #170 by Stedman Solutions and Database Health Monitor.

Wait statistics, in the context of SQL Server, refer to the amount of time that a query spends waiting to access data in the database. When a client application requests data from the database, the request is placed in a queue and the client application must wait for its turn to access the data. The time that the query spends waiting is called a "wait" and is tracked by SQL Server. This information can be used to identify potential performance bottlenecks and optimize the performance of the database. Wait statistics are commonly used by database administrators to diagnose and troubleshoot performance issues in SQL Server.


SQL Server wait types help administrators identify where processes might be delayed. The HADR_DB_COMMAND wait type is specific to Always On Availability Groups. It occurs when SQL Server is waiting to perform a database-related command as part of the high availability and disaster recovery (HADR) process. In this blog post, we’ll explain what the HADR_DB_COMMAND wait type means, when it appears, and how to address it.

What Is the HADR_DB_COMMAND Wait Type?

The HADR_DB_COMMAND wait type occurs when SQL Server is waiting to execute a command that involves synchronizing or managing a database in an Always On Availability Group. This could involve tasks like committing changes, synchronizing log records, or managing metadata for databases in the Availability Group.

This wait type typically reflects coordination between the primary replica and its secondary replicas to maintain data consistency and ensure failover readiness.

When Does HADR_DB_COMMAND Appear?

HADR_DB_COMMAND waits typically occur in environments using Always On Availability Groups. Scenarios where this wait type may appear include:

  • Log Synchronization – When SQL Server is synchronizing transaction log records between the primary and secondary replicas.
  • Metadata Updates – When database-level metadata is being updated as part of HADR operations.
  • High-Concurrency Workloads – Environments with frequent updates or writes to databases in the Availability Group.

These waits are a normal part of Always On operations but can signal potential issues if they occur frequently or for long periods.

Why HADR_DB_COMMAND Waits Matter

While some HADR_DB_COMMAND waits are expected, excessive or prolonged waits can indicate performance bottlenecks that may affect your Availability Group’s performance and reliability. Common causes of prolonged waits include:

  • Slow Network Connectivity – Delays in communication between the primary and secondary replicas can increase wait times.
  • Storage Performance Issues – Slow disk I/O on either the primary or secondary replicas can delay synchronization.
  • Heavy Workloads – High transaction volumes on the primary replica can overwhelm synchronization processes.
  • Replica Configuration Issues – Misconfigured secondary replicas or outdated hardware can slow down HADR operations.

How to Address HADR_DB_COMMAND Waits

If HADR_DB_COMMAND waits are affecting performance, consider these strategies to reduce them:

  • Optimize Network Performance – Ensure low latency and high bandwidth connections between replicas. Consider dedicated network links for HADR traffic.
  • Upgrade Storage Performance – Use high-speed storage solutions, such as SSDs, to reduce delays in writing transaction logs and synchronizing data.
  • Monitor Workloads – Analyze transaction volumes and consider spreading write-heavy workloads across databases not in Availability Groups.
  • Check Replica Health – Verify that all replicas are functioning properly and that their resources (CPU, memory, and disk) are not overutilized.
  • Review Synchronization Mode – If using synchronous commit, consider switching to asynchronous commit for less critical replicas to reduce synchronization overhead.

Monitoring HADR_DB_COMMAND Waits

To monitor HADR_DB_COMMAND waits, use SQL Server’s sys.dm_os_wait_stats to analyze wait statistics. Additionally, the Always On Dashboard and views like sys.dm_hadr_availability_replica_states can provide valuable insights into replica health and synchronization performance.

Conclusion

The HADR_DB_COMMAND wait type in SQL Server is a normal part of managing databases in Always On Availability Groups. While these waits are expected, excessive or prolonged waits may indicate network, storage, or configuration issues. By optimizing network and storage performance, monitoring workloads, and ensuring proper configuration, you can reduce HADR_DB_COMMAND waits and ensure efficient HADR operations.

For expert assistance with Always On Availability Groups, performance tuning, or resolving wait types, Stedman Solutions offers managed services to help you maintain a reliable and efficient SQL Server environment.


Find out more about our SQL Server Managed Services

Applies to

    Related Waits

    HADR_AG_MUTEX
    HADR_AR_CRITICAL_SECTION_ENTRY
    HADR_AR_MANAGER_MUTEX
    HADR_AR_UNLOAD_COMPLETED
    HADR_ARCONTROLLER_NOTIFICATIONS_SUBSCRIBER_LIST
    HADR_BACKUP_BULK_LOCK
    HADR_BACKUP_QUEUE
    HADR_CLUSAPI_CALL
    HADR_COMPRESSED_CACHE_SYNC
    HADR_CONNECTIVITY_INFO
    HADR_DATABASE_FLOW_CONTROL
    HADR_DATABASE_VERSIONING_STATE
    HADR_DATABASE_WAIT_FOR_RESTART
    HADR_DATABASE_WAIT_FOR_TRANSITION_TO_VERSIONING
    HADR_DB_OP_COMPLETION_SYNC
    HADR_DB_OP_START_SYNC
    HADR_DBR_SUBSCRIBER
    HADR_DBR_SUBSCRIBER_FILTER_LIST
    HADR_DBSEEDING
    HADR_DBSEEDING_LIST
    HADR_DBSTATECHANGE_SYNC
    HADR_FABRIC_CALLBACK
    HADR_FILESTREAM_BLOCK_FLUSH
    HADR_FILESTREAM_FILE_CLOSE
    HADR_FILESTREAM_FILE_REQUEST
    HADR_FILESTREAM_IOMGR
    HADR_FILESTREAM_MANAGER
    HADR_GROUP_COMMIT
    HADR_LOGCAPTURE_SYNC
    HADR_LOGCAPTURE_WAIT
    HADR_LOGPROGRESS_SYNC
    HADR_NOTIFICATION_DEQUEUE
    HADR_NOTIFICATION_WORKER_EXCLUSIVE_ACCESS
    HADR_NOTIFICATION_WORKER_STARTUP_SYNC
    HADR_NOTIFICATION_WORKER_TERMINATION_SYNC
    HADR_PARTNER_SYNC
    HADR_READ_ALL_NETWORKS
    HADR_RECOVERY_WAIT_FOR_CONNECTION
    HADR_RECOVERY_WAIT_FOR_UNDO
    HADR_REPLICAINFO_SYNC
    HADR_SYNC_COMMIT
    HADR_SYNCHRONIZING_THROTTLE
    HADR_TDS_LISTENER_SYNC
    HADR_TDS_LISTENER_SYNC_PROCESSING
    HADR_TIMER_TASK
    HADR_TRANSPORT_DBRLIST
    HADR_TRANSPORT_FLOW_CONTROL
    HADR_TRANSPORT_SESSION
    HADR_WORK_POOL
    HADR_WORK_QUEUE
    HADR_XRF_STACK_ACCESS

    See Also


    All Wait Types
    HADR_DB_COMMAND SQL Server Wait Type