Kubernetes Workload Resources
Internal
Overview
Workload resources exist to create and manage Pods, which should not usually be created directly. Various workload resources implement different pod operational patterns. The pod-managing resources described here are some times referred to as higher-level pod controllers or "templated controllers".
From the simplest to the most complex ones, the workload resources are Jobs, CronJobs, ReplicaSets, Deployments, DaemonSets and StatefulSets.
Jobs and CronJobs are aimed mainly at running individual pods, as part of one-off or repeated executions.
A ReplicaSet is a resource aimed at maintaining a stable set of replica Pods running at any given time, guaranteeing the availability of a specified number of identical Pods.
The Deployment is a resource that
These controllers are part of and supervised by the controller manager.
TODO
Workload Resource
Describe the relationship between pod, deployment, ReplicaSet and workload resources. Which one are controllers and which are not?
Controller
TODO: https://kubernetes.io/docs/concepts/workloads/pods/#pods-and-controllers
A workload resource has an associated controller. The controller handles replication, rollout and automatic healing in case of pod failure. For example if a node fails, a controller notices that the pods on that node have stopped working and creates replacement pods, which are scheduled on healthy nodes.
Workload resources: