Skip to content

Commit

Permalink
feat: configuring number of replicas
Browse files Browse the repository at this point in the history
Signed-off-by: Anatolii Bazko <abazko@redhat.com>
  • Loading branch information
tolusha committed Feb 13, 2024
1 parent 3bd4064 commit 7f4be97
Show file tree
Hide file tree
Showing 4 changed files with 81 additions and 0 deletions.
1 change: 1 addition & 0 deletions modules/administration-guide/nav.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
** xref:configuring-server-components.adoc[]
*** xref:mounting-a-secret-as-a-file-or-an-environment-variable-into-a-container.adoc[]
*** xref:advanced-configuration-options-for-the-che-server-component.adoc[]
*** xref:configuring-number-of-replicas.adoc[]
** xref:configuring-workspaces-globally.adoc[]
*** xref:limiting-the-number-of-workspaces-that-a-user-can-keep.adoc[]
*** xref:enabling-users-to-run-multiple-workspaces-simultaneously.adoc[]
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
:_content-type: ASSEMBLY
:description: Configuring number of replicas for a {prod} container
:keywords: administration guide, configuring-number-of-replicas
:navtitle: Configuring number of replicas for a {prod} container
:page-aliases:

[id="configuring-number-of-replicas"]

include::partial$proc_configuring-number-of-replicas.adoc[leveloffset=+1]

Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,5 @@
= Configuring server components

* xref:mounting-a-secret-as-a-file-or-an-environment-variable-into-a-container.adoc[]
* xref:advanced-configuration-options-for-the-che-server-component.adoc[]
* xref:configuring-number-of-replicas.adoc[]
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
:_content-type: PROCEDURE
:description: Configuring a number of replicas
:keywords: administration-guide, configuring-number-of-replicas
:navtitle: Configuring a number of replicas {prod-cli}
:page-aliases:

[id="configuring-number-of-replicas"]
= Configuring a number of replicas

Check failure on line 8 in modules/administration-guide/partials/proc_configuring-number-of-replicas.adoc

View workflow job for this annotation

GitHub Actions / Linting with Vale

[vale] reported by reviewdog 🐶 [RedHat.TermsErrors] Use 'several' rather than 'a number of'. Raw Output: {"message": "[RedHat.TermsErrors] Use 'several' rather than 'a number of'.", "location": {"path": "modules/administration-guide/partials/proc_configuring-number-of-replicas.adoc", "range": {"start": {"line": 8, "column": 15}}}, "severity": "ERROR"}

To configure the number of replicas for {prod-short} operands using {kubernetes} `HorizontalPodAutoscaler`
(HPA), you can define an `HPA` resource for deployment. The `HPA` dynamically adjusts the number
of replicas based on specified metrics.

.Procedure

. Create an `HPA` resource for a deployment, specifying the target metrics and desired replica count.

Check warning on line 16 in modules/administration-guide/partials/proc_configuring-number-of-replicas.adoc

View workflow job for this annotation

GitHub Actions / Linting with Vale

[vale] reported by reviewdog 🐶 [RedHat.TermsWarnings] Consider using 'needed' or 'required' rather than 'desired' unless updating existing content that uses the term. Raw Output: {"message": "[RedHat.TermsWarnings] Consider using 'needed' or 'required' rather than 'desired' unless updating existing content that uses the term.", "location": {"path": "modules/administration-guide/partials/proc_configuring-number-of-replicas.adoc", "range": {"start": {"line": 16, "column": 80}}}, "severity": "WARNING"}
+
[source,yaml,subs="+attributes,+quotes"]
----
apiVersion: autoscaling/v2
kind: HorizontalPodAutoscaler
metadata:
name: scaler
namespace: {prod-namespace}
spec:
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: __<deployment_name>__ <1>
...
----
<1> The `__<deployment_name>__` corresponds to the one following deployments:
* `{prod-deployment}`
* `che-gateway`
* `{prod-deployment}-dashboard`
* `plugin-registry`
* `devfile-registry`

.Create a `HorizontalPodAutoscaler` for {prod-deployment} deployment:
====
[source,yaml,subs="+attributes,+quotes"]
----
apiVersion: autoscaling/v2
kind: HorizontalPodAutoscaler
metadata:
name: {prod-deployment}-scaler
namespace: {prod-namespace}
spec:
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: {prod-deployment}
minReplicas: 2
maxReplicas: 5
metrics:
- type: Resource
resource:
name: cpu
target:
type: Utilization
averageUtilization: 75
----
In this example, the HPA is targeting the Deployment named {prod-deployment}, with a minimum of 2 replicas, a maximum of 5 replicas
and scaling based on CPU utilization.
====

.Additional resources
* link:https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale[Horizontal Pod Autoscaling]

0 comments on commit 7f4be97

Please sign in to comment.