- After installing SharePoint, ensure the check box Run the SharePoint Products and Technologies Configuration Wizard now is un-checked.
- When creating an instance of the VM, run SysPrep.
By doing these two things, you are ensuring you're not writing machine specific information to the database and secondly the machine is generating new system IDs.
Once the base was completed, I found we could intantiate clones of this base in a few hours (max). That includes copying the VM (say 100 gig), running sysprep, and running psconfig. Pretty sweet.
Building the VM template.
My Development VM consisted of the following (all installed as local administrator):- Windows Server 2008 R2 (64bit)
- SQL Server 2008 R2
- SharePoint Server (Enterprise) 2010 (and language packs where necessary)
- Visual Studio Ultimate 2010
- Office Professional Plus 2010 (x86)
- Visio Professional 2010
- SharePoint Designer 2010
- SharePoint WorkSpace 2010
- ULS Viewer
- SharePoint Manager 2010
- CKS Codeplex Visual Studio tools (v1.2)
- PowerGUI
- ...obviously everything is service packed (except SharePoint).
Save a backup copy of the 'base'. Always a good idea.
Creating an instance from the Base VM
- Make a copy the SharePoint VM template from the base.
- Rename the .vmx file and VM folder to the server name you will use.
- Whilst the VM is off, edit it's properties and rename the Virtual Machine Name to the intended VM name before boot up.
- When prompted, click "I copied it".
- Log in as the Administrator.
- To run SysPrep, click to Start > Run, type sysprep and press OK.
- Select Enter System Out-of-Box Experience (OOBE). Uncheck Generalize. As 'Shutdown Options' select Reboot.
- After rebooting you’ll have to enter some data, for example, Country or region, Time and currency and Keyboard input. Also, accept EULA and reboot.
- Change the local administrators password when prompted.
- Right Click computer and click properties. Change the name of the server to the name that was changed in step 2. Remain in workgroups here. Do not join the domain yet. The system will ask you to reboot.
- After the reboot, log back in as Administrator.
- You’ll now attempt to join the domain. It might be a good idea to 'ping' the domain controller to see if the connection works. If it doesn’t you’ll probably have to change the VM’s network adapter from Bridged to NAT (that way you are using the host’s access to the domain). You will need domain admin access here to join the domain.
- Optional: once the computer has joined the domain, don’t power it back on until you have moved the object to the appropriate OU. Some OUs in organisation get a lot more settings pumped down to them via the GPO. We have a developement OU where only the minimal stuff gets downloaded.
- Re-start the VM.
- Log back in as local Administrator
- Add your domain accounts as local administrators on the VM.
- Also, you will need to give this account access to SQL as well. I tend to use the same domain account as the farm account and service accounts for SharePoint (obviously not advised for production but this is for dev only)
- Log out and log in as this domain account.
At this point you can now run the SharePoint 2010 Product Configuration Wizard (psconfig). An alternative approach here is to use the CodePlex project AutoSPInstaller (highly recommended). This will streamline your VM creation even better becuase it will create all the necessary service applications, and web applications, site collections, and farm solutions you like.
One thing to note: Every Microsoft product installed in the VM will have to be re-activated from a licensing perspective. This includes the OS. Don't bother activating the products in the base (and it pays to use your enterprise licenses not your MSDN license that everyone you share this base with will use. I learnt the hard way on that one)
Hope this helps a SharePoint development team build quicker VMs.