When looking for a good way to deploy Nano Server on vSphere I found some guides, but they were all referring to older Tech Preview (TP) versions of Server 2016 (things have changed in the current TP5) and/or did not result in optimal state-of-the art configurations. So I decided to write up my own guide, and here it is ...
You cannot install Nano Server via a bootable setup CD like other editions of Windows Server, but it comes with its own Powershell based deployment framework. It will output a Windows WIM file or a Hyper-V virtual disk file in the old vhd or the newer vhdx format. The image needs to be converted to a VMware vmdk file, and then it needs to be uploaded to an ESXi host and attached to a newly created VM.
The following steps have been tested on a Windows 10 workstation and an ESXi 6.0 U2 host. It should also work with Windows 8.1 and ESXi 5.5 though (maybe with minor modifications).
Building the Image
1. Download the Windows Server 2016 TP5 ISO
If you have not already done so download the Windows Server 2016 Technical Preview 5 ISO file from the Microsoft Technet Evaluation Center. The requires a Microsoft account and a quick (free) registration.
2. Get the latest VMware vmxnet3 and pvscsi drivers
Download the latest VMware Tools for Windows (x64) in exe format. At the time of this writing this was version 10.0.9. Perform an administrative install of the package by calling it with the /a switch, e.g.:
VMware-tools-10.0.9-3917699-x86_64.exe /a
This will not actually install the Tools on your local system, but extract all files in a directory that you specify in the upcoming GUI:
In this example we use the directory C:\TEMP\VMTools. Make sure that C:\TEMP already exists or use another existing parent directory.
Now create a new directory C:\TEMP\Drivers and copy the extracted pvscsi and vmxnet3 drivers to there. In a command prompt run
mkdir C:\TEMP\Drivers
cd "C:\TEMP\VMTools\VMware\VMware Tools\VMware\Drivers"
copy pvscsi\*.* C:\TEMP\Drivers
copy vmxnet3\NDIS6\*.* C:\TEMP\Drivers
To clean up you can delete the C:\TEMP\VMTools directory again now. We do not need it anymore.
3. Run the image build script
Mount the Windows Server 2016 TP5 ISO to make it available as a Windows drive (In Windows 8 and 10 you just need to double-click on it in Explorer to accomplish this). In the following examples I assume that it has been mounted to E:. Adjust this as needed.
Now open a Powershell window as Administrator and run commands like the following:
Import-Module -Global E:\NanoServer\NanoServerImageGenerator\NanoServerImageGenerator.psm1 New-NanoServerImage -MediaPath E:\ -BasePath C:\TEMP\Base -TargetPath C:\TEMP\Nano01.vhdx -ComputerName Nano01 -EnableRemoteManagementPort -DriversPath C:\TEMP\Drivers -AdministratorPassword (ConvertTo-SecureString -String "VMware123!" -AsPlainText -Force) -DeploymentType Host -Edition Standard -ComputeThe first command imports the NanoServerImageGenerator Powershell module from the TP5 ISO. The second command creates the image. Here is the meaning of the most important switches:
- -MediaPath : Drive letter of the mounted TP5 ISO
- -BasePath : Temporary writable build directory (will be created if not existing)
- -TargetPath : Full file name of the generated image (the format will be determined by the extension: .wim, .vhd or .vhdx)
- -ComputerName : Computername of the Nano Server (you guessed it)
- -EnableRemoteManagementPort : enable the Remote Management Port in Nano Server by default. This can also be done after deployment on the console.
- -DriversPath : Directory with additional drivers to be added. We specify the path to the extracted VMware drivers here
- -AdministratorPassword : the local Administrator's password as SecureString. We use VMware123! in this example.
- -DeploymentType : Either Host or Guest. Specifying Guest here would automatically add the Hyper-V Integration Tools (the Microsoft equivalent to the VMware Tools), so that you can smoothly run the image as a Hyper-V VM. Since we want to run it under vSphere it is safe to specify Host here (which would also be used for physical deployments).
- -Edition : The Nano Server Edition, either Standard or DataCenter.
- -Compute : This is an optional switch that automatically adds the Hyper-V role to the image. There are other switches for other roles available.
- -DomainName <AD-Domain> : (Not used here) If you have an Active Directory available then you can have the Nano Server automatically join the domain by using this switch. This makes remote management a bit easier, but requires the build command being executed as a Domain admin (resp. with sufficient permissions to join the computer to the domain).
... and this is how the output will look like:
As you will have noticed I chose to create a vhdx file rather than a vhd file, because it is more modern: It uses the GPT partition format and an EFI boot partition. Using vhd instead will also work perfectly fine. I just like to be on the cutting edge :)
4. Convert the vhdx file to vmdk format
For converting a vhdx file to VMware format there is really only one straightforward way: Use the free Starwind V2V Converter Tool. It requires a registration to download and must be installed, but it is simple enough to use and just does the job. When using it select VMware ESX server image as the Destination image format:
This will create two output files, a small metadata *.vmdk file and the actual disk file *-flat.vmdk (with 4 GB size).
Deploying the VM
Create a new VM on your ESXi host with these options:
- Latest available virtual hardware version (11 on ESXi 6.0)
- Guest OS: Microsoft Windows Server 2016 (64-bit)
- CPU and RAM as needed (I used one CPU socket with two cores and 4 GB RAM)
- A vmxnet 3 Network adapter
- A VMware Paravirtual (pvscsi) SCSI controller
- Do not add a hard disk at creation time!
After creating the VM edit its Advanced Options / Boot Options and select EFI as the boot firmware (this is only needed when you used the vhdx disk format like I proposed):
Now upload the two vmdk files that were produced by the Starwind Converter tool to the ESXi datastore directory that was created for your VM. Edit the VM and add the uploaded disk as Existing virtual disk and Virtual Device Node "SCSI (0:0)". You must use the legacy vSphere Client for this step! I tried with the new HTML5 Host Client fling, but due to a bug in it you can add the disk only as type IDE there.
Finally change the type of the SCSI controller that was automatically added with the disk to VMware Paravirtual (pvscsi):
You have now created your first Nano Server VM on vSphere and are ready to power it on! It will only take two or three seconds to boot and will greet you with this minimalist login screen:
Continue from here
This is "only" a guide for deploying Nano Server on vSphere (using the most modern options), but not a guide to using it. There is tons of good documentation already available for this, your starting point is here: http://www.aka.ms/nanoserver.
Only one note: If you want to try out using Nano Server as Hyper-V host then you need to enable nested virtualization for the VM by
- enabling hardware assisted virtualization for its virtual CPUs and
- adding the advanced configuration parameter hypervisor.cpuid.v0 with value false
while the VM is powered off.
|  | 
| Enabling hardware assisted virtualization in the Host Client | 
|  | 
| Adding Advanced Configuration parameter hypervisor.cpuid.v0 in the Host Client | 
One final note: My build instructions are based on the current Technical Preview 5 (TP5) of Windows Server 2016, and they may slightly change with the released version of Windows Server 2016. However, I do not really expect this, because Microsoft already announced that TP5 will be the last TP and that GA release is most likely to happen in September.
So get started early and have fun!
This post first appeared on the VMware Front Experience Blog and was written by Andreas Peetz. 
 Follow him on Twitter to keep up to date with what he posts.
 Follow him on Twitter to keep up to date with what he posts.
 Follow him on Twitter to keep up to date with what he posts.
 Follow him on Twitter to keep up to date with what he posts.
 







Excellent article. Thank you.
ReplyDeleteOne small typo -DriverPath is the correct item. Great article
ReplyDeleteIt should be -DriverPath C:\TEMP\Driver not -DriversPath C:\TEMP\Driver
ReplyDeleteYes, this changed in the GA release of Windows Server 2016. Before (e.g. in TP5) it was -DriversPath, with the GA it's -DriverPath
DeleteNice article - thank you for taking the time to write it, useful for testing.
ReplyDeleteIs it a bad idea to include the balloon driver or is there any other reason why you didn't include it?
ReplyDeleteYou can try to include it, but it won't work as expected, because for ballooning to work the VMware Tools Service is also required. It communicates with the ESXi host and initiates the ballooning/memory allocation inside the guest when instructed to do so.
DeleteGreat article, thank you!
ReplyDelete