Skip to content

Commit

Permalink
📝 update capacity planning doc
Browse files Browse the repository at this point in the history
Signed-off-by: vankichi <[email protected]>
  • Loading branch information
vankichi committed Jan 18, 2024
1 parent 958f7f4 commit e8383ef
Showing 1 changed file with 17 additions and 6 deletions.
23 changes: 17 additions & 6 deletions docs/user-guides/capacity-planning.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,34 +6,45 @@ Capacity planning is essential before deploying the Vald cluster to the cloud se
There are three viewpoints: Vald cluster view, Kubernetes view, and Component view.
Let's see each view.

<div class="notice">
When introducing production, we recommend that you actually measure how many resources are required for verification.
</div>

## Vald cluster view

The essential point at the Vald cluster view is the hardware specification, especially RAM.
The Vald cluster, especially Vald Agent components, requires much RAM capacity because the vector index is stored in memory.

It is easy to figure out the minimum required RAM capacity by the following formula.
The minimum required memory for each vector (bit) is:

```bash
// minimum required bit of vector
{ oid (64bit) + timestamp (64bit) + uuid (user defined) } * 2 + { dimension * 64 } + { the creation edge size + the search edge size } * 8
```
Considering the `index size` and `index_replica`, it is easy to figure out the minimum required RAM capacity by the following formula.
```bash
( { the dimension vector } × { bit number of vector } + { the bit of vectors ID string } ) × { the maximum number of the vector } × { the index replica }
{ minimum required bit of vector } * { the index size } * { index_replica }
```
For example, if you want to insert 1 million vectors with 900 dimensions and the object type is 32-bit with 32 byte (256 bit) ID, and the index replica is 3, the minimum required RAM capacity is:
For example, you want to insert 1 million vectors with 900 dimensions with 32 byte (256 bit) UUID, the index replica is 3, `creation edge size` is 20, and `search edge size` is 10, the minimum required RAM capacity is:
```bash
(900 × 32 + 256 ) × 1,000,000 × 3 = 8,7168,000,000 (bit) = 10.896 (GB)
{(64 + 64 + 256) × 2 + (900 × 64) + (20 + 10) × 8 } × 1,000,000 × 3 = 175,824,000,000 (bit) = 21.978 (GB)
```
It is just the minimum required RAM for indexing.
Considering the margin of RAM capacity, the minimum RAM capacity should be less than 60% of the actual RAM capacity.
Therefore, the actual minimum RAM capacity will be:
```bash
8,7168,000,000 (bit) / 0.6 = 145,280,000,000 (bit) = 18.16 (GB)
8,7168,000,000 (bit) / 0.6 = 145,280,000,000 (bit) = 36.63 (GB)
```
<div class="warn">
In the production usage, memory usage may be not enough in the minimum required RAM.<BR>
E.g., there are a noisy problem, high memory usage for createIndex (indexing on memory), high traffic needs more memory, etc.
Because for example, there are a noisy problem, high memory usage for createIndex (indexing on memory), high traffic needs more memory, etc.
</div>
## Kubernetes cluster view
Expand Down

0 comments on commit e8383ef

Please sign in to comment.