mirror of
https://github.com/ceph/ceph
synced 2025-01-10 13:10:46 +00:00
e2ce8ed1ff
Read balancing may now be managed automatically via the balancer manager module. Users may choose between two new modes: ``upmap-read``, which offers upmap and read optimization simultaneously, or ``read``, which may be used to only optimize reads. Existing balancer commands have also been added to contain more information about read balancing. Run the following commands to test the new automatic behavior: `ceph balancer on` (on by default) `ceph balancer mode <read|upmap-read>` `ceph balancer status` Run the following commands to test the new supervised behavior: `ceph balancer off` `ceph balancer mode <read|upmap-read>` `ceph balancer eval` | `ceph balancer eval <pool-name>` `ceph balancer eval-verbose` | `ceph balancer eval-verbose <pool-name>` `ceph balancer optimize <plan-name>` `ceph balancer show <plan-name>` `ceph balancer eval <plan-name>` `ceph balancer execute <plan-name>` In the balancer module, there is also a new "self_test" function which tests the module's basic functionality. This test can be triggered with the following commands: `ceph mgr module enable selftest` `ceph mgr self-test module balancer` Related Trello: https://trello.com/c/sWoKctzL/859-add-read-balancer-support-inside-the-balancer-module Signed-off-by: Laura Flores <lflores@ibm.com>
58 lines
2.8 KiB
ReStructuredText
58 lines
2.8 KiB
ReStructuredText
============================
|
||
Balancing in Ceph
|
||
============================
|
||
|
||
Introduction
|
||
============
|
||
|
||
In distributed storage systems like Ceph, it is important to balance write and read requests for optimal performance. Write balancing ensures fast storage
|
||
and replication of data in a cluster, while read balancing ensures quick access and retrieval of data in a cluster. Both types of balancing are important
|
||
in distributed systems for different reasons.
|
||
|
||
Upmap Balancing
|
||
==========================
|
||
|
||
Importance in a Cluster
|
||
-----------------------
|
||
|
||
Capacity balancing is a functional requirement. A system like Ceph is as full as its fullest device: When one device is full, the system can not serve write
|
||
requests anymore, and Ceph loses its function. To avoid filling up devices, we want to balance capacity across the devices in a fair way. Each device should
|
||
get a capacity proportional to its size so all devices have the same fullness level. From a performance perspective, capacity balancing creates fair share
|
||
workloads on the OSDs for write requests.
|
||
|
||
Capacity balancing is expensive. The operation (changing the mapping of pgs) requires data movement by definition, which takes time. During this time, the
|
||
performance of the system is reduced.
|
||
|
||
In Ceph, we can balance the write performance if all devices are homogeneous (same size and performance).
|
||
|
||
How to Balance Capacity in Ceph
|
||
-------------------------------
|
||
|
||
See :ref:`upmap` for more information.
|
||
|
||
Read Balancing
|
||
==============
|
||
|
||
Unlike capacity balancing, read balancing is not a strict requirement for Ceph’s functionality. Instead, it is a performance requirement, as it helps the system
|
||
“work” better. The overall goal is to ensure each device gets its fair share of primary OSDs so read requests are distributed evenly across OSDs in the cluster.
|
||
Unbalanced read requests lead to bad performance because of reduced overall cluster bandwidth.
|
||
|
||
Read balancing is cheap. Unlike capacity balancing, there is no data movement involved. It is just a metadata operation, where the osdmap is updated to change
|
||
which participating OSD in a pg is primary. This operation is fast and has no impact on the cluster performance (except improved performance when the operation
|
||
completes – almost immediately).
|
||
|
||
In Ceph, we can balance the read performance if all devices are homogeneous (same size and performance). However, in future versions, the read balancer can be improved
|
||
to achieve overall cluster performance in heterogeneous systems.
|
||
|
||
How to Balance Reads in Ceph
|
||
----------------------------
|
||
See :ref:`read_balancer` for more information.
|
||
|
||
Also, see the Cephalocon 2023 talk `New Read Balancer in Ceph <https://www.youtube.com/watch?v=AT_cKYaQzcU/>`_ for a demonstration of the offline version
|
||
of the read balancer.
|
||
|
||
Plans for the Next Version
|
||
--------------------------
|
||
|
||
1. Improve behavior for heterogeneous OSDs in a pool
|