In 2015, Paul Cunningham wrote about this topic. Time marches on, and new versions of Exchange Server mean that it’s good to review the current position up to and including Exchange 2019.

As time goes by, Exchange mailbox databases continue to grow. Mailboxes are added, users continue to send and receive email messages, the average message size increases, and users tend to keep all their email. At the same time, users delete messages, and Exchange administrators remove mailboxes when users leave the company. Unfortunately, Exchange mailbox databases don’t shrink.

Available New Mailbox Space

When individual items or complete mailboxes are removed, the space occupied by deleted items becomes available in the mailbox databases once their retention time lapses. This is called “available new mailbox space,” but is often referred to as “white space.” Over time, “available new mailbox space” can become significant in terms of overall database size.

To retrieve the available new mailbox space for a mailbox database, use the Get-MailboxDatabase cmdlet with the -Status option:

Get-MailboxDatabase -Status | Select-Object Name, DatabaseSize, AvailableNewMailboxSpace | Format-Table -AutoSize

Name   DatabaseSize                       AvailableNewMailboxSpace

----   ------------                       ------------------------

DB01   553.9 GB (594,718,752,768 bytes)   381.4 MB (399,966,208 bytes)

DB02   606.1 GB (650,821,763,072 bytes)   294.6 MB (308,903,936 bytes)

DB03   508.1 GB (545,596,112,896 bytes)   4.519 GB (4,851,990,528 bytes)

DB04   183.8 GB (197,300,060,160 bytes)   333.2 MB (349,339,648 bytes)

DB05   787 GB (845,034,815,488 bytes)     146.1 MB (153,223,168 bytes)

Note. Besides the available new mailbox space, the -Status option can also return information regarding the following attributes:

  • BackupInProgress – When a mailbox database is backed up, information regarding the backup is written in the header of the mailbox database. This information is only available offline using the ESEUTIL utility. When a backup is in progress, this information is available using this option.
  • Mounted – Returns the status of a mailbox database, similar to the Get-MailboxDatabaseCopyStatus cmdlet.
  • OnlineMaintenanceInProgress – Online maintenance is a background process that optimizes a mailbox database. It removes mailbox items and mailboxes that are past their retention, and it optimizes the available new mailbox space.

All three options return either FALSE or TRUE.

To get a more readable output that is also usable for reporting, I convert it to GB or MB, or both:

Get-MailboxDatabase -Status | Sort-Object name | Select-Object name,@{Name='DB Size (Mb)';Expression={$_.DatabaseSize.ToGb()}

},@{Name='Available New Mbx Space Mb)';Expression={$_.AvailableNewMailboxSpace.ToMb()}}

Name   DB Size (Gb) Available New Mbx Space Mb)

----   ------------ ---------------------------

DB01               554                         381

DB02               606                         294

DB03               508                        4627

DB04               184                         333

DB05               787                         146

Now you know the available space in the mailbox databases. In the list above, mailbox database DB03 can host a lot of new items before it grows.

Disk Full Scenarios

Exchange mailbox databases do not shrink automatically, i.e. they won’t get any smaller and return the available space to the operating system. The only way to reclaim space from a mailbox database is by creating a new mailbox database and moving all the mailboxes to the new mailbox database. Only the mailboxes will be moved to the new mailbox database, not the available new mailbox space. Suppose you have a 250 GB mailbox database, there is 200 GB of mailbox data in this mailbox database, and 50 GB available new mailbox space. Ather moving mailboxes to this new mailbox database, it will be 200 GB in size, and 50 GB will be returned to the operating system.

A common concern I hear a lot is about the Exchange Server standard edition, which can host 5 mailbox databases. When 5 mailbox databases are running, there’s no option to create a new mailbox database to reclaim the available new mailbox space.

There are a couple of options available in this situation:

  • If you run virtualized Exchange servers, you can extend the disks to accommodate larger mailbox databases. You must, however, think about backup and restore times. Restoring large mailbox databases can take a long time.
  • If you run an Exchange server in a Database Availability Group (DAG), you can remove one mailbox database copy, create a new mailbox database, and move all mailboxes to this new mailbox database and create a new copy.
  • Upgrade to Exchange server Enterprise Edition (which supports up to 100 databases on a server), create a new mailbox database, and move mailboxes to the new mailbox database, assuming you have additional disks available.
  • Offload mailboxes from the mailbox database you want to reclaim to Exchange Online. When this mailbox database is empty, remove it, create a new one, and redistribute some mailboxes to the mailbox database that you just created.
  • If all other options are not feasible, you can take the mailbox database offline and use the ESEUTIL tool to perform an offline defragmentation. But this is a last resort, and you should make sure you know what you are doing. If you are in doubt, create a ticket at Microsoft Support. I have seen too many admins run into troubles because they didn’t understand in advance what to expect.

Moving Forward

All these options take some time and planning, and you must ask yourself how you ended up in this situation. My best guess would be a lack of monitoring, but I don’t want to judge your situation.

It’s natural for mailbox databases to grow over time, and if you don’t pay attention, your mailbox databases will expand and become too big. This can result in your server running out of disk space. You can check the amount of available new mailbox space to see if you have any ‘white space’ left inside a mailbox database, but the mailbox database will not shrink automatically.

As explained above, you have multiple options to overcome this issue. In the long run, it is better to have a proper monitoring solution so that you don’t run into this issue at all.

About the Author

Jaap Wesselius

Jaap is an independent consultant based in The Netherlands. Starting with Exchange 5.0 in 1997, he has been working with Exchange for almost half of his life. After leaving Microsoft as an employee, Jaap started as an independent consultant in 2006, continuing to work with Exchange and later on with Exchange Online. Besides consulting work, Jaap is an author of several books (some coauthoring with Michel de Rooij), blogger, presenter, and these days part-time (kids leaving the house) dad. Besides working with Exchange, Jaap is also a motorcycle enthusiast, owning several motorcycles. For his work in the community, Jaap received the MVP award back in 2007, an award that was constantly re-awarded up to this day, something he is very proud of.

Comments

  1. Jaap Wesselius

    Hi Mike,
    Are you using the Exchange Management Shell or are you loading the Exchange module directly using Add-PSSnapin Microsoft.Exchange.Management.PowerShell.Snapin?
    The latter can give unexpected results since it sometimes returns information in a string, where EMS returns an object (and thus supports something like the .toMB() function.

  2. Mike Koch

    I feel like I’m missing something simple. On my Exchange 2016 server, the values returned by Get-MailboxDatabase -Status for DatabaseSize and AvailableNewMailboxSpace are strings, not integers, so attempts to convert those values to MB or GB fail because there are no tomb() or togb() methods available for strings. Using the exact same code you show above, those two fields come out blank.

    Simplified version:
    PS > $db = Get-MailboxDatabase -status
    PS > $db.databasesize
    12.13 GB (13,019,119,616 bytes)
    PS > ($db.databasesize).toMB()
    InvalidOperation: Method invocation failed because [System.String] does not contain a method named ‘toMB’.

    What am I doing wrong?

    Thanks for all your great contributions over the years! I’ve learned a lot.

Leave a Reply