Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RFC: Extract DSC from Existing Environments #146

Open
NikCharlebois opened this issue Oct 23, 2018 · 5 comments
Open

RFC: Extract DSC from Existing Environments #146

NikCharlebois opened this issue Oct 23, 2018 · 5 comments

Comments

@NikCharlebois
Copy link

--
RFC: RFC00xx
Author: Nik Charlebois

Reverse Engineering Existing Environment into DSC

Users have been complaining about the learning curve to get started with DSC and about the amount of work it takes for them to re-write their existing technology investment onto DSC for monitoring purposes. There have been various community projects to solve this issue by extracting DSC configurations out of existing environments, such as ReverseDSC, which had incredible success with clients wanting to adopt Configuration as Code practices within their organizations.

The purpose of this RFC is to propose that a fourth method that would retrieve all instances of a resource against an existing environment be included in DSC resources for them to be identified as HQRM.

Motivation

  • Reduce amount of work required to on-board existing environments onto DSC
  • Reduce learning curve to get started with DSC
  • Provide an automated path to migrate on-premises environments onto Azure
  • Allow users to easily document their environment’s configuration as code
  • Quickly compare configuration deltas between two environments

Specifications

There are three components to the requested solution:

  • Component 1 needs to iterate through all instances of the current resource and provide the Get-TargetResource function the key parameters for it to be able to retrieve all other parameters associated with this resource instance.
  • Component 2 needs to retrieve the Hash tables received back from the Get-TargetResource and convert them into a DSC string. This is already automated and handled by the existing ReverseDSC Core module https://github.com/microsoft/reversedsc
  • Component 3 needs to orchestrate the calls to the resources’ Component 1 and 2 and collect the results into a resulting file, which will be a DSC script that can be used to replicate the environment.

The vision is as follow:
Component 1 and 2 would be combined into a new fourth function required by every HQRM, call it Export-TargetResource. Component 3 would be a global utility module, contained within the DSC module, which would orchestrate all the calls to the module’s Export-TargetResource methods (see SharePointDSC.Reverse at https://github.com/microsoft/sharepointdsc.reverse for a reference)

@awickham10
Copy link

I 100% second this. The ability to extract DSC resources is critical to adoption in a brownfield environment and the existing solution feel "bolt on."

@adminastoolsmith
Copy link

I am in agreement with this recommendation. I have used the ReverseDSC Core module to retrieve system configuration information from an existing environment in order to automate the creation of the DSC Configuration scripts. This has helped to reduce the time frame that it would normally take to adopt Configuration As Code in my environment. Powershell DSC should have an option to retrieve all instances of a resource.

@ykuijs
Copy link

ykuijs commented Oct 26, 2018

This would absolutely make DSC much easier to learn. I see many customers struggling with learning DSC. Being able to output a configuration based on an existing environment would give them the possibility to generate a starting point and go from there. SharePointDsc.Reverse does an excellent job for SharePoint and it would be great if this would be native functionality in DSC.

@awickham10
Copy link

This would absolutely make DSC much easier to learn. I see many customers struggling with learning DSC. Being able to output a configuration based on an existing environment would give them the possibility to generate a starting point and go from there. SharePointDsc.Reverse does an excellent job for SharePoint and it would be great if this would be native functionality in DSC.

Another great use case! So sounds like this would ease adoption and decrease learning curve. Sounds like this needs to be a PR in order to be reviewed by the committee.

https://github.com/PowerShell/powershell-rfc/blob/master/RFC0000-RFC-Process.md

@SteveL-MSFT
Copy link
Member

@mgreenegit @nitinbps can you two look at this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants