{"id":20699,"date":"2025-01-23T13:15:06","date_gmt":"2025-01-23T13:15:06","guid":{"rendered":"http:\/\/www.devopsschool.com\/blog\/?p=20699"},"modified":"2025-01-23T13:16:13","modified_gmt":"2025-01-23T13:16:13","slug":"kubernetes-resourcequota-limitrange-example-programs","status":"publish","type":"post","link":"https:\/\/www.devopsschool.com\/blog\/kubernetes-resourcequota-limitrange-example-programs\/","title":{"rendered":"Kubernetes ResourceQuota &#038; LimitRange Example Programs"},"content":{"rendered":"\n<p>Kubernetes ResourceQuota and LimitRange are two important mechanisms for managing resource allocation and usage within a Kubernetes cluster.<\/p>\n\n\n\n<p>Here&#8217;s a comparison of ResourceQuota and LimitRange features and use cases in a tabular format:<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>Feature<\/th><th>ResourceQuota<\/th><th>LimitRange<\/th><\/tr><\/thead><tbody><tr><td>Scope<\/td><td>Namespace-wide<\/td><td>Individual pods and containers<\/td><\/tr><tr><td>Purpose<\/td><td>Limit aggregate resource consumption<\/td><td>Set constraints on individual resources<\/td><\/tr><tr><td>Resource Types<\/td><td>CPU, memory, storage, object counts<\/td><td>CPU, memory<\/td><\/tr><tr><td>Default Values<\/td><td>Does not set defaults<\/td><td>Can set default requests and limits<\/td><\/tr><tr><td>Enforcement Level<\/td><td>Across all pods in a namespace<\/td><td>Per pod or container<\/td><\/tr><tr><td>Ratio Enforcement<\/td><td>No<\/td><td>Can enforce request-to-limit ratio<\/td><\/tr><tr><td>Object Creation<\/td><td>Can limit number of objects by type<\/td><td>N\/A<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>Use Case<\/th><th>ResourceQuota<\/th><th>LimitRange<\/th><\/tr><\/thead><tbody><tr><td>Prevent resource overuse by a team<\/td><td>\u2713<\/td><td><\/td><\/tr><tr><td>Ensure fair resource distribution<\/td><td>\u2713<\/td><td><\/td><\/tr><tr><td>Set default resource requests\/limits<\/td><td><\/td><td>\u2713<\/td><\/tr><tr><td>Prevent creation of pods without limits<\/td><td><\/td><td>\u2713<\/td><\/tr><tr><td>Limit storage consumption<\/td><td>\u2713<\/td><td><\/td><\/tr><tr><td>Control number of objects (e.g., services, ConfigMaps)<\/td><td>\u2713<\/td><td><\/td><\/tr><tr><td>Enforce minimum resource requirements<\/td><td><\/td><td>\u2713<\/td><\/tr><tr><td>Prevent excessive resource allocation to single pod<\/td><td><\/td><td>\u2713<\/td><\/tr><tr><td>Maintain consistent request-to-limit ratios<\/td><td><\/td><td>\u2713<\/td><\/tr><tr><td>Isolate resources between different environments (dev\/prod)<\/td><td>\u2713<\/td><td><\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<p>This comparison highlights the complementary nature of ResourceQuota and LimitRange in managing Kubernetes cluster resources effectively.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">ResourceQuota<\/h2>\n\n\n\n<p>ResourceQuota is used to limit the aggregate resource consumption per namespace. It can restrict:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Total compute resources (CPU and memory) that can be requested<\/li>\n\n\n\n<li>Number of objects that can be created by type (e.g., pods, services)<\/li>\n\n\n\n<li>Total storage resources that can be consumed<\/li>\n<\/ul>\n\n\n\n<p>Key features:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Applied at the namespace level<\/li>\n\n\n\n<li>Limits the sum of resources across all pods in a namespace<\/li>\n\n\n\n<li>Enforces constraints on both resource requests and limits<\/li>\n<\/ul>\n\n\n\n<p>Example ResourceQuota:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"CSS\" data-shcb-language-slug=\"css\"><span><code class=\"hljs language-css\"><span class=\"hljs-selector-tag\">apiVersion<\/span>: <span class=\"hljs-selector-tag\">v1<\/span>\n<span class=\"hljs-selector-tag\">kind<\/span>: <span class=\"hljs-selector-tag\">ResourceQuota<\/span>\n<span class=\"hljs-selector-tag\">metadata<\/span>:\n  <span class=\"hljs-selector-tag\">name<\/span>: <span class=\"hljs-selector-tag\">compute-resources<\/span>\n<span class=\"hljs-selector-tag\">spec<\/span>:\n  <span class=\"hljs-selector-tag\">hard<\/span>:\n    <span class=\"hljs-selector-tag\">requests<\/span><span class=\"hljs-selector-class\">.cpu<\/span>: \"2\"\n    <span class=\"hljs-selector-tag\">requests<\/span><span class=\"hljs-selector-class\">.memory<\/span>: 1<span class=\"hljs-selector-tag\">Gi<\/span>\n    <span class=\"hljs-selector-tag\">limits<\/span><span class=\"hljs-selector-class\">.cpu<\/span>: \"4\"\n    <span class=\"hljs-selector-tag\">limits<\/span><span class=\"hljs-selector-class\">.memory<\/span>: 2<span class=\"hljs-selector-tag\">Gi<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">CSS<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">css<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<h2 class=\"wp-block-heading\">LimitRange<\/h2>\n\n\n\n<p>LimitRange sets constraints on individual pods and containers within a namespace. It can:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Enforce minimum and maximum compute resources per pod or container<\/li>\n\n\n\n<li>Set default request\/limit values for containers<\/li>\n\n\n\n<li>Enforce a ratio between request and limit for a resource<\/li>\n<\/ul>\n\n\n\n<p>Key features:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Applied at the pod and container level within a namespace<\/li>\n\n\n\n<li>Sets default values for resource requests and limits<\/li>\n\n\n\n<li>Can prevent the creation of pods that don&#8217;t meet the specified constraints<\/li>\n<\/ul>\n\n\n\n<p>Example LimitRange:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\">apiVersion: v1\n<span class=\"hljs-attr\">kind<\/span>: LimitRange\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: limit-mem-cpu-per-container\n<span class=\"hljs-attr\">spec<\/span>:\n  limits:\n  - <span class=\"hljs-keyword\">default<\/span>:\n      cpu: <span class=\"hljs-number\">500<\/span>m\n      <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">512<\/span>Mi\n    <span class=\"hljs-attr\">defaultRequest<\/span>:\n      cpu: <span class=\"hljs-number\">200<\/span>m\n      <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">256<\/span>Mi\n    <span class=\"hljs-attr\">type<\/span>: Container<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<h2 class=\"wp-block-heading\">Use Cases<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>ResourceQuota: Useful for enforcing overall resource constraints in a shared cluster environment, preventing one team or application from consuming all available resources.<\/li>\n\n\n\n<li>LimitRange: Helpful for setting reasonable defaults and preventing the creation of pods with excessive resource requirements or no specified limits.<\/li>\n<\/ul>\n\n\n\n<p>By using both ResourceQuota and LimitRange together, cluster administrators can effectively manage resource allocation and ensure fair usage across different teams and applications within a Kubernetes cluster.<\/p>\n\n\n\n<p><\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-3\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\">apiVersion: v1\n<span class=\"hljs-attr\">kind<\/span>: Namespace\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: myspace\n---\napiVersion: v1\n<span class=\"hljs-attr\">kind<\/span>: ResourceQuota\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: compute-quota\n  <span class=\"hljs-attr\">namespace<\/span>: myspace\n<span class=\"hljs-attr\">spec<\/span>:\n  hard:\n    requests.cpu: <span class=\"hljs-string\">\"1\"<\/span>\n    requests.memory: <span class=\"hljs-number\">1<\/span>Gi\n    limits.cpu: <span class=\"hljs-string\">\"2\"<\/span>\n    limits.memory: <span class=\"hljs-number\">2<\/span>Gi\n---\napiVersion: v1\n<span class=\"hljs-attr\">kind<\/span>: ResourceQuota\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: object-quota\n  <span class=\"hljs-attr\">namespace<\/span>: myspace\n<span class=\"hljs-attr\">spec<\/span>:\n  hard:\n    configmaps: <span class=\"hljs-string\">\"10\"<\/span>\n    <span class=\"hljs-attr\">persistentvolumeclaims<\/span>: <span class=\"hljs-string\">\"4\"<\/span>\n    <span class=\"hljs-attr\">replicationcontrollers<\/span>: <span class=\"hljs-string\">\"20\"<\/span>\n    <span class=\"hljs-attr\">secrets<\/span>: <span class=\"hljs-string\">\"10\"<\/span>\n    <span class=\"hljs-attr\">services<\/span>: <span class=\"hljs-string\">\"10\"<\/span>\n    services.loadbalancers: <span class=\"hljs-string\">\"2\"<\/span>\n\n\n\n<span class=\"hljs-attr\">apiVersion<\/span>: extensions\/v1beta1\n<span class=\"hljs-attr\">kind<\/span>: Deployment\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: helloworld-deployment\n  <span class=\"hljs-attr\">namespace<\/span>: myspace\n<span class=\"hljs-attr\">spec<\/span>:\n  replicas: <span class=\"hljs-number\">3<\/span>\n  <span class=\"hljs-attr\">template<\/span>:\n    metadata:\n      labels:\n        app: helloworld\n    <span class=\"hljs-attr\">spec<\/span>:\n      containers:\n      - name: k8s-demo\n        <span class=\"hljs-attr\">image<\/span>: wardviaene\/k8s-demo\n        <span class=\"hljs-attr\">ports<\/span>:\n        - name: nodejs-port\n          <span class=\"hljs-attr\">containerPort<\/span>: <span class=\"hljs-number\">3000<\/span>\n        <span class=\"hljs-attr\">resources<\/span>:\n          requests:\n            cpu: <span class=\"hljs-number\">200<\/span>m\n            <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">0.5<\/span>Gi\n          <span class=\"hljs-attr\">limits<\/span>:\n            cpu: <span class=\"hljs-number\">400<\/span>m\n            <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">1<\/span>Gi\n\n\n<span class=\"hljs-attr\">apiVersion<\/span>: v1\n<span class=\"hljs-attr\">kind<\/span>: LimitRange\n<span class=\"hljs-attr\">metadata<\/span>:\n  name: limits\n  <span class=\"hljs-attr\">namespace<\/span>: myspace\n<span class=\"hljs-attr\">spec<\/span>:\n  limits:\n  - <span class=\"hljs-keyword\">default<\/span>:\n      cpu: <span class=\"hljs-number\">200<\/span>m\n      <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">512<\/span>Mi\n    <span class=\"hljs-attr\">defaultRequest<\/span>:\n      cpu: <span class=\"hljs-number\">100<\/span>m\n      <span class=\"hljs-attr\">memory<\/span>: <span class=\"hljs-number\">256<\/span>Mi\n    <span class=\"hljs-attr\">type<\/span>: Container<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-3\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n<div class=\"epyt-gallery\" data-currpage=\"1\" id=\"epyt_gallery_95101\"><figure class=\"wp-block-embed wp-block-embed-youtube is-type-video is-provider-youtube epyt-figure\"><div class=\"wp-block-embed__wrapper\"><iframe loading=\"lazy\"  id=\"_ytid_75207\"  width=\"760\" height=\"427\"  data-origwidth=\"760\" data-origheight=\"427\" src=\"https:\/\/www.youtube.com\/embed\/?enablejsapi=1&#038;autoplay=0&#038;cc_load_policy=0&#038;cc_lang_pref=&#038;iv_load_policy=1&#038;loop=0&#038;rel=1&#038;fs=1&#038;playsinline=0&#038;autohide=2&#038;theme=dark&#038;color=red&#038;controls=1&#038;disablekb=0&#038;\" class=\"__youtube_prefs__  no-lazyload\" title=\"YouTube player\"  data-epytgalleryid=\"epyt_gallery_95101\"  allow=\"fullscreen; accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share\" referrerpolicy=\"strict-origin-when-cross-origin\" allowfullscreen data-no-lazy=\"1\" data-skipgform_ajax_framebjll=\"\"><\/iframe><\/div><\/figure><div class=\"epyt-gallery-list\"><div>Sorry, there was a YouTube error.<\/div><\/div><\/div>","protected":false},"excerpt":{"rendered":"<p>Kubernetes ResourceQuota and LimitRange are two important mechanisms for managing resource allocation and usage within a Kubernetes cluster. Here&#8217;s a comparison of ResourceQuota and LimitRange features and&#8230; <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_joinchat":[],"footnotes":""},"categories":[4859],"tags":[],"class_list":["post-20699","post","type-post","status-publish","format-standard","hentry","category-kubernetes"],"_links":{"self":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/20699","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/comments?post=20699"}],"version-history":[{"count":4,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/20699\/revisions"}],"predecessor-version":[{"id":48285,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/posts\/20699\/revisions\/48285"}],"wp:attachment":[{"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/media?parent=20699"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/categories?post=20699"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.devopsschool.com\/blog\/wp-json\/wp\/v2\/tags?post=20699"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}