Logo

dev-resources.site

for different kinds of informations.

Introduction to Containers - The Foundation!

Published at
12/3/2024
Categories
aws
containers
docker
kubernetes
Author
Koti Vellanki
Categories
4 categories in total
aws
open
containers
open
docker
open
kubernetes
open
Introduction to Containers - The Foundation!

Welcome to Day 1: The Beginning of Our AWS Containers Journey

"The world of containers unfolds over a father-daughter evening."

Hi there! 👋 Welcome to the first day of our 15-day AWS Containers learning series. Over the next two weeks, we’ll explore concepts, tackle hands-on labs, and dive deep into the world of AWS container services like ECS, EKS, and ECR.

If you’ve just landed here, make sure to check out the Introduction to the Series to understand the context and flow. Each day builds on the last, so don’t skip!

Today, we begin with the foundational topic: Containers. Let’s step into the story of Ovi and her dad as they embark on this learning journey together.

Table of Contents

  1. The Story: Ovi Learns Containers
  2. What Are Containers?
    • Key Features of Containers
  3. Containers vs. Virtual Machines
  4. Advanced Topics: Containers for All Experience Levels
    • Namespaces and Cgroups
    • Container Orchestration
    • Container Runtime
  5. Why Are Containers So Popular?
  6. Security Aspects
  7. Performance Insights
  8. Hands-On Lab for Day 1
  9. Thank You for Reading!

The Story: Ovi Learns Containers

It’s 9 PM, and after finishing his work, Ovi’s Dad, a DevOps Engineer, sits with her in their Bengaluru apartment. Today, he decides to introduce her to a foundational concept in the tech world—containers.

Suddenly, Ovi comes and asks, "Dad, what are you working on?" she asks, tugging his shirt. He smiles, knowing this is the perfect moment to introduce her to the fascinating world of containers.

“Imagine, Ovi, you're packing your toys to take to grandma’s house (Vijayawada / Belagavi). Wouldn't it be easier to pack them neatly in boxes instead of carrying them all in your hands?” he begins, as Ovi nods enthusiastically.

What Are Containers?

Containers are lightweight, portable packages that bundle an application and all its dependencies, ensuring they run consistently across different environments.

Her dad explains, "Just like your toy box keeps everything in one place and ready to use, containers bundle up applications and their dependencies into neat packages. These packages can run reliably, no matter where they’re opened—your grandma’s house, mama-mami’s house, or anywhere else!"

Key Features of Containers:

  1. Portability:

    • Run anywhere—your laptop, a server, or the cloud.
    • Just like Ovi's toy box can be taken from Bengaluru to Vijayawada.
  2. Isolation:

    • Containers keep applications and resources separate, avoiding conflicts.
    • Think of how Ovi’s toy box keeps her toys from mixing with her dad’s work tools!
  3. Efficiency:

    • Containers share the host operating system’s kernel, reducing overhead.
    • This makes them faster and more resource-efficient than Virtual Machines (VMs).

Containers vs. Virtual Machines

Feature Containers Virtual Machines (VMs)
Definition Lightweight environments to run apps. Full operating systems running on a hypervisor.
Boot Time Seconds Minutes
Resource Usage Shares the host OS kernel, lightweight. Requires separate OS instances, heavyweight.
Isolation Process-level isolation; less secure. Strong isolation with separate OS/kernel.
Scalability Highly scalable; smaller size. Slower to scale due to heavy OS instances.
Portability Consistent across environments. Less portable due to OS/hypervisor dependency.
Use Cases Microservices, CI/CD, cloud-native apps. Legacy apps, multi-tenant workloads.
Performance Near-native performance. Lower performance due to virtualization overhead.

Advanced Topics: Containers for All Experience Levels

Namespaces and Cgroups

“Containers achieve isolation by using namespaces and cgroups,” Ovi’s dad explains.

  1. Namespaces:

    • Provide isolated views of system resources for each container.
    • Example: Each container gets its own process tree, network stack, and filesystem view.
    • Analogy: Imagine Ovi playing with her toys in a special corner of the room. Even though her dad is working nearby, she sees her own "world" and doesn’t notice his setup.
  2. Cgroups:

    • Limit the resources containers can use, such as CPU and memory.
    • Analogy: "What if I told you to only play with a few toys at a time to avoid making a mess?" he asks. "That's what cgroups do—they limit how much memory, CPU, or disk a container can use."

Container Orchestration

Ovi’s dad adds, “Managing thousands of containers is like organizing a big party. You need someone to assign tasks, handle issues, and make sure everything runs smoothly.”

  • Orchestration Tools:

    • Examples: Kubernetes, Docker Swarm, AWS ECS.
    • Kubernetes is like the party manager, automating deployment, scaling, and managing containerized applications.
  • Real-Life Analogy:

    • “Imagine you’re at a fair, and Kubernetes is the event organizer making sure every stall is stocked, staffed, and running perfectly!”

Container Runtime

"Docker is a runtime, but it’s not the only one," he explains.

  • Popular Runtimes: Docker, containerd, CRI-O.
  • Analogy: Think of Docker as the engine of a car. While Docker focuses on user-friendliness, containerd and CRI-O are designed for efficiency and Kubernetes-native operations.

Why Are Containers So Popular?

  1. Speed and Agility: Containers boot in seconds and are easy to deploy.
  2. Cloud-Native: Perfect for modern microservices architectures.
  3. Scalability: Spin up or down in response to traffic seamlessly.

Security Aspects

“Containers are secure, but we must stay vigilant,” her dad warns.

Best Practices:

  • Avoid running containers as root.
  • Regularly scan images with tools like Trivy or Clair.
  • Use signed images from trusted registries.

Open-Source Security Tools:

  • Trivy
  • Clair

Performance Insights

“Efficiency is the heart of containers,” he adds.

Benchmarking Tools:

  • Use tools like sysbench and Apache Bench to test container performance.

Trade-offs:

  • Containers share the kernel, which may impact performance in high-I/O scenarios.

Hands-On Lab for Day 1

Check out some practical activities, including:

  1. Installing Docker on an EC2 instance.
  2. Running your first container.
  3. Exploring AWS container services like ECS, ECR, and EKS.

Thank You for Reading!

Thank you so much for reading Day 1 of our 15-day AWS Containers journey. Stay tuned for Day 2, where we’ll dive into Amazon ECS Overview and deploy our first containerized app using Fargate.

Let’s Connect!

Found this helpful? Share it with your network and help others learn about containers!

See you in the next episode! 🚀

Featured ones: