Defining Resource Defaults and Limitations within a Namespace
In this lesson, we will find out why resource defaults and limitations are needed and how to define these.
We'll cover the following
Why we Need Resource Defaults and Limitations?
We already learned how to leverage Kubernetes Namespaces to create clusters within a cluster. When combined with RBAC, we can create Namespaces and give users permissions to use them without exposing the whole cluster. Still, one thing is missing.
We can, let’s say, create a test
Namespace and allow users to create objects without permitting them to access other Namespaces. Even though that is better than allowing everyone full access to the cluster, such a strategy would not prevent people from bringing the whole cluster down or affecting the performance of applications running in other Namespaces. The piece of the puzzle we’re missing is resource control on the Namespace level.
We already discussed that every container should have resource limits
and requests
defined. That information helps Kubernetes schedule Pods more efficiently. It also provides it with the information it can use to decide whether a Pod should be evicted or restarted.
Still, the fact that we can specify resources
does not mean that we are forced to define them. We should have the ability to set default resources
that will be applied when we forget to specify them explicitly.
Even if we define default resources
, we also need a way to set limits. Otherwise, everyone with permissions to deploy a Pod can potentially run an application that requests more resources than we’re willing to give.
Defining Default Requests and Limits
Our next task is to define default requests and limits as well as to specify minimum and maximum values someone can define for a Pod.
Creating a Namespace
We’ll start by creating a test Namespace.
Get hands-on with 1400+ tech skills courses.