PowerShell Server: Unable to execute Virtual Box commands.

Problem Description

When attempting to manage Virtual Box VMs from the PowerShell Server prompt, the user may see the following error:

.\VBoxManage.exe : VBoxManage.exe: error: Could not find a registered machine named 'CentOS-6.4-i386-Gnome' At line:1 char:1 + .\VBoxManage.exe startvm CentOS-6.4-i386-Gnome + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + CategoryInfo : NotSpecified: (VBoxManage.exe:...6.4-i386-Gnome' :String) [], RemoteException + FullyQualifiedErrorId : NativeCommandError VBoxManage.exe: error: Details: code VBOX_E_OBJECT_NOT_FOUND (0x80bb0001), component VirtualBox, interface IVirtualBox, callee IUnknown VBoxManage.exe: error: Context: "FindMachine(Bstr(pszVM).raw(), machine.asOutParam())" at line 575 of file VBoxManageMisc.cpp

Cause

There appears to be an issue with the sharing of Virtual Box’s internal registry of VMs in remote sessions. Due to this issue, any VMs previously registered in a local session or another remote session are not recognized as registered VMs.

Solution

The solution to this issue is quite simple. All that is needed is to register the VM in the PowerShell Server session. Once this is done you will again be able to manage the Virtual Box VM. Please see the example below:

PS> .\vboxmanage.exe registervm "C:\Users\myUser\VirtualBox VMs\test\test.vbox" PS> .\vboxmanage.exe startvm test --type headless

Note: When registering the VM, the user must specify the full path to the VM’s .vbox file.

Note 2: The “–type headless” parameter in the Start VM command indicates that the VM will be started silently with no user interaction. See: VirtualBox Manual: vboxmanage startvn

We appreciate your feedback.  If you have any questions, comments, or suggestions about this article please contact our support team at kb@nsoftware.com.