You are looking at the documentation of a prior release. To read the documentation of the latest release, please
visit here.
New to KubeDB? Please start here.
Horizontal Scaling Overview
This guide will give you an overview of how KubeDB enterprise operator scales up/down the number of members of a Postgres instance.
Before You Begin
- You should be familiar with the following KubeDBconcepts:
How Horizontal Scaling Process Works
The following diagram shows how KubeDB enterprise operator used to scale up the number of members of a Postgres cluster. Open the image in a new tab to see the enlarged version.

The horizontal scaling process consists of the following steps:
- At first, a user creates a - Postgrescr.
- KubeDBcommunity operator watches for the- Postgrescr.
- When it finds one, it creates a - StatefulSetand related necessary stuff like secret, service, etc.
- Then, in order to scale the cluster, the user creates a - PostgresOpsRequestcr with the desired number of members after scaling.
- KubeDBenterprise operator watches for- PostgresOpsRequest.
- When it finds one, it halts the - Postgresobject so that the- KubeDBcommunity operator doesn’t perform any operation on the- Postgresduring the scaling process.
- Then - KubeDBenterprise operator will add nodes in case of scale up or remove nodes in case of scale down.
- Then the - KubeDBenterprise operator will scale the StatefulSet replicas to reach the expected number of replicas for the cluster.
- After successful scaling of the StatefulSet’s replica, the - KubeDBenterprise operator updates the- spec.replicasfield of- Postgresobject to reflect the updated cluster state.
- After successful scaling of the - Postgresreplicas, the- KubeDBenterprise operator resumes the- Postgresobject so that the- KubeDBcommunity operator can resume its usual operations.
In the next doc, we are going to show a step by step guide on scaling of a Postgres cluster using Horizontal Scaling.































