Skip to content

DeploymentFlow

github-actions edited this page Oct 25, 2021 · 21 revisions

Azure Landing Zones Bicep - Deployment Flow

This document outlines the prerequisites, dependencies and flow to help orchestrate an end-to-end Azure Landing Zone deployment. The orchestration templates provided with this reference implementation have been pre-configured to follow the dependencies described in this document.

Prerequisites

  1. Azure Active Directory Tenant.
  2. Minimum 1 subscription. Subscription(s) are required when configuring Log Analytics Workspace & Hub Networking services. Each can be deployed in the same subscription or separate subscriptions based on deployment requirements.
  3. Deployment Identity with Owner permission to the / root management group. Owner permission is required to allow the Service Principal Account to create role-based access control assignments. See configuration instructions below.

High Level Deployment Flow

High Level Deployment Flow

Module Deployment Sequence

Modules in this reference implementation must be deployed in the following order to ensure consistency across the environment:

Order Module Description Prerequisites Module Documentation
1 Management Groups Configures the management group hierarchy to support Azure Landing Zone reference implementation. Owner role assignment at / root management group. infra-as-code/bicep/modules/management-groups
2 Custom Role Definitions Configures custom roles based on Cloud Adoption Framework's recommendations at the organization management group. Management Groups. infra-as-code/bicep/modules/custom-role-definitions
3 Custom Policy Definitions Configures Custom Policy Definitions at the organization management group. Management Groups. infra-as-code/bicep/modules/policy/definitions
4 Logging & Sentinel Configures a centrally managed Log Analytics Workspace, Automation Account and Sentinel in the Logging subscription. Management Groups & Subscription for Log Analytics and Sentinel. infra-as-code/bicep/modules/logging
5 Built-In and Custom Policy Assignments Creates policy assignments to provide governance at scale. Management Groups, Log Analytics Workspace & Custom Policy Definitions infra-as-code/bicep/modules/reusable/policy-assignments
6 Role Assignments Creates role assignments using built-in and custom role definitions. Management Groups & Subscriptions. infra-as-code/bicep/modules/reusable/role-assignments
7 Subscription Placement Moves one or more subscriptions to the target management group. Management Groups & Subscriptions. infra-as-code/bicep/modules/reusable/subscription-placement
8 Hub Networking Creates Hub networking infrastructure with Azure Firewall to support Hub & Spoke network topology in the Connectivity subscription. Management Groups, Subscription for Hub Networking. infra-as-code/bicep/modules/hub-networking
9 Corp Connected Spoke Network Creates Spoke networking infrastructure with Virtual Network Peering to support Hub & Spoke network topology. Spoke subscriptions are used for deploying construction sets and workloads. Management Groups, Hub Networking & Subscription for spoke networking infra-as-code/bicep/modules/spoke-networking

Deployment Identity

Service Principal Account

A service principal account is required to automate through Azure DevOps or GitHub Workflows.

  • Service Principal Name: any name (i.e. spn-azure-platform-ops)
  • RBAC Assignment
    • Scope: / (Root Management Group)
    • Role Assignment: Owner

See step-by-step instructions on Azure Docs to configure the role assignment at / root management group.

Configure Service Principal Account in Azure DevOps or GitHub