Last modified January 21, 2025
Prepare your provider account for Azure
When running the Giant Swarm platform in your Azure subscription, several prerequisites must be satisfied to support Cluster API Provider Azure (CAPZ). In the current implementation, management and workload clusters must run in the same subscription.
In addition to the following prerequisites, your account engineer will provide you with a pre-installation checklist that you must complete before starting the installation process.
Requirements
The Azure subscription must be chosen from existing ones or created if needed in the customer’s Azure account. For security reasons regarding sensitive data stored within customer accounts, the advice is to use a subscription-only designated for Giant Swarm Azure resources management.
An individual has to have the following permissions and tools working within the designated Azure subscription:
- An account with Owner or User Access Administrator role.
- Azure CLI installed and configured to point to chosen subscription via
az account set
command.
Step 1: Service quotas
Azure enforces service quota through all cloud services. The following overview lists the usual resources you may adjust, depending on the number and size of clusters planned to be deployed:
Access to the Quotas portal service to check and adjust quotas as required. You can also use the Azure CLI to check quotas like:
az vm list-usage --location <region>
If your current quotas are insufficient, you can request an increase. In the Azure portal, follow the steps below:
- Go to the Quotas section in the Azure portal.
- Click on the pencil button to request an update.
- Fill the new limit and submit the request.
You can follow the request status in the Quotas section.
Step 2: Permissions
Two permission roles need to be created in the Azure subscription: one for the Giant Swarm controller used by the CAPZ controller in the management cluster to provision all infrastructure to manage workload clusters and the other for Giant Swarm engineers to access the Azure account for support purposes.
Staff permissions
Firstly, you need to grant access to Giant Swarm ops/support to your Azure subscription. Access to the portal is essential for our everyday support, where investigation and manual interventions are sometimes necessary.
The easiest way is to create an Azure Deployment Environment to delegate resource management to third parties. In this case, you must allow the Giant Swarm Staff
group to manage your resources. This is beneficial as you don’t have to manage access for each person separately within your subscription, instead you add a managed group that’s kept up to date by Giant Swarm. There is a solution available called Azure Lighthouse, which allows resource management to be delegated to service providers such as Giant Swarm.
The recommendation is to choose Azure’s built-in role Contributor
to give Giant Swarm access and deployment permissions for resources within your subscription.
Alternatively, you can create your role assignment with restricted access to specific Resource Groups. However, it must be kept up to date so that Giant Swarm can also provide full support for newly created clusters.
Create a Deployment Environment
Download the template file delegatedResourceManagement. This file is left unchanged.
Download the parameters example file delegatedResourceManagement.parameters and fill in the required fields:
- Replace
<GiantSwarmTenantID>
and<GiantSwarmPrincipalID>
with the values provided by Giant Swarm’s Account Engineer - Keep the value of
roleDefinitionId
if you are fine assigning theContributor
role. If a custom role is desired, please replace the value.
- Replace
Now you can run this command to create the Deployment Environment:
$ az deployment create --name "giantswarm-access" \ --location <AzureRegion> \ --template-file delegatedResourceManagement.json \ --parameters delegatedResourceManagement.parameters.json \ --verbose
The
--name
value can be freely chosen if you prefer another name.
Controller permissions
On the other hand, the automation requires an Azure Service Principal, let’s call it Giant Swarm Service Principal
, to enable CAPZ controller to control the Azure resources.
Create the service principal
The Giant Swarm Service Principal can be created in two different ways: via the az
CLI or the Azure portal.
Using the Azure CLI
Please run the following command and keep the output for later usage.
# Please fill in the details of the management cluster (MC) and Azure subscription
MC_SUBSCRIPTION_ID=XXXX-XXXX-XXXX-XXX
MC_NAME=ZZZZ
az login
az account set -s ${MC_SUBSCRIPTION_ID}
az ad sp create-for-rbac --role contributor --scopes="/subscriptions/${MC_SUBSCRIPTION_ID}" --display-name "${MC_NAME}-bootstrap"
az role assignment create \
--assignee "<please fill in the app ID from the previous command output>" \
--role "User Access Administrator" \
--scope "/subscriptions/${MC_SUBSCRIPTION_ID}"
Note: Store the output of az ad sp create-for-rbac
. This needs to be provided to Giant Swarm in step 2.
Using Azure Portal
Login to the Azure Portal
Go to the “Azure Active Directory” service
From the left pane, select the “App registrations” section, then click “New registration” from the menu at the top of the page
Enter the name
<MC_NAME>-bootstrap
. Replace<MC_NAME>
with the name of the management clusterSelect “Accounts in any organizational directory (Any Azure AD directory - Multi-tenant)” as “Supported account types”
Click “Register”
Go to the “Certificates & secrets” section. Under the “Client secrets” part, create a new “Client Secret”
Set expiration to
2 Days
and click “Add”Store the new secret’s
Value
. Later, this needs to be provided to Giant Swarm.Add “RoleAssignment” to the newly created App
- Select the right “Subscription” where the management cluster should be created
- Go to “Access control (IAM)”
- Click “Add Role Assignment” and add the “Contributor” role and the “User Access Administrator” role to the App with the “subscription” Scope
Provide generated credentials to Giant Swarm
The following information needs to be provided to Giant Swarm:
* ClientID
* ClientSecret
* SubscriptionID
* TenantID
Note: Contact your Account Engineer, who will help you find a secure way to share this information. Our recommended tool is Keybase.
Post deployment cleanup
Once all necessary information is provided, our engineers create the management cluster. The provided permissions work within your subscription to provision and validate the infrastructure, ensuring a seamless and efficient process.
When Giant Swarm completes the management cluster provisioning, our engineers can clean up part of the initial setup. The Giant Swarm Service Principal can be deleted as it’s used only for the initial bootstrap, during which an Azure user-assigned managed identity is created.
Step 3: Virtual machine templates
Accept legal terms for Flatcar Linux
Giant Swarm deploys Flatcar Linux images for Kubernetes cluster nodes. It’s developed by Kinvolk and taken from the Azure Marketplace. In order to be able to run the images, Azure requires customers to accept the legal terms.
Please run the following command before creating a cluster on a given subscription:
az vm image terms accept --offer flatcar-container-linux-free --plan stable --publisher kinvolk
Note: This acceptance needs to be performed only once for a subscription that’s used to run Giant Swarm workload clusters.
Enable encryption at host
If your security requirements demand this, you can enable encryption of data stored on virtual machine hosts. With this enabled, your data will be encrypted when stored and transferred between storage and host, adding additional protection from unauthorized access.
Please run the following command before creating a cluster on a given subscription:
az feature register --name EncryptionAtHost --namespace Microsoft.Compute --subscription $YOUR_SUBSCRIPTION_ID
Step 4: Configure the cluster role identity
The last step involves storing the Azure credentials in the platform to allow the CAPZ controller to manage the infrastructure in your account. In Cluster API, there is a custom resource called AzureClusterIdentity
that stores the Azure credentials. This resource is namespaced.
By default, the controller uses a default
configuration, which points to the role in the management cluster account. If you want to create a new workload cluster in a new Azure subscription, you need to create a new AzureClusterIdentity
resource that references the role of that Azure subscription. Example:
apiVersion: infrastructure.cluster.x-k8s.io/v1beta1
kind: AzureClusterIdentity
metadata:
labels:
cluster.x-k8s.io/watch-filter: capi
name: <SUBSCRIPTION_NAME>
spec:
type: WorkloadIdentity
tenantID: <TENANT_ID>
clientID: <CLIENT_ID>
The <SUBSCRIPTION_NAME>
is a short unique name referencing Azure subscription (development
, sandbox
or staging2
). We advocate using the same name as the organization to help map the resources and the accounts. The <TENANT_ID>
and <CLIENT_ID>
is the Azure client ID and tenant ID that represent the subscription where the workload cluster will be provisioned.
Note: The official documentation provides more information about configuring Azure credentials.
In the next step you define which role the AzureCluster
uses to provision the cluster adjusting the value providerSpecific.azureClusterIdentity.name
.
Note: If you are working with a Giant Swarm partner, you might not have access to the platform API. Please provide the credentials, CAPZ controller, and staff to your partner contact.
Next steps
Contact your Giant Swarm account engineer to verify the setup and proceed with the management cluster provisioning. For sharing any secret with us please read this article first. In case you have already set up the management cluster and you have just configured a new Azure subscription, you can proceed with the creation of the workload cluster.
Need help, got feedback?
We listen to your Slack support channel. You can also reach us at support@giantswarm.io. And of course, we welcome your pull requests!