forked from vitalif/vitastor
42 lines
3.5 KiB
Markdown
42 lines
3.5 KiB
Markdown
|
[Документация](../../README-ru.md#документация) → Производительность → Теоретическая максимальная производительность Vitastor
|
|||
|
|
|||
|
-----
|
|||
|
|
|||
|
[Read in English](theoretical.en.md)
|
|||
|
|
|||
|
# Теоретическая максимальная производительность Vitastor
|
|||
|
|
|||
|
При использовании репликации:
|
|||
|
- Задержка чтения в 1 поток (T1Q1): 1 сетевой RTT + 1 чтение с диска.
|
|||
|
- Запись+fsync в 1 поток:
|
|||
|
- С мгновенным сбросом: 2 RTT + 1 запись.
|
|||
|
- С отложенным ("ленивым") сбросом: 4 RTT + 1 запись + 1 fsync.
|
|||
|
- Параллельное чтение: сумма IOPS всех дисков либо производительность сети, если в сеть упрётся раньше.
|
|||
|
- Параллельная запись: сумма IOPS всех дисков / число реплик / WA либо производительность сети, если в сеть упрётся раньше.
|
|||
|
|
|||
|
При использовании кодов коррекции ошибок (EC):
|
|||
|
- Задержка чтения в 1 поток (T1Q1): 1.5 RTT + 1 чтение.
|
|||
|
- Запись+fsync в 1 поток:
|
|||
|
- С мгновенным сбросом: 3.5 RTT + 1 чтение + 2 записи.
|
|||
|
- С отложенным ("ленивым") сбросом: 5.5 RTT + 1 чтение + 2 записи + 2 fsync.
|
|||
|
- Под 0.5 на самом деле подразумевается (k-1)/k, где k - число дисков данных,
|
|||
|
что означает, что дополнительное обращение по сети не нужно, когда операция
|
|||
|
чтения обслуживается локально.
|
|||
|
- Параллельное чтение: сумма IOPS всех дисков либо производительность сети, если в сеть упрётся раньше.
|
|||
|
- Параллельная запись: сумма IOPS всех дисков / общее число дисков данных и чётности / WA либо производительность сети, если в сеть упрётся раньше.
|
|||
|
Примечание: IOPS дисков в данном случае надо брать в смешанном режиме чтения/записи в пропорции, аналогичной формулам выше.
|
|||
|
|
|||
|
WA (мультипликатор записи) для 4 КБ блоков в Vitastor обычно составляет 3-5:
|
|||
|
1. Запись метаданных в журнал
|
|||
|
2. Запись блока данных в журнал
|
|||
|
3. Запись метаданных в БД
|
|||
|
4. Ещё одна запись метаданных в журнал при использовании EC
|
|||
|
5. Запись блока данных на диск данных
|
|||
|
|
|||
|
Если вы найдёте SSD, хорошо работающий с 512-байтными блоками данных (Optane?),
|
|||
|
то 1, 3 и 4 можно снизить до 512 байт (1/8 от размера данных) и получить WA всего 2.375.
|
|||
|
|
|||
|
Кроме того, WA снижается при использовании отложенного/ленивого сброса при параллельной
|
|||
|
нагрузке, т.к. блоки журнала записываются на диск только когда они заполняются или явным
|
|||
|
образом запрашивается fsync.
|