Virtually Painless - Using Disk2VHD to reduce time to solution

Virtually Painless - Using Disk2VHD to reduce time to solution

  • Comments 4
  • Likes

 

Hello all, happy New Year and welcome back from the holidays.

I recently worked a case involving intermittent COM+ corruption, and resetting security permissions would alleviate the issue for a period of several weeks. As I am sure you can imagine, this makes troubleshooting root cause very difficult. In cases like this where a relatively easy workaround is available, there is often pressure from above to implement the workaround and release the system back into production without root cause being determined.

For issues such as this, the Disk2VHD tool from Sysinternals may come in handy.  Simply create a virtual image of your physical server using Disk2VHD, then load the VHD under Microsoft Virtual PC or a Windows 2008 Hyper-V server.  With undo disks or snapshots enabled, you can reproduce the issue as many times as needed until root cause is determined.  At the same time, your production server can remain active while you troubleshoot it’s twin in a virtual environment.

A useful feature of the tool is that the target machine need not be offline when you are creating a VHD; in fact you may run this tool on the problem system itself, and though not recommended you may also write the VHD to a local disk that you are backing up. The tool is very simple to use and creates separate VHDs for different drives. All you need to do is select the drives you would like to be converted. I am including a snapshot below.

 

clip_image002

 

The VHDs are created in Microsoft’s Virtual Machine disk format and can be used in Microsoft Virtual PC or Microsoft Hyper-V virtual machines.

We also have the option to enable creation of VHD’s via scripts. The following command line may be used for this. Specify the volumes you want included in a snapshot by drive letter (e.g. c:) or use "*" to include all volumes.

Usage: disk2vhd <[drive: [drive:]...]|[*]> <vhdfile>

Example: disk2vhd * c:\vhd\snapshot.vhd

Here are some recommendations and known issues that you may run into while using Disk2Vhd:

1. It is not recommended to attach a VHD to the same system from which it has been created. If you do so, the operating system assigns a new disk signature to this disk to avoid collision and Windows will fail to locate the boot disk.

2. On Microsoft Virtual PC, be aware that virtual disks sized greater than 127GB are not recognized regardless of the amount of data.

3. Virtual PC also does not support multiple processors.

4. There was a known issue with the initial version of Disk2VHD that sometimes caused Windows XP and Windows Server 2003 to not boot. To mitigate this, be sure to use the latest version.

So, thanks for your time and I hope you find this information helpful.

Paras Pant

Share this post :


Your comment has been posted.   Close
Thank you, your comment requires moderation so it may take a while to appear.   Close
Leave a Comment
  • Absoluetly fantastic tool. Thank You!

  • Very good program. Thank you for information.

  • Disk2VHD does not work for me. The VHD file is created and Windows 7 virtual PC opens the VPC I build to use the VHD. The

    initial boot commences and then hangs. I can start it in safe mode, which starts listing the drivers in windows\system32\drives and hangs after IABFilt.sys. None of the other F8 boot functions work any better.

    I thought this utility was supposed to remove the hardware specific drivers from the original XP system; so that only those that are virtual PC compatible would be loaded. But that does not appear to be the case. How can I troubleshoot the VPC boot problem?

  • Hi Colin,

     It is true that the tool should remove hardware specific drivers, but not all filter drivers may be seen as hardware-specific. IABFilt.sys is an Iomega Volume Filter driver and is apparently missed during the conversion. The only thing I can think of is to remove this software from the initial install and then make the VHD from that.

    Tim