Skip to content
This repository has been archived by the owner on Oct 12, 2023. It is now read-only.

Latest commit

 

History

History
200 lines (139 loc) · 12.7 KB

quickstart.md

File metadata and controls

200 lines (139 loc) · 12.7 KB

Toolkit Quickstart Guide

This guide will walk you through deploying one of the example archetypes provided in the toolkit. Specifically, we will deploy a shared services that does not depend on an on-premises environment.

Prerequisites

At a minimum you will need to follow this quickstart:

We recommended Visual Studio Code as well, though any text editor will suffice.

You can install these on your local machine, or you can the lab VM provided in the toolkit. See these instructions for setting up the lab VM.

After these prerequisties are installed, we will clone the reposistory on GitHub and build a Docker image. This quickstart assumes that you will be interacting with the toolkit through the Docker image.

Clone the repository

These steps assume that the git command is on your path.

  1. Open a terminal window
  2. Navigate to a folder where you want to store the source for the toolkit. If you are using the labVM, you can use the default c:\Users\vdcadmin folder.
  3. Run git clone https://github.com/Azure/vdc.git. This will clone the GitHub repository in a folder named vdc.
  4. Run cd vdc to change directory in the source folder.
  5. Run git checkout master to switch to the branch with the current in-development version of the toolkit.

Build the Docker image

  1. Ensure that the Docker daemon is running. If you are new to Docker, the easiest way to do this is to install Docker Desktop.
  2. Open a terminal window
  3. Navigate to the folder where you cloned the repository. The rest of the quickstart assumes that this path is C:\Users\vdcadmin\vdc\
  4. Run docker build . -t vdc:latest to build the image.

Run the toolkit container

After the image finishing building, you can run it using:

docker run -it --rm -v C:\Users\vdcadmin\vdc\Config:/usr/src/app/Config -v C:\Users\vdcadmin\vdc\Environments:/usr/src/app/Environments -v C:\Users\vdcadmin\vdc\Modules:/usr/src/app/Modules vdc:latest

A few things to note:

  • You don't need to build the image every time you want to run the container. You'll only need to rebuild it if there are changes to the source (primarily changes in the Orchestration folder).
  • The docker run command above will map volumes in the container to volumes on the host machine. This will allow you to directly modify files in these directories (Config,Environments, and Modules).

When the container starts, you will see the prompt PS /usr/src/app>

Configure the toolkit

To configure the toolkit for this quickstart, we will need to collect the following information.

You'll need:

  • A subscription for the toolkit to use for logging and tracking deployment.
  • A subscription that we'll deploy a shared services environment into.
  • The associated tenant id of the Azure Active Directory associated with those subscriptions.
  • The object id of the user account that you'll use to run the deployment.
  • The object id of a service principal that Azure DevOps can use for deployment.
  • An organizatgion name for generating a prefix for naming resources. This can be something fictious like "contoso".
  • The desired username and password for the Active Directory domain admin that will be created.
  • The public ssh key for accessing the Linux jumpbox.
  • The desired password of the Windows jumpbox.

Note: You can use a single subscription. You'll just need to provide the same subscription id in multiple locations in the configuration.

Collecting user object id and tentant id

You can get your user object id and tenant id in the portal or by using command line utitilies.

Using Azure PowerShell:

  1. Run Connect-AzAccount to login and set an Azure context.
  2. Run Get-AzContext | % { Get-AzADUser -UserPrincipalName $($_.Account.Id) } | select Id to get the user object id.
  3. Run Get-AzContext | select Tenant to get the tenant id.

Additional details on these cmdlets are here:

Azure DevOps service principal

Strictly speaking, you do not need a service principal for the purpose of this quickstart. You can reuse your user object id in place of the service principal object id. However, if you want to deploy using Azure DevOps will need to create the service principal.

Follow thse instructions for creating the service principal and note the object id during creation. The service principal will require owner permissions.

Setting the configuration

To deploy the shared services environment, you will need to modify two configuration files and set several environmental variables.

This file is for toolkit configuration in general.

  • Set Subscription.TenantId to the tenant id note above.
  • Set Subscription.SubscriptionId to the id of the subscription used for logging and deployment state tracking noted above.

This file is for the deployment enviroments configuration. In the quickstart, we are only interested in the SharedServices.

  • Set SharedServices.TenantId to the tenant id note above.
  • Set SharedServices.SubscriptionId to the id of the target subscription for the deployment noted above.

Environmental variables

The toolkit uses environmental variables instead of configuration files to help avoid the accidental inclusion of secrets into your source control. In the context of a CI/CD pipeline, these values would be retrieved from a key vault.

You can set these environmental variables by substituting the actual values in the script below. You can then copy and paste this script into PowerShell to execute it.

Note: The first two variables are set with the content of the configuration files we just modified. The path will not resolve correctly unless you are in /usr/src/app directory.

$ENV:VDC_SUBSCRIPTIONS = (Get-Content .\Environments\_Common\subscriptions.json -Raw)
$ENV:VDC_TOOLKIT_SUBSCRIPTION = (Get-Content .\Config\toolkit.subscription.json -Raw)

$ENV:ORGANIZATION_NAME = "contoso"
$ENV:TENANT_ID = "00000000-0000-0000-0000-000000000000"

$ENV:KEYVAULT_MANAGEMENT_USER_ID  = "00000000-0000-0000-0000-000000000000"
$ENV:DEVOPS_SERVICE_PRINCIPAL_USER_ID = "00000000-0000-0000-0000-000000000000"

$ENV:DOMAIN_ADMIN_USERNAME = "xxx"
$ENV:DOMAIN_ADMIN_USER_PWD = "yyy"

$ENV:ADMIN_USER_PWD = "zzz"

$ENV:ADMIN_USER_SSH = "ssh-rsa ... [email protected]"

To use the above script:

  1. Return to the running Docker container from earlier in the quickstart.
  2. Confirm that you are in the /usr/src/app directory.
  3. Make a copy of the above script and replace the necessary values.
  4. Copy the script into the clipboard and paste it in the terminal.
  5. Verify that the enviromental variables are set by running env to view the current values.

Deploying the shared services environment

  1. Return to the running Docker container from earlier in the quickstart.

  2. If you have not already done so, run Connect-AzAccount to login and set an Azure context.

  3. To deply the entire shared services environment, you can run a single command:

    ./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json

The toolkit will begin deploying the constituent modules and the status will be sent to the terminal. Open the Azure portal and you can check the status of the invididual deployments.

Deploying individual moduels

If you prefer you can deploy the constituent modules for shared services individually. The following is the series of commands to execute.

./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "DiagnosticStorageAccount"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "LogAnalytics"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "AutomationAccounts"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "LinkLogAnalyticsWithAutomationAccount"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "JumpboxASG"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "DomainControllerASG"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "SharedServicesNSG"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "DMZNSG"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "SharedServicesRouteTable"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "VirtualNetwork"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "EnableServiceEndpointOnDiagnosticStorageAccount"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "VirtualNetworkGateway"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "LocalVirtualNetworkGatewayConnection"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "RemoteVirtualNetworkGatewayConnection"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "AzureFirewall"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "KeyVault"
./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -DefinitionPath ./Environments/SharedServices/definition.json -ModuleConfigurationName "ArtifactsStorageAccount"

Teardown the environment

You can easily tear down the shared services environment by running this command:

./Orchestration/OrchestrationService/ModuleConfigurationDeployment.ps1 -TearDownEnvironment -DefinitionPath ./Environments/SharedServices/definition.json

Note: This is the same command you used to deploy expect that you include -TearDownEnvironment. It uses the same configuration, so if you change the configuration the tear down may not execute as expected.

For safety reasons, the key vault will not be deleted. Instead, it will be set to a removed state. This means that the name is still considered in use. To fully delete the key vault, use:

Get-AzKeyVault -InRemovedState | ? { Write-Host "Removing vault: $($_.VaultName)"; Remove-AzKeyVault -InRemovedState -VaultName $_.VaultName -Location $_.Location -Force }

Next steps

Congratulations! You've deployed your first environment with the VDC Toolkit. Please be sure to report any issues you might encounter.