Skip to main content

About container runtimes in 2 minutes

  • 14 October 2023
  • 2 comments
  • 306 views

Container runtimes are fundamental components of Kubernetes. It is responsible for managing the execution and lifecycle of containers, and it is necessary to choose and install a container runtime into each worker node in the Kubernetes cluster to run PODs.

 

Container runtimes can be categorized into:

• High-level container runtimes: CRI-O, containerd and Docker.

• Low-level container runtimes: runc and crun.

• Sandboxed and virtual container runtimes: runsc (from gVisor) and kata-runtime/the-runtime (from Kata Containers).

 

The Container Runtime Interface (CRI) is the specification in charge of the communication between the kubelet and the high-level runtimes. The CRI defines gRPC APIs that allow the kubelet to interact as a client with different runtimes. CRI performs an abstraction layer for high-level runtimes.

 

The high-level runtimes use a lower-level container runtime to run and manage the components required to deploy and operate containers. Open Container Initiative (OCI) specifications allow the integration of different high- and low-level runtimes.

 

The OCI Runtime Specification is one of the three specifications defined by OCI. It describes the requirements for the runtime environment, the interfaces for containers, and the minimum set of functionalities that high and low-level runtimes must provide to be considered OCI compliant.

 

For more information:

https://kubernetes.io/docs/setup/production-environment/container-runtimes/

 

 

2 comments

Userlevel 7
Badge +21

Interesting post. Enjoy learning about Kubernetes stuff. Thanks for sharing.

Userlevel 6
Badge +3

Nice share, always appreciate the visuals to help explain things

Comment