Skip to content

Latest commit

 

History

History
218 lines (147 loc) · 11 KB

Exercise1.md

File metadata and controls

218 lines (147 loc) · 11 KB

Task 2 - The build

Estimated time to completion: 30-60 minutes

This task is about building the solution locally. For that, no infrastructure or service is required. All you need is having cloned the public DscWorkshop repository to your machine.

To kick off a new build, the script build.ps1 is going to be used. Whether or not you are in a build pipeline, the build script will create all artifacts in your current environment.

After completing this task, you have gone through the build process for all artifacts that are required for a DSC pull server scenario (on-prem or Azure).

Note: Remember to check the prerequisites first. You can just call the script ../CheckPrereq.ps1 to start the Pester tests that will check your system against the requirements.


2.1 Running a manual build locally

  1. Open Windows PowerShell as elevated Admin. Do this by pressing the Windows-Symbol and then typing powershell.exe and then right-click select 'Run As Administrator'

  2. Execute the Get-ExecutionPolicy cmdlet. The resulting execution policy should be either RemoteSigned, Unrestricted or Bypass:

    Get-ExecutionPolicy
    
    RemoteSigned
    

    If this is not the case, execute

    Set-ExecutionPolicy RemoteSigned -Force
  3. Change to a suitable directory in which to clone the workshop files. As you will navigate to that folder quite often, keep it easy like

    mkdir C:\Git
    Set-Location -Path C:\Git
  4. Optional: If you have not yet installed git, please do so now by executing the following lines of code:

    Install-PackageProvider -Name nuget -Force
    Install-Module Chocolatey -Force
    Install-ChocolateySoftware
    Install-ChocolateyPackage -Name git -Force

    If you do not want to install Chocolatey, you can also browse to https://git-scm.org and download and install git from there.

  5. Optional: Later when moving to a release pipeline on Azure DevOps, the current version is evaluated automatically using 'GitVersion'. If you want to get the version number the same way, you want to install 'GitVersion' additionally.

Install-ChocolateyPackage -Name GitVersion.Portable
  1. Ensure that the git executable is in your path to make the next exercises work. Otherwise, please use the full or relative path to git.exe in the following steps.

    Note: After installing git, you may need to close and open VSCode or the ISE again to make the process read the new path environment variable.

  2. In this and the following exercises we will be working with the open-source DscWorkshop repository hosted at https://github.com/dsccommunity/DscWorkshop. To clone this repository, please execute:

    Note: Please make sure you are in the 'C:\Git' folder or wherever you want to store the project.

    git clone https://github.com/dsccommunity/DscWorkshop
  3. Change into the newly cloned repository and checkout the dev branch to move into the development

    Set-Location -Path .\DscWorkshop\

    To get the branch you are currently using, just type:

    git branch

    The command should return main. Please create a new branch and name it exercise.

    git branch exercise
    git checkout exercise

    Note: If you want to read more about branches in git, have a look at the documentation about git branches

  4. Open the DscWorkshop folder in VSCode and examine the repository contents. The shortcut in VSCode to open a folder is CTRL+K CTRL+O. You can also press F1 and type in the command you are looking for. And of course there is the classical way using the file menu.

  5. For a build to succeed, multiple dependencies have to be met. These are defined in a file containing hashtables of key/value pairs much like a module manifest (*.psd1) file. Take a look at the content of the file RequiredModules.psd1 by opening it from the project's root folder in VSCode:

    PSDepend is another PowerShell module being used here which can be leveraged to define project dependencies to PowerShell modules, GitHub repositories and more.

    To learn more about PSDepend, have a look at https://github.com/RamblingCookieMonster/PSDepend

  6. Without modifying anything yet, start the build script by executing:

    .\build.ps1
    

    This command will download all dependencies that are defined in the previously mentioned file RequiredModules.psd1 and then build the entire environment. Downloading all the dependencies can take a short while.

    While the script is running, you may want to explore the following folders. The PSDepend module downloads and stores the dependencies into the folder defined as target in the RequiredModules.psd1, which is output\RequiredModules.

    Note: Depending on your machine's speed, your internet connection and the performance of the PowerShell Gallery, the initial build with downloading all the resources may take 5 to 15 minutes. Subsequent builds should take around 2 to 4 minutes.

  7. After the build process has finished, a number of artifacts have been created. The artifacts that we need for DSC are the

    • MOF files
    • Meta.MOF files
    • compressed modules

    Additionally, you have artifacts that help when investigating issues with the configuration data or when debugging something. These artifacts are not required for DSC.

    • CompressedArtifacts
    • Logs
    • RSOP
    • RsopWithSource

    Before having a closer look at the artifacts, let's have a look at how nodes are defined for the environment named Dev. In VSCode, please navigate to the folder source\AllNodes\Dev.

    You should see two files here: DSCFile01.yml and DSCWeb01.yml.

  8. Please open the files DSCFile01.yml and DSCWeb01.yml. Both files are in the YAML format. YAML, like JSON, has been around since 2000 / 2001 and can be used to serialize data.

    The file server for example looks like this:

    NodeName: '[x={ $Node.Name }=]'
    Environment: '[x={ $File.Directory.BaseName } =]'
    Role: FileServer
    Description: '[x= "$($Node.Role) in $($Node.Environment)" =]'
    Location: Frankfurt
    Baseline: Server
    
    ComputerSettings:
    Name: '[x={ $Node.NodeName }=]'
    Description: '[x= "$($Node.Role) in $($Node.Environment)" =]'
    
    NetworkIpConfiguration:
    Interfaces:
        - InterfaceAlias: DscWorkshop 0
        IpAddress: 192.168.111.100
        Prefix: 24
        Gateway: 192.168.111.50
        DnsServer:
            - 192.168.111.10
        DisableNetbios: true
    
    PSDscAllowPlainTextPassword: True
    PSDscAllowDomainUser: True
    
    LcmConfig:
    ConfigurationRepositoryWeb:
        Server:
        ConfigurationNames: '[x={ $Node.NodeName }=]'
    
    DscTagging:
    Layers:
        - '[x={ Get-DatumSourceFile -Path $File } =]'
    
    FilesAndFolders:
    Items:
        - DestinationPath: Z:\DoesNotWork
        Type: Directory

    Note: The syntax '[x={ <code> } =]' invokes PowerShell code for adding data to your yaml files during compilation. More information about this can be found on Datum.InvokeCommand.

    A node's YAML will contain data that is unique to the node, like its name or IP address. It will also contain role assignments like FileServer, the location of the node as well as the optional LCM configuration name to pull.

  9. The role of a node (FileServer) is effectively a link to another YAML file, in this case FileServer.yml in the folder .\source\Roles\FileServer.yml. A role describes settings that are meant for a group of nodes and is the next level of generalization. Notice that the content starts with the Configurations key. Nodes, Roles and Locations can all subscribe to DSC composite resources, which we call configurations:

    Configurations:
    - FilesAndFolders
    - RegistryValues

    Each composite resource can receive parameters by specifying them a little further down in the YAML:

    FilesAndFolders:
        Items:
          - DestinationPath: C:\Test
            Type: Directory

    In this case, the configuration (composite resource) FilesAndFolders accepts a (very generic) parameter called Items. The Items parameter is simply a hashtable expecting the same settings that the File resource would use as well. The configuration is documented and you can find some examples how to use it in DSC Resource FilesAndFolders.

    The location of a node is even more generic than the role and can be used to describe location-specific items like network topology and other settings. Same applies to the environment.

  10. Now it's time to focus more on the artifacts. The build process created six types of artifacts:

    • MOF files
    • Meta.MOF files
    • Compressed modules
    • RSoP YAML files with and without source level information
    • Logs files
    • Pester Test Results

    Among these, the RSoP (Resultant Set of Policy) will be very helpful as these files will show you what configuration items exactly will be applied to your nodes and the parameters given to them. The concept of RSoP is very similar to Windows Group Policies and how to use Resultant Set of Policy to Manage Group Policy.

    Examine the RSoP files now which are in the folder output\RSOP and output\RsopWithSource.

  11. Let's take the RSoP artifact for DSCFile01. If you compare the RSoP output of this node (output\RSOP\DSCFile01.yml) to the node's config file (AllNodes\Dev\DSCFile01.yml), you will notice that there are many more properties defined than in the original DSCFile01.yml. Where did these come from? They are defined in the node's role and location YAML files.

    For understanding how Datum merges different layers, please refer to Lookup Merging Behavior.

  12. The usable artifacts are your MOF, Meta.MOF files and compressed modules - these files will be part of your release pipeline.


Congratulations. You have just built the entire development environment! Want to test this, but don't have the infrastructure (Azure DevOps Server, SQL, AD, PKI, target nodes)? Try AutomatedLab, the module that helps you with rapid prototyping of your apps ;) Included in this repository is the entire lab script for

Please continue with Exercise 2 when your are ready.