Every SQL Server instance relies on tempdb as its universal scratch pad. When one poorly-written report or maintenance job floods that database with temporary objects, the entire server can stall or even go offline. SQL Server 2025 finally gives database administrators a precise brake pedal: TempDB Space Resource Governance, an extension to Resource Governor that lets you cap how much tempdb space each workload can consume.
Category: Memory
Optimizing SQL Server with Indirect Checkpoints and Target Recovery Time
A checkpoint is a background process that writes dirty pages to disk. A checkpoint performs a full scan of the pages in the buffer pool, lists all the dirty pages that are yet to be written to disk, and finally writes those pages to disk. In SQL instances that do not have many dirty pages in the buffer pool, this is a trivial operation. However, with SQL instances that have OLTP databases, use more memory and/or involve sequential scanning of all pages, the performance of the system could be impacted.
SQL Server 2019 and the Memory Grant
When SQL Server runs a query, it needs memory for operations like sorting and joining data. It also relies on memory during query compilation to hold intermediate plans while the Query Optimizer finds the best execution strategy. In parallel processing scenarios, the memory requirement grows even further. SQL Server manages this by pre-allocating memory for each query through the SQL Server Operating System (SQLOS). This process ensures that no single query can monopolize the server’s memory
Monitoring SQL Server on Linux with Native Linux Tools
As organizations deploy SQL Server on Linux, leveraging native Linux tools for monitoring becomes essential to ensure optimal performance and reliability. Tools like htop, vmstat, and iostat provide valuable insights into system resources and help identify potential bottlenecks. This blog explores how to use these native Linux tools to monitor SQL Server effectively.
Understanding the Importance of Bucket Counts in Hash Indexes for Memory-Optimized Tables
In the realm of memory-optimized tables, every table must have at least one index to connect its rows. Notably, every index on such tables is also memory-optimized. Among the various types of indexes available, hash indexes stand out for their unique structure and functionality. Understanding the importance of bucket counts in hash indexes for memory-optimized tables is crucial for maintaining optimal performance in SQL Server. This post looks at the structure of hash indexes, how to specify and adjust bucket counts, and the consequences of incorrect bucket counts. Learn best practices for planning and optimizing your hash indexes to ensure efficient data management and avoid common performance pitfalls.
Understanding In-Memory Tables with Always On in SQL Server
In today’s dynamic database management landscape, achieving high performance and reliability is paramount. SQL Server’s Always On availability groups offer a robust framework for high availability and disaster recovery. When combined with the power of in-memory tables, the capabilities of your SQL Server deployment are significantly amplified. This blog explores the benefits of using in-memory tables with Always On availability groups and demonstrates how these technologies can work together to optimize performance and ensure reliability in your SQL Server environment.
Understanding and Diagnosing SQL Server Wait Types
In SQL Server, wait types are important indicators of where and why delays occur during query execution, directly impacting database performance. Properly understanding and diagnosing these wait types enable database administrators to pinpoint specific performance bottlenecks. This blog post aims to provide an overview of essential wait types that demand attention, distinguish common wait types that can usually be ignored, and offer strategies for effective diagnosis and interpretation to enhance overall database performance.
Mastering Resource Governance for SQL Server Agent Jobs
Have you ever found yourself in a situation where certain SQL Server Agent jobs are taking up more than their fair share of CPU resources? It’s a common scenario in the world of database management, where jobs essential to your database’s functionality end up hogging the limelight, so to speak. The Resource Governor (RG) is a powerful tool in SQL Server’s arsenal, designed to help you manage these situations. However, applying it effectively, especially to SQL Agent jobs, can be a bit tricky. This blog dives deep into the mechanics of Resource Governor and offers practical advice on managing your SQL Agent jobs efficiently.
Row Mode Memory Grant Feedback in SQL Server: A Technical Overview
Understanding memory grants is important for ensuring SQL Server queries run efficiently, as they play a pivotal role in allocating temporary storage for data operations like sorting and joining. By analyzing how SQL Server calculates these grants and the impact of new features like Row Mode Memory Grant Feedback, database administrators can significantly enhance system performance. This blog delves into the mechanisms of memory allocation for query execution, the challenges it presents, and the operational benefits of leveraging advanced SQL Server functionalities to optimize resource utilization.
Optimizing SQL Server Performance on Linux: Beyond the Basics
Following our initial exploration of installing SQL Server on Ubuntu 22.04, we delve into the intricacies of advanced configuration on Linux. This post aims to provide DBAs and system administrators with a better understanding of the configurations specific to Linux environments that enhance SQL Server performance. Configuring SQL Server on Linux requires consideration of both SQL Server-specific settings and Linux system configurations. Here we’ll discuss the adjustments and settings unique to the Linux environment.