You need a Kubernetes cluster to install things on. Here, we install a Kubernetes cluster on Azure.
First of all, you need an Azure subscription. This can be the Open University, Ordina or a personal account. If you have a Virtual Studio license, you can obtain a Azure subscription for development. Click here
Running the resources as described in this page will cost around €80/month.
The person creating the Azure Kubernetes Service should have global administrator access rights, or at least be able to create resource groups. The users of the Kubernetes Cluster do not require these permissions.
Following the principle of least privilege, a developer should have the following role assignments to the Azure Kubernetes Service. Access to other services should not be required.
Role | Description | Purpose |
---|---|---|
Reader | View all resources, but does not allow you to make any changes | Monitor resources such as Virtual Machines |
Azure Kubernetes Service RBAC Cluster Admin | Lets you manage all resources in the cluster. | Developer should be able to create namespaces, service accounts, deployments etc. |
The setup is described using Azure CLI, but can also be executed through the portal.
Login to the correct tenant, set the subscription and check if this returns the expected value.
az login --tenant <<tenant: 'abc.onmicrosoft.com'>>
az account set -s <<subscription: a3c9b201-2e5c-4f26-9bb1-6e54cbf0ca08>>
echo (az account show --query=name) # should return Open University or Ordina MTech
First of all a resource group should be generated where the Azure Kubernetes Service (and other resources) are deployed.
az group create `
--name <<resource group: RG_ampersand>> `
--location <<region: westeurope>>
Next the Azure Kubernetes Cluster is created. For this deployment 2 of the most simple virtual machines are used to run the cluster. Each virtual machines needs to have at least two cores (see sizes here). Note that RBAC role of the creator needs to be global administrator.
az aks create `
--resource-group <<resource group: RG_ampersand>> `
--name <<cluster name: ampersand-rap-aks>> `
--node-count <<nodes: 2>> `
--node-vm-size <<virtual machine: Standard_B2s>> `
--nodepool-name <<name [optional]: ampersand>> `
--node-resource-group <<generated resource group: RG_ampersand_aks>> `
--generate-ssh-keys
When AKS is created, it creates a managed resource group (which will also be deleted if AKS would be deleted). In this resource group a public IP address, which can be used to assign DNS records to.
Once the static ip-address is obtained, the following DNS records can be configured.
For Open University ou.nl
:
Host | Type record | Value |
---|---|---|
rap.cs.ou.nl | A | <IP address> |
*.rap.cs.ou.nl | CNAME | rap.cs.ou.nl |
staging.cs.ou.nl | CNAME | rap.cs.ou.nl |
*.staging.cs.ou.nl | CNAME | rap.cs.ou.nl |
rap.staging.cs.ou.nl | CNAME | rap.cs.ou.nl |
*.rap.staging.cs.ou.nl | CNAME | rap.cs.ou.nl |
For tarski.nl
:
Host | Type record | Value |
---|---|---|
a-team.tarski.nl | A | <IP address> |
*.a-team.tarski.nl | CNAME | a-team.tarski.nl |
rap.tarski.nl | CNAME | a-team.tarski.nl |
*.rap.tarski.nl | CNAME | a-team.tarski.nl |
To connect yourself to the Kubernetes Cluster you need to log in on your command line interface (CLI):
az login
az aks get-credentials -g $RG -n $AKSCluster --overwrite-existing
You can switch between clusters by listing all clusters and set the current using the NAME parameter.
kubectl config get-contexts
kubectl config use-context 'NAME'
We want to automate the deployment and let gitHub Actions do the work for us. This requires Open ID Connect (OIDC) to allow GitHub Actions to apply new deployments to AKS. The following steps show you how.
The following permissions are required for registering an app:
- You must have sufficient permissions to register an application with your Azure AD tenant, and assign to the application a role in your Azure subscription. To complete these tasks, you require
Application.ReadWrite.Allpermission
.
- Login to Azure and set the right subscription
az login --tenant <TENANT_NAME>
az account set -n <SUBSCRIPTION_NAME>
- Create an Azure Active Directory Application then get the appId and save it in an environment variable:
az ad app create --display-name <APP_NAME>
$appId = $(az ad app list --display-name <APP_NAME> --query "[].appId" -o tsv)
- Create a service principal and save the id
az ad sp create --id $appId
$assigneeObjectId = $(az ad sp show --id $appId --query id -o tsv)
- Create a new role assignment
az role assignment create --role contributor --subscription $subscriptionId --assignee-object-id $assigneeObjectId --assignee-principal-type ServicePrincipal --scope /subscriptions/$subscriptionId/resourceGroups/<RESOURCE_GROUP_NAME>
- Create federated credentials for the active directory application
az ad app federated-credential create --id $appId --parameters credential.json
credential.json
{
"name": "<CREDENTIAL_NAME>",
"issuer": "https://token.actions.githubusercontent.com",
"subject": "<REPOSITORY_REFERENCE>",
"description": "<DESCRIPTION>",
"audiences": [
"api://AzureADTokenExchange"
]
}
- Get the required ids:
$appId = $(az ad app list --display-name <APP_NAME> --query "[].appId" -o tsv)
$tenantId = $(az account show --query tenantId -o tsv)
$subscriptionId = $(az account show --query id -o tsv)
-
Go to Settings in the GitHub repository
-
Navigate to Security > Secrets and variables > Actions
-
Create and save the following three secrets
GitHub secret Copy value from AZURE_CLIENT_ID $appId AZURE_TENANT_ID $tenantId AZURE_SUBSCRIPTION_ID $subscriptionId