Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

By the end of week 4, students will have a good understanding of how to work with multi-container applications and how to simplify their deployment using Docker Compose. The hands-on exercise will give them practical experience working with multi-container applications, and this will prepare them for next weeks where they will learn how to use orchestration tools like Kubernetes to manage the deployment of multi-container applications at scale.

Week 5: Introduction to Kubernetes

  • Overview of Kubernetes and its components: Explain what Kubernetes is, its main components such as Pods, Services, Replication Controllers, etc. and how they work together.

  • Understanding the role of Kubernetes in container orchestration: Discuss the benefits of using Kubernetes, such as scaling, failover, and service discovery.

  • Hands-on exercise: Deploying a multi-container application to a Kubernetes cluster: Provide instructions on how to deploy a multi-container application to a Kubernetes cluster using manifests, including creating pods, services, and deployments, and how to configure and access the application.

Weekly Objectives

  • Introduction to Kubernetes: Students will be able to understand what Kubernetes is and its main components.

  • Understanding the role of Kubernetes: Students will be able to discuss the benefits of using Kubernetes in container orchestration.

  • Hands-on experience: Students will be able to deploy a multi-container application to a Kubernetes cluster.

By the end of week 5, students will have a good understanding of how to use Kubernetes for container orchestration, its components and how it works. The hands-on exercise will give them practical experience working with Kubernetes and deploying multi-container applications, this will prepare them for next weeks where they will learn how to use infrastructure as code tools to deploy and manage Kubernetes clusters.

Week 6: Extended Kubernetes Concepts Part 1

  • Introduction to Service Mesh: Explain what a Service Mesh is, its main components, and its role in improving service communication and security in a Kubernetes cluster.

  • Understanding Ingress and Kubernetes Services: Discuss the role of Ingress and Kubernetes Services in routing traffic to pods within a cluster, and how to configure and use them.

  • Understanding Volumes and VolumeMounts: Explain the role of Volumes and VolumeMounts in providing persistent storage for pods, and how to configure and use them.

  • Introduction to Operators and Service Accounts: Explain what Operators and Service Accounts are, and how they can be used to automate and manage complex applications and to provide specific permissions and access controls to pods.

  • Introduction to Helm: Explain what Helm is and how it can be used as a package manager for Kubernetes to manage, install, and upgrade applications and resources.

Weekly Objectives

  • Introduction to Service Mesh: Students will be able to understand what a Service Mesh is, its main components, and its role in improving service communication and security in a Kubernetes cluster.

  • Understanding Ingress and Kubernetes Services: Students will be able to understand the role of Ingress and Kubernetes Services in routing traffic to pods within a cluster, and how to configure and use them.

  • Understanding Volumes and VolumeMounts: Students will be able to understand the role of Volumes and VolumeMounts in providing persistent storage for pods, and how to configure and use them.

  • Introduction to Operators and Service Accounts: Students will be able to understand what Operators and Service Accounts are, and how they can be used to automate and manage complex applications and to provide specific permissions and access controls to pods.

  • Introduction to Helm: Students will be able to understand what Helm is and how it can be used as a package manager for Kubernetes to manage, install, and upgrade applications and resources.

...

  • Introduction to mTLS and Role-Based Access Control (RBAC): Explain the importance of mutual Transport Layer Security (mTLS) in securing communication between pods and services, and how to configure it. Understand the Role-Based Access Control (RBAC) in securing access to a Kubernetes cluster and how to configure it.

  • Introduction to the Open Policy Agent (OPA): Explain what the Open Policy Agent is, its role in providing fine-grained policy enforcement in a Kubernetes cluster, and how to use it to define and enforce policies.

  • Introduction to Container Network Interface (CNI): Explain what the CNI is, its role in providing network connectivity to pods, and how to configure and use it in a Kubernetes cluster.

  • Hands-on exercise: Securing a Kubernetes cluster with mTLS and RBAC, Enforcing policies with OPA, and Configuring network connectivity with CNI.

Weekly Objectives

  • Introduction to mTLS and Role-Based Access Control (RBAC): Students will be able to understand the importance of mutual Transport Layer Security (mTLS) in securing communication between pods and services, and how to configure it. They will also be able to understand the Role-Based Access Control (RBAC) in securing access to a Kubernetes cluster and how to configure it.

  • Introduction to the Open Policy Agent (OPA): Students will be able to understand what the Open Policy Agent is, its role in providing fine-grained policy enforcement in a Kubernetes cluster, and how to use it to define and enforce policies.

  • Introduction to Container Network Interface (CNI): Students will be able to understand what the CNI is, its role in providing network connectivity to pods, and how to configure and use it in a Kubernetes cluster.

  • Hands-on experience: Students will be able to secure a Kubernetes cluster with mTLS and RBAC, enforce policies with OPA, and configure network connectivity with CNI.

...

  • Introduction to Infrastructure as Code (IaC): Explain what IaC is, its benefits, and how it can be used to automate the provisioning, configuration, and management of infrastructure.

  • Introduction to Terraform: Introduce Terraform, its features and how it can be used to define, provision and manage infrastructure as code.

  • Hands-on exercise: Creating and deploying a Kubernetes cluster using Terraform: Provide instructions on how to create and deploy a Kubernetes cluster using Terraform, including configuring and provisioning resources such as VMs, Load Balancers, and DNS, and how to manage and update the cluster over time.

  • Hands-on exercise: Creating a CI/CD pipeline using Github Actions: Provide instructions on how to create a CI/CD pipeline using Github Actions, including building, testing, and deploying code changes to the Kubernetes cluster provisioned using Terraform.

Weekly Objectives

  • Introduction to IaC: Students will be able to understand what IaC is, its benefits, and how it can be used to automate the provisioning, configuration, and management of infrastructure.

  • Introduction to Terraform: Students will be able to understand what Terraform is, its features and how it can be used to define, provision, and manage infrastructure as code.

  • Hands-on experience: Students will be able to create and deploy a Kubernetes cluster using Terraform.

  • Hands-on experience: Students will be able to create a CI/CD pipeline using Github Actions, including building, testing, and deploying code changes to the Kubernetes cluster provisioned using Terraform.

...