Skip to content

Commit

Permalink
Adding documentation for Managed Identity on AKS (#1440)
Browse files Browse the repository at this point in the history
  • Loading branch information
Nicholas M. Iodice authored Sep 12, 2020
1 parent bfc5418 commit d342fd8
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 0 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ Bedrock helps you:
* [Walkthrough: Single Cluster Infrastructure Deployment](./docs/single-cluster.md)
* [Deep Dive: Multicluster and "Day 2" Infrastructure Scenarios](./docs/multicluster.md)
* [CLI Reference](https://github.com/microsoft/bedrock-cli/blob/master/guides/cloud-infra-management.md)
* [Managed Identity Reference](./docs/managed-identity.md)

## GitOps Pipeline
* [Walkthrough: GitOps Pipeline](./docs/hld-to-manifest.md)
Expand All @@ -33,6 +34,7 @@ Bedrock helps you:
* [Deep Dive: Helm Charts](https://github.com/microsoft/bedrock-cli/blob/master/guides/building-helm-charts-for-bedrock.md)
* [Configuring A Service through Fabrikate configurations](./docs/service-configuration.md)
* [CLI Reference](https://github.com/microsoft/bedrock-cli/blob/master/guides/service-management.md)
* [Managed Identity Reference](./docs/managed-identity.md)

## Rings Management
* [Walkthrough: Rings](./docs/rings.md)
Expand Down
77 changes: 77 additions & 0 deletions docs/managed-identity.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
# Managed Identity

This document is intended to give an overview of using [Managed Identities](https://docs.microsoft.com/en-us/azure/active-directory/managed-identities-azure-resources/overview) (MI) with [Azure Kubernetes Service](https://azure.microsoft.com/en-us/services/kubernetes-service/) (AKS).

MI is a common alternative to [Service Principal](https://docs.microsoft.com/en-us/azure/active-directory/develop/app-objects-and-service-principals) based authentication because it provides services with an automatically managed identity in Azure AD. Applications can use the identity to authenticate to any service that supports Azure AD authentication, including Key Vault, without any credentials in code or the environment.

## AKS Managed Identities

AKS natively supports MI ([docs](https://docs.microsoft.com/en-us/azure/aks/use-managed-identity)). Azure automatically creates a [System Assigned Managed Identity](https://docs.microsoft.com/en-us/azure/active-directory/managed-identities-azure-resources/overview#managed-identity-types) for AKS deployments that leverage MI.

Infrastructure deployed through Terraform can leverage an `identity` block ([ref](https://www.terraform.io/docs/providers/azurerm/r/kubernetes_cluster.html#identity)) to deploy a cluster with Managed Identity.

### Required Role Assignments

#### ACR Pull

Grants AKS MI the ability to pull application images from ACR

```hcl
resource "azurerm_role_assignment" "acrpull" {
scope = var.acr_id
role_definition_name = "AcrPull"
principal_id = module.aks.kubelet_id
}
```

## Pod Managed Identities

AAD Pod Identity enables Kubernetes applications to access cloud resources securely with Azure Active Directory (AAD).

Using Kubernetes primitives, administrators configure identities and bindings to match pods. Then without any code modifications, your containerized applications can leverage any resource in the cloud that depends on AAD as an identity provider.

### Required Role Assignments

The following Role Assignments are required based on the [AAD Pod Identity](https://github.com/Azure/aad-pod-identity/blob/master/docs/readmes/README.role-assignment.md) documentation:

#### Managed Identity Operator

Grant AKS MI the ability to read and assign User Assigned MI

```hcl
resource "azurerm_role_assignment" "mi_operator" {
scope = data.azurerm_resource_group.kube_rg.id
role_definition_name = "Managed Identity Operator"
principal_id = module.aks.kubelet_id
}
```

#### Virtual Machine Contributor

Grant AKS MI the ability to manage VMs in AKS VM Scale Set

```hcl
resource "azurerm_role_assignment" "vm_contrib" {
scope = data.azurerm_resource_group.kube_rg.id
role_definition_name = "Virtual Machine Contributor"
principal_id = module.aks.kubelet_id
}
```

#### Other

Pod MIs will also need access to other Azure Managed Services. Here is an example of what that might look like:

```hcl
# Example: grant Pod MI access to Azure Storage
resource "azurerm_role_assignment" "mi_container" {
count = length(local.identities_for_storage)
scope = azurerm_storage_container.example.resource_manager_id
role_definition_name = "Storage Blob Data Contributor"
principal_id = local.identities_for_storage[count.index].principal_id
}
```

### Installing AAD Pod Identity on AKS

AAD Pod Identity can be installed on AKS using Helm. The [official documentation](https://github.com/Azure/aad-pod-identity#1-deploy-aad-pod-identity) details the steps needed.

0 comments on commit d342fd8

Please sign in to comment.