Kubernetes is an open source container orchestration tool developed by Google. You can run and manage container-based workloads by using Kubernetes. The most common Kubernetes use case is to deploy an array of interconnected microservices, building an application in a cloud native way. You can create Kubernetes clusters that can span hosts across on-premise, public, private, or hybrid clouds.
Traditionally, applications were deployed on top of a single operating system. With virtualization, you can split the physical host into several virtual hosts. Working on virtual instances on shared resources is not optimal for efficiency and scalability. Because a virtual machine (VM) consumes as many resources as a physical machine, providing resources to a VM such as CPU, RAM, and storage can be expensive. Also, you might see your application degrading in performance due to virtual instance usage on shared resources.
To solve this problem, you can use containerization technologies that segregate applications in a containerized environment. Similar to a VM, a container has its own filesystem, vCPU, memory, process space, dependencies, and more. Containers are decoupled from the underlying infrastructure, and are portable across clouds and OS distributions. Containers are inherently much lighter than a fully-featured OS, and are lightweight isolated processes that run on the operating system kernel. VMs are slower to boot, and are an abstraction of physical hardware. VMs run on a single machine with the help of a hypervisor.
You can perform the following actions by using Kubernetes:
Sharing resources
Orchestrating containers across multiple hosts
Installing new hardware configurations
Running health checks and self-healing applications
Scaling containerized applications
| Component | Purpose | 
|---|---|
| 
 | Runs on every node in the cluster and maintains the network traffic between the Kubernetes resources. | 
| 
 | Governs the state of the cluster. | 
| 
 | Allocates pods to nodes. | 
| 
 | Stores cluster data. | 
| 
 | Validates and configures data for the API objects. | 
| 
 | Runs on nodes and reads the container manifests. Ensures that the defined containers have started and are running. | 
| 
 | Allows you to define how you want to run workloads. Use the  | 
| Node | Node is a physical machine or a VM in a Kubernetes cluster. The control plane manages every node and schedules pods across the nodes in the Kubernetes cluster. | 
| container runtime | container runtime runs containers on a host operating system. You must install a container runtime on each node so that pods can run on the node. | 
| Persistent storage | Stores the data even after the device is shut down. Kubernetes uses persistent volumes to store the application data. | 
| 
 | Stores and accesses the container images. | 
| Pod | The pod is the smallest logical unit in Kubernetes. A pod contains one or more containers to run in a worker node. | 
A custom resource is an extension of the Kubernetes API. You can customize Kubernetes clusters by using custom resources. Operators are software extensions which manage applications and their components with the help of custom resources. Kubernetes uses a declarative model when you want a fixed desired result while dealing with cluster resources. By using Operators, Kubernetes defines its states in a declarative way. You can modify the Kubernetes cluster resources by using imperative commands. An Operator acts as a control loop which continuously compares the desired state of resources with the actual state of resources and puts actions in place to bring reality in line with the desired state.
| Resource | Purpose | 
|---|---|
| Service | Kubernetes uses services to expose a running application on a set of pods. | 
| 
 | Kubernetes uses the  | 
| Deployment | A resource object that maintains the life cycle of an application. | 
Kubernetes is a core component of an OKD. You can use OKD for developing and running containerized applications. With its foundation in Kubernetes, the OKD incorporates the same technology that serves as the engine for massive telecommunications, streaming video, gaming, banking, and other applications. You can extend your containerized applications beyond a single cloud to on-premise and multi-cloud environments by using the OKD.
A cluster is a single computational unit consisting of multiple nodes in a cloud environment. A Kubernetes cluster includes a control plane and worker nodes. You can run Kubernetes containers across various machines and environments. The control plane node controls and maintains the state of a cluster. You can run the Kubernetes application by using worker nodes. You can use the Kubernetes namespace to differentiate cluster resources in a cluster. Namespace scoping is applicable for resource objects, such as deployment, service, and pods. You cannot use namespace for cluster-wide resource objects such as storage class, nodes, and persistent volumes.
Before getting started with the OKD, consider these conceptual guidelines of Kubernetes:
Start with one or more worker nodes to run the container workloads.
Manage the deployment of those workloads from one or more control plane nodes.
Wrap containers in a deployment unit called a pod. By using pods provides extra metadata with the container and offers the ability to group several containers in a single deployment entity.
Create special kinds of assets. For example, services are represented by a set of pods and a policy that defines how they are accessed. This policy allows containers to connect to the services that they need even if they do not have the specific IP addresses for the services. Replication controllers are another special asset that indicates how many pod replicas are required to run at a time. You can use this capability to automatically scale your application to adapt to its current demand.
The API to OKD cluster is 100% Kubernetes. Nothing changes between a container running on any other Kubernetes and running on OKD. No changes to the application.
OKD brings added-value features to provide enterprise-ready enhancements to Kubernetes. OKD CLI tool  (oc) is compatible with kubectl. While the Kubernetes API is 100% accessible within OKD, the kubectl command-line lacks many features that could make it more user-friendly. OKD offers a set of features and command-line tool like oc.
Although Kubernetes excels at managing your applications, it does not specify or manage platform-level requirements or deployment processes. Powerful and flexible platform management tools and processes are important benefits that OKD offers. You must add authentication, networking, security, monitoring, and logs management to your containerization platform.