Repairing Corrupt File Systems on VMs with Repair-Volume

The other day I ran into one of the most common issues IT pros have to face, file corruption. Out of the blue, one of our clients called in reporting issues printing from their Windows Server 2008 terminal server. This was a VM, which was being hosted on a Server 2008 R2 Hyper-V Cluster. Users were not receiving their redirected printers at logon. It turned out multiple remote desktop services were repeatedly crashing. A read only Check Disk on the system volume reported evidence of corrupt system files. In order to repair the corrupt files, a Check Disk repair had to be run on the system volume which required the server to be offline. This process ended up taking over 6 hours to fully complete the repair resulting in unwanted downtime and lost productivity for the client.

Fortunately, Microsoft has made some improvements to the Check Disk utility in Windows Server 2012 reducing the downtime for offline volume repairs to seconds instead of hours. The Check Disk repair process can now also be ran through Windows PowerShell using the Repair-Volume Cmdlet.

Using the Repair-Volume Cmdlet

Windows PowerShell 4.0 introduced the Repair-Volume Cmdlet. This cmdlet is built upon the Check Disk repair feature and allows repairs to be done on volumes through PowerShell.

In order to scan the volume for corruption without attempting to repair it, open up PowerShell on the VM you’d like to scan and type the following commands. In this example we will use the C volume to scan:
Repair-Volume –driveletter c –scan
repair-volume -scan

Once the scan has completed, PowerShell will report whether or not errors were found on the volume. If there were errors found on the volume, an offline scan and fix will need to be ran in order to fix the errors. This will take the volume offline, scan for errors, and fix any errors that it finds. This will also make the volume inaccessible during the scan, so this needs to be taken into account when planning an offline scan and fix. Also, performing a scan with the –scan parameter is not needed before running an offline scan and fix. You would use the –scan parameter on a volume that you’d want to check for corruption when you can’t take it offline at the moment. In order to perform an offline scan and fix, open up PowerShell and type the following commands:
Repair-Volume –driveletter E -offlinescanandfix
repair-volume -offlinescanandfix

Once the scan and repair is complete, the volume will automatically come back online and will once again be accessible.

Running an Offline Scan and Fix on the System Volume of a Running VM

If you try to run an offline scan and fix on the system volume of a running Windows OS, you will be presented with the following message:

repair-volume -offlinescanandfix failed msg

This is because the system volume is being used to run the Windows OS and cannot be taken offline unless the OS is shut down and that volume is no longer in use. This message can be deceiving because unlike the Check Disk repair utility which gives the option to run the offline repair at the next OS boot; the repair-volume cmdlet does not give the user a choice and will automatically flag the OS to run the Scan at next boot.

Using the Spotfix Parameter

Windows Server 2012 introduced an awesome feature called Check Disk spot fix. This feature allows you to do an online scan on a volume and logs any issues to a file called $corrupt. You can then issue a spot fix repair that will reference that file and repair the logged issues without needing to scan the entire volume again. This considerably speeds up the repair process taking only seconds to take a volume offline and repair, preventing the need to hassle with long outages.

To run a spot fix repair on a volume, first run an online scan on the volume to search for any errors with the following command, in this example we will use the system volume:
Repair-volume –driveletter c –scan
After the scan is run, any issues are automatically logged in the background. You can now initiate a scan using the –Spotfix parameter:
Repair-volume –driveletter c –spotfix
repair-volume -spotfix

Since this is a system volume, just like the example above, the “failed” message will show. However, once a reboot of the OS is done, the spot fix repair will automatically initiate and repair any issues that were logged from the online scan.

Disk Repair on Multiple VMs

The repair-volume cmdlet also allows for multiple VM’s to be scanned for file system issues with just a single line. In the example below I will perform an online scan of the System volume of 3 servers using the –cimsession parameter:
Repair-Volume –driverletter c -scan –cimsession dc01,fs02,fw
repair-volume -cimsession

The online scan will run on each server and the progress of each scan will be displayed.

repair-volume -cimsession results

At the end of the scans the results of each server will be displayed. You can also scan multiple drives of multiple servers by listing all the possible drives you would like to scan.
Repair-Volume –driverletter C,D,E -scan –cimsession dc01,fs02,fw
There are many scenarios where being able to scan multiple servers at once can be beneficial. One example would be if a SAN went down hard because of a power or hardware issue. Once it was back up and fully functional, a good procedure would be to run a repair-volume scan on all the VMs residing on that storage target to check for any instances of file corruption. The repair-volume cmdlet not only allows us to be efficient, but also proactive.

 

Altaro Hyper-V Backup
Share this post

Not a DOJO Member yet?

Join thousands of other IT pros and receive a weekly roundup email with the latest content & updates!

11 thoughts on "Repairing Corrupt File Systems on VMs with Repair-Volume"

  • I have had no one problem with VM’s VHDs in my experience but this article gives me an a receipt for the future.
    Thanks, Luke!

  • I have had no one problem with VM’s VHDs in my experience but this article gives me an a receipt for the future.
    Thanks, Luke!

  • Dave says:

    Regarding this part

    “This is because the system volume is being used to run the Windows OS and cannot be taken offline unless the OS is shut down and that volume is no longer in use. This message can be deceiving because unlike the Check Disk repair utility which gives the option to run the offline repair at the next OS boot; the repair-volume cmdlet does not give the user a choice and will automatically flag the OS to run the Scan at next boot.”

    If you can’t run the scan because the O/S is on this volume, how do you scan the disk? Do you do it against the VHD file from the underlying host O/S?

    Thanks

    • Luke Orellana says:

      You would still use the -offlinescanandfix or -spotfix parameters, but just like with a regular chkdsk /f /r repair you would have to restart the OS and the scan would initiate and run automatically before start up. The normal check disk repair command will ask you yes or no if you’d like to do this or not, however, the repair-volume cmdlet will automatically do it without asking.

      You can also use the -verbose parameter to see what is going on “under the hood” while the cmdlet is running and it will make more sense. It will look somewhat like this:

      Repair-volume -offlinescanandfix -driveletter c -verbose

      Verbose: Windows can’t check the disk while it’s in use. Do you want to check for hard disk errors the next time you start your computer?
      Verbose: This volume will be checked the next time the system restarts.

  • Dave says:

    Regarding this part

    “This is because the system volume is being used to run the Windows OS and cannot be taken offline unless the OS is shut down and that volume is no longer in use. This message can be deceiving because unlike the Check Disk repair utility which gives the option to run the offline repair at the next OS boot; the repair-volume cmdlet does not give the user a choice and will automatically flag the OS to run the Scan at next boot.”

    If you can’t run the scan because the O/S is on this volume, how do you scan the disk? Do you do it against the VHD file from the underlying host O/S?

    Thanks

  • Randy Bennett says:

    I read you blog re: Repairing Corrupt File Systems on VMs with Repair-Volume. Have you any insight as to how to repair the volume on an ISCSI volume attached to Windows server 2019?
    I have a Buffalo Terastation 7000 series NAS configured as a ISCSI volume attached to my Windows server 2019 through ISCSI initiator. The Windows server is reporting the volume is corrupt and needs offline scan and repair completed. I have never ran this utility before and do not know if windows will be able to repair the offline volume since it is not actually part of the server but simply attached. I cannot complete a full backup of the NAS anymore because of this issue and users are now reporting corruption in data files. So I need to get this fixed.
    Any insight on how to repair the volume?

  • John says:

    Repair-Volume : No MSFT_Volume objects found with property ‘DriveLetter’ equal to ‘C’. Verify the value of the property and
    retry.
    At line:1 char:1
    Repair-Volume -DriveLetter C -scan
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    CategoryInfo : ObjectNotFound: (C:Char) [Repair-Volume], CimJobException
    FullyQualifiedErrorId : CmdletizationQuery_NotFound_DriveLetter,Repair-Volume

    • Hi John,

      This error is indicating that PowerShell cannot find a drive letter of C. Are you running PowerShell with administrative privileges? That’s where I would look first. Thanks!

Leave a comment or ask a question

Your email address will not be published. Required fields are marked *

Your email address will not be published. Required fields are marked *

Notify me of follow-up replies via email

Yes, I would like to receive new blog posts by email

What is the color of grass?

Please note: If you’re not already a member on the Dojo Forums you will create a new account and receive an activation email.