Hardware requirements for nodes
This page documents the preview version (v2.23). Preview includes features under active development and is for development and testing only. For production, use the stable version (v2024.1). To learn more, see Versioning.
Refer to Hardware requirements for database cluster node hardware requirements. In particular, note the following sections:
It is recommended to use separate disks for the Linux OS and for the data.
Refer to Hardware requirements for database cluster node hardware requirements. In particular, note the following sections:
-
Amazon Web Services instance type and volume recommendations
Note: The ephemeral disk-based instances (such as i3) in this list come with certain restrictions for Day 2 YugabyteDB Anywhere (YBA) operations. Instances with EBS attached storage are recommended.
Refer to Hardware requirements for database cluster node hardware requirements. In particular, note the following sections:
-
Google Cloud instance type and volume type recommendations
Note that using local disks comes with certain restrictions for Day 2 YBA operations. For YBA, remote disks are recommended.
Refer to Hardware requirements for database cluster node hardware requirements. In particular, note the following sections:
- CPU and RAM
- Verify support for SSE2 and SSE4.2
- Disks
- Azure instance type and disk type recommendations
YBA does not support using ephemeral OS disks for Azure DB clusters.
Compute requirements
In general, a Kubernetes node that is running YBDB pods is expected to meet the following requirements:
- 5 cores (minimum) or 8 cores (recommended)
- 15 GB RAM (minimum)
- 100 GB SSD disk (minimum)
- 64-bit CPU architecture
However, to estimate the exact resources needed, see CPU and RAM for the CPU and RAM requirements for each yb-tserver and yb-master pod. For proper fault tolerance, each Kubernetes node should not run more than one yb-tserver and one yb-master pod. Use these requirements to estimate the total node capacity required in each of the zones that are part of the Kubernetes cluster.
Storage requirements
An appropriate storage class has to be specified both during YBA installation and when creating the Kubernetes provider configuration. The type of volume provisioned for YugabyteDB depends on the Kubernetes storage class being used. Consider the following recommendations when selecting or creating a storage class:
-
Use dynamically provisioned volumes for YBA and YBDB cluster pods. Set volume binding mode on a storage class to
WaitForFirstConsumer
for such volumes. This delays provisioning until a pod using the persistent volume claim (PVC) is created. The pod topology or scheduling constraints are respected.Scheduling might fail if the storage volume is not accessible from all the nodes in a cluster and the default volume binding mode is set to
Immediate
for certain regional cloud deployments. The volume may be created in a location or zone that is not accessible to the pod, causing the failure.On Google Cloud Provider (GCP), if you choose not to set binding mode to
WaitForFirstConsumer
, you might use regional persistent disks to replicate data between two zones in the same region on Google Kubernetes Engine (GKE). This can be used by the pod when it reschedules to another node in a different zone. For more information, see the following: -
Use a storage class based on remote volumes (like cloud provider disks) rather than local storage volumes attached directly to the kubernetes node or local ephemeral volumes. Local storage provides great performance, but the data is not replicated and can be lost if the node fails or undergoes maintenance, requiring a full remote bootstrap of YugabyteDB data in a pod. Local storage is not recommended for production use cases.
-
Use an SSD-based storage class and an extent-based file system (XFS), as per recommendations provided in Deployment checklist - Disks.
-
Set the
allowVolumeExpansion
totrue
. This enables you to expand the volumes later by performing additional steps if you run out of disk space. Note that some storage providers might not support this setting. For more information, see Expanding persistent volumes claims. -
The storage class for most cloud providers allows further configuration like IOPS and throughput and volume types. It is recommended to configure these parameters to match the recommended parameters as listed in Public clouds. For information on these configuration parameters, refer to the AWS, GCP, and Azure documentation.
The following is a sample storage class YAML file for Google Kubernetes Engine (GKE). You are expected to modify it to suit your Kubernetes cluster:
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: yb-storage
provisioner: kubernetes.io/gce-pd
volumeBindingMode: WaitForFirstConsumer
allowVolumeExpansion: true
parameters:
type: pd-ssd
fstype: xfs