Home SQL Compliance Manager SQL SERVER – Introduction to Log Space Usage DMV – sys.dm_db_log_space_usage

SQL SERVER – Introduction to Log Space Usage DMV – sys.dm_db_log_space_usage


It has been quite a while since SQL Server 2017 has been introduced, however just recently I have been seeing interest for this project. Lots of users are just switching to SQL Server 2017 and I believe that is normal. In the year 2017 during my Comprehensive Database Performance Health Check, I encountered mostly SQL Server 2014 and SQL Server 2016. Recently, during the consultancy, I received a very interesting question about log space.

SQL SERVER - Introduction to Log Space Usage DMV - sys.dm_db_log_space_usage dm_db_log_space_usage1-800x319

DBAs at my customers place wanted to know more about their log file. Though they had kept the log file in Simple Recovery mode, the issue which they were facing was they were not sure when exactly to take backup of the log file. They often observed that in the same interval their log file was growing either too big or too small based on the business transactions. What they actually wanted to achieve was to take log backup as soon as there is transaction of certain amount.

As they were using SQL Server 2017, I proposed following script which exactly does what they were looking for. When you run following script in SQL Server 2017, it will give you various important information about your log file.

SELECT total_log_size_in_bytes/1048576.0 AS [Total Log Size in Bytes],
used_log_space_in_bytes/1048576.0 AS [Used Log Size in Bytes],
used_log_space_in_percent [Used Log Space in %],
(total_log_size_in_bytes - used_log_space_in_bytes)/1048576.0 AS [Free log space in MB],
log_space_in_bytes_since_last_backup/1048576.0 [Log Since Last Log Backup]
FROM sys.dm_db_log_space_usage;

When you run above script, it will give you size your log file with how much log file has been filled up and how much is empty.

SQL SERVER - Introduction to Log Space Usage DMV - sys.dm_db_log_space_usage dm_db_log_space_usage

The best part is that this script also provides you details about how much your log generated since your last log backup. This is very important information. If you want, you can read this column in your schedule job and skip taking log file backup if your generated log is below certain threshold. For example, my customer did not want to take log backup if the log file is less than 1 MB. This way they can avoid generating a less number of log files, so in case of the disaster they do not have to restore many (nearly) empty log files and delay their restore process.

You can also use above query to monitor your log space growth and also log generated since the last log backup. Please note that this script will work for any (full or simple) recovery model in SQL Server 2017. However, it will not work for version earlier than SQL Server 2017.

Reference: Pinal Dave (https://blog.sqlauthority.com)


Source link


Please enter your comment!
Please enter your name here