Containers
What are containers?
Containers provide a method to encapsulate code, binaries, libraries, and runtimes. They act as a form of virtualization for an operating system. Containers are run on container orchestrators that provide the scheduling and high availability benefits. The most commonly used containers and container orchestrators are built on open source software, more on this below. Or here is a link to the Wikipedia article that gives a larger overview.
Why is this important for hybrid cloud developers?
Containers are one of the main drivers of modern software development and designing applications for clouds in general. However, containers become more important in a hybrid cloud or multicloud setting where consistency and repeatability are key.
Key open source projects
Container engines and runtimes
Name | GitHub repo | Get Started guide |
---|---|---|
Podman | GitHub Repo | Getting Started |
containerd | GitHub Repo | Getting Started |
Docker | GitHub Repo | Getting Started |
Container orchestrators
Container registry
Name | GitHub repo | Get Started guide |
---|---|---|
Docker Hub | N/A | Getting Started |
Quay | GitHub repo | Getting Started |
Harbor | GitHub repo | Getting Started |
Cloud comparision
Additional resources
Courses
- CNCF: Certification and Training
- CognitiveClass.ai: Introduction to Containers, Kubernetes, and OpenShift
- LinuxFoundation: Certification and Training
Blogs
Videos
- Getting started with containers and Kubernetes
- Kubernetes Tutorial for Beginners (TechWorld with Nana)
- Kubernetes 101 - Episode 1 (Jeff Geerling)