/cDayZeroDeploy

Powershell DSC Resources for Day Zero deployment

Primary LanguagePowerShellMIT LicenseMIT

cDayZeroDeploy

Powershell DSC Resources for Day Zero data center deployment

Copyright 2017 Conscia Norway AS

Summary

cDayZeroDeploy is an effort to make use of Powershell DSC to build a full Powershell DSC managed datacenter. The concept is that from the moment that hardware arrives on site and is plugged in, absolutely no manual configuration will be done to deploy the servers. Once the day-zero scripts are finished running, the system left behind should be 100% maintained via DSC. The goal is to configure switches, routers, bare metal servers, storage, etc... all from Powershell DSC.

The project is ambitious, but thanks to Microsoft's SDN Express deployment scripts which focus entirely on functionality before being "proper", it is clear that it can be done. Darren Starr the initial contributor to this code is already shipping products using the underlying code distributed here.

Current status

cDayZeroDeploy is in its very early stages of development. While there is far more code privately kept by Darren, that code is similar to SDN Express in the sense that it makes use of Script resources where it should instead make use of custom DSC resources.

Direction/Guidelines

Class-based

All DSC resources contributed to this repository must be class based resources. There are however some drawbacks to this. Class based resources are in the infancy stages at Microsoft and can be very difficult to work with. In addition, since includes (dot-sourcing) and neither does using module, don't appear to work from within DSC resources for classes, it is necessary to run a build script to concatenate all the class files together into a single file.

Integration tests

All resources must include at least an integration test that can be used to verify that it operates correctly. Optimally, this integration test will clean up after itself and always have before code that can cleanup any mess left behind due to earlier failures

Unit tests

Perform unit testing however you possibly can for now. As of the time, there's no good method to be able to mock tests for class based resources.

Prefer splatting

Prefer splatting over backticks for multi-line continuations.

Prefer Powershell

It is tempting at times to code in mixed languages, but so far, we haven't seen any cases where Powershell wasn't up to the task. Powershell can get fantastically ugly when performing some tasks, but the beauty of a system like this is that you don't need to download 10,000 tools and modules to make this system work. When in doubt, use Powershell.

Resources

Each individual resource is documented in its own README.md. Currently the resources available as part of this module are as follows :

  • cDeployWindowsVM - creates a new VHD, boots Windows, runs the unattend.xml and detects when the machine is fully operational
  • cDifferencingVHD - a simple replacement for xVHD which works with differencing disks only
  • cUnattendXML - a XML and namespace correct unattend.xml file generator based on System.Text.XML
  • cVHDFileSystem - mounts and adds files/directories to a VHD file
  • cGuestRegistryKey - waits for registry changes within a VM via Hyper-V key/value exchange
  • cWindowsVHD - installs Windows Server 2016 directly from the Windows ISO to a VHD file
  • cNATRule - configures a Windows networking NAT rule