Windows Server Container on an AKS (Azure Kubernetes Service) – Preview

Azure Kubernetes Service aka (AKS) is a managed service provided by Microsoft Azure to deploy micro-service applications quickly and managed those apps with less administrative efforts.

With a Kubernetes release of v1.14 it enable the production level support for windows nodes and containers. With this announcement, AKS team announce the Windows server container support for the v1.13.5 and v1.14.0. With this enables now we can run Linux and Windows node pools within the same cluster.

Prerequisite

Note – Don’t enable preview features on production subscriptions. Use a separate test or development Azure subscription for testing preview features.

Limitations

  • Multiple node pools are available for clusters created after you’ve successfully registered the WindowsPreview. Multiple node pools are also available if you register the MultiAgentpoolPreviewand VMSSPreview features for your subscription. You can’t add or manage node pools with an existing AKS cluster created before these features were successfully registered.
  • You can’t delete the first node pool.
  • The AKS cluster can have a maximum of eight node pools.
  • The AKS cluster can have a maximum of 400 nodes across those eight node pools.
  • The Windows Server node pool name has a limit of 6 characters.
  • Windows Server node pools are not available in Canada regions at this time.

Install AKS Preview CLI extension

As of this features are preview first we need to enable preview feature in Azure CLI to access them. If this is the first time using Azure AKS preview features, run below command to enable extension.

If enabled the preview feature previously use below command to update the aks-preview extension to latest version.

aks-cluster

Enable Windows Preview Feature

First enable the WindowsPreview feature on your subscription. This feature uses multi-node pool cluster and VMSS to manage the Kubernetes nodes.

WindowsPreview

This will take few minutes to complete. We can verify the status of the registration from below command.

aks-cluster

After feature is registered refresh the the registration from below command.

aks-cluster

Create Resource Group

When deploying resources to Azure each resource should be deployed to a resource group. Resource group is a logical group in which Azure resources are deployed and managed. Following Azure CLI can use to create new resource group.

aks-clsuter

Create AKS Cluster

For creation of AKS cluster to support windows containers we need to use Azure CNI as the network plugin. When we create a AKS cluster for windows container default it creates a Linux node pool as the default. After creation of the cluster we’ll add the windows node pool to support windows containers. With following command we can create cluster.

In above we use PASSWORD_WIN=”” variable to store the password. Its important to have a strong password with complaint with Azure password policy, otherwise the cluster creation will fail with below error.

Error

If the cluster creation succeeded you can see slimier output as below.

If the cluster creation succeeded

It will take few minutes to complete the cluster creation.

Add Windows Server Node Pool

By default AKS use Linux node pool to create a cluster we can add windows node pool from bellow command.

If the provisioned is succeeded we can see two nodes with Windows and Linux. To verify the nodes first we need to download the credentials to access the API server. Following command can use to download credentials.

Next we can verify the nodes by using kubectl command.

In above output we can see one node is running Ubuntu 16.04.6 LTS and other node runs Windows Server Datacenter. Now we know the deployment is succeeded. Lets use sample app to try windows containers.

Run the Application

We can use following sample app to run windows container inside the windows node. We use nodeSelector:”beta.kubernetes.io/os”: windows property to specify the windows node inside the YAML.

To deploy application, we can use following kubectl command

LabFiles

In above YAML it create Deployment & LoadBalancer Service. To create a load balancer it will take few minutes as it allocate a public IP.


Deployment & LoadBalancer Service

We can test the application by accessing the public IP. If the deployment succeeded we can access the app as below.

ASP.NET

For additional resources follow below links

About the Author:

Consultant with 4+ years of experience in Windows technologies, Networking, Cloud Computing, Server Administration & etc.

Currently I mainly focus on System Center Product such as Operations Manager, Microsoft Operation Management Suit, Azure & AWS. Previous experience includes works with customers from manufacturing & IT service providers.

I like to share my knowledge with others

Twitter :- @KasunSJC

Dream big, Start small, Act now. – Robin Sharma

Reference:

Rajapakse, K. (2019). Available at:
http://www.allaboutwindowssl.com/2019/05/windows-server-container-on-an-aks-azure-kubernetes-service-preview/ [Accessed 10th July 2019].

Share this on...

Rate this Post:

Share: