Skip to main content

Installing Sitecore 10.4 on Kubernetes: A Step-by-Step Guide

Introduction

Recently, a community member attempted to install Sitecore 10.4 on a Kubernetes (K8s) cluster and reached out to me regarding the challenges they faced. Despite following Sitecore's standard installation document, they encountered issues due to their limited knowledge of Kubernetes. This blog post summarizes their experience and serves as a reference for other developers in a similar situation.

Steps for Installation

To successfully set up a Sitecore instance in a K8s cluster, follow these detailed steps:

  1. Prerequisites

    • Access to Azure Kubernetes Service (AKS): Ensure you have the ability to create namespaces and clusters in AKS. Having a team member knowledgeable in Kubernetes is highly beneficial.

    • Local Tools: Install Azure CLI, Chocolatey, and Helm on your local machine. You'll be needing these while executing commands in PowerShell.

  2. Cluster Specifications Ensure your cluster meets these specifications:

    • Kubernetes 1.27.x or later

    • Windows Server 2019 version 1809 or later OS node

    • Minimum 16 GB RAM per Kubernetes cluster

    • Quad-core or higher CPU per Kubernetes node

    • Premium SSD disks

    • For non-production environments: Minimum VM size of Standard_D4s_v3

    • For production environments: Minimum VM size of Standard_D8s_v3

  3. Login to Azure Environment Execute the following commands in PowerShell in admin mode to login and retrieve cluster credentials:

    az login
    az aks get-credentials --resource-group <your resource group name> --name <your cluster name>
    
  4. Navigate to Working Directory Change to your working directory where you've unzipped the Sitecore container deployment package:

    cd C:\Projects\<your project name>\k8s\ltsc2022\xp1
  5. Install Ingress Controller Ingress in Sitecore is similar to Traefik in Docker. It's crucial for networking in the cluster as it exposes routes from outside the cluster to services within the cluster. Run following commands to create ingress and ingress controller:

    helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx
    helm install nginx-ingress ingress-nginx/ingress-nginx --set controller.replicaCount=2 --set controller.nodeSelector."beta\.kubernetes\.io/os"=linux --set defaultBackend.nodeSelector."beta\.kubernetes\.io/os"=linux --set controller.admissionWebhooks.patch.nodeSelector."kubernetes\.io/os"=linux --set controller.service.externalTrafficPolicy=Local
    kubectl apply -k ./ingress-nginx/
    
  6. Configure Secrets Set up the necessary secrets for Sitecore, including admin passwords and SQL credentials. This will specify certain settings called as Secrets to Cluster:

    .\k8s-init.ps1 -Topology <your topology like xm1 or xp1> -LicenseXmlPath <license path>\license.xml -IdHost <hostname for id server> -CdHost <hostname for cd server> -CmHost <hostname for cm server> -ExternalIPAddress <Ingress controller IP> -SqlUserPassword <sql user password> -SqlUserName sa -SitecoreAdminPassword <Sitecore admin password>
    

    ExternalIPAddress in above command can be retrieved by running:

    kubectl get ingress
  7. Deploy Secrets to Cluster

    kubectl apply -k ./secrets/
  8. Set Up External Services Deploy MSSQL, Solr, and Redis, which are prerequisites for Sitecore:

    kubectl apply -k ./external/
  9. Run Initialization Scripts Initialize MSSQL and Solr:

    kubectl apply -k ./init/
    kubectl wait --for=condition=Complete job.batch/mssql-init --timeout=900s
    
  10. Create Storage Volumes This deploys a persistent volume claim:

    kubectl apply -f ./volumes/azurefile
  11. Install Sitecore Pods Deploy the Sitecore cd, cm, and id pods:

    kubectl apply -k ./

    This process may take 30 minutes to an hour. Verify pod status with:

    kubectl get pods -n default 

    If any pod is not in a running state, troubleshoot using:

    kubectl describe pod <pod name>
  12. Update Local Hosts File Map Ingress IP to the specified hostnames for cd, cm, and id servers in your hosts file:

    4.175.34.228  cd.sitename.dev
    4.175.34.228  cm.sitename.dev
    4.175.34.228  id.sitename.dev
    

Conclusion

By following these steps, you should be able to successfully set up a Sitecore instance on a Kubernetes cluster. If you encounter issues, consider reaching out to a team member with Kubernetes expertise or leveraging online resources for further assistance. This guide aims to provide a comprehensive reference for developers facing similar challenges in their Sitecore and Kubernetes journey

Comments

POPULAR POSTS

Sitecore PowerShell Script to create all language versions for an item from en version

  We have lots of media items and our business wants to copy the data from en version of media item to all other language versions defined in System/Languages. This ensures that media is available in all the languages. So, we created the below powershell script to achieve the same -  #Get all language versions defined in System/Languages $languages = Get-ChildItem /sitecore/System/Languages -recurse | Select $_.name | Where-Object {$_.name -ne "en"} | Select Name #Ensuring correct items are updated by comparing the template ID  $items = Get-ChildItem -Path "/sitecore/media library/MyProjects" -Recurse | Where-Object {'<media item template id>' -contains $_.TemplateID} #Bulk update context to improve performance New-UsingBlock (New-Object Sitecore.Data.BulkUpdateContext) { foreach($item in $items){    foreach($language in $languages){ $languageVersion = Get-Item -Path $item.Paths.Path -Language $language.Name #Check if language versi...

Export Sitecore media library files to zip using SPE

If you ever require to export Sitecore media files to zip (may be to optimize them), SPE (Sitecore Powershell Extension) has probably the easiest way to do this for you. It's as easy as the below 3 steps -  1. Right click on your folder (icons folder in snap)>Click on Scripts> Click on Download 2. SPE will start zipping all the media files placed within this folder. 3. Once zipping is done, you will see the Download option in the next screen. Click Download Zip containing the media files within is available on your local machine. You can play around with the images now. Hope this helps!! Like and Share ;)

Make Sitecore instance faster using Roslyn Compiler

When we install the Sitecore instance on local, the first load is slow. After each code deploy also, it takes a while for the Sitecore instance to load and experience editor to come up. For us, the load time for Sitecore instance on local machines was around 4 minutes. We started looking for ways to minimize it and found that if we update our Web.config to use Roslyn compiler and include the relevant Nugets into the project, our load times will improve. We followed the simple steps - Go to the Project you wish to add the NuGet package and right click the project and click 'Manage NuGet Packages'. Make sure your 'Package Source' is set to nuget.org and go to the 'Browse' Tab and search Microsoft.CodeDom.Providers.DotNetCompilerPlatform. Install whichever version you desire, make sure you note which version you installed. You can learn more about it  here . After installation, deploy your project, make sure the Microsoft.CodeDom.Providers.DotNetCompilerPlatform.d...

Experience of a first time Sitecore MVP

The Journey I have been working in Sitecore for almost 10 years now. When I was a beginner in Sitecore, I was highly impressed by the incredible community support. In fact, my initial Sitecore learning path was entirely based on community written blogs on Sitecore. During a discussion with my then technology lead Neeraj Gulia , he proposed the idea that I should start giving back to developer community whenever I get chance. Just like I have been helped by many developers via online blogs, stackoverflow etc., I should also try to help others. Fast forward a few years and I met  Nehemiah Jeyakumar  (now an MVP). He had a big archive of his technical notes in the form Sitecore blogs. I realized my first blog dont have to be perfect and it can be as simple as notes to a specific problem for reference in future. That's when I probably created my first blog post on Sitecore. At that time, I didn't knew about the Sitecore MVP program. Over the years, I gained more confidence to writ...

Clean Coding Principles in CSharp

A code shall be easy to read and understand. In this post, I am outlining basic principles  about clean coding after researching through expert recommended books, trainings and based on my experience. A common example to start with is a variable declaration like - int i  The above statement did not clarify the purpose of variable i. However,  the same variable can be declared as -  int pageNumber The moment we declared the variable as int pageNumber, our brain realized that the variable is going to store the value for number of pages. We have set the context in our brain now and it is ready to understand what the code is going to do next with these page numbers. This is one of the basic advantages of clean coding. Reasons for clean coding -  • Reading clean code is easier - Every code is revisited after certain amount of time either by the same or different developer who created it. In both the cases, if the code is unclean, its difficult to understand and u...