184 похожих чатов

Добрый день. Есть кластер КХ на железках с локальными nvme

ssd 800k iops на чтение и 300k iops на запись, линейная скорость 4.5Гбайт/с и 2Гбайт/с соответственно. тестировали через fio и dd. 4 nvme собраны в mdadm raid10 и на массиве линейная скорость чтения х4, записи х2. аналогичные скорости показывает и наш прикладкой софт генерирующий файлики.
Но, при заливке файлика из ~0.7 млрд строк через clickhouse-client в ReplacingMergeTree видим скорость на уровне 2.68 million rows/s., 48.18 MB/s. Тесты с изменением типа таблиц (Log, MergeTree), с копированием через insert показывают аналогичную скорость. на системе в этот момент латентность дискового ввода-вывода на уровне 40мкс, iowait близок к нулю, clickhouse-server нагружает одно ядро на 0.9, ещё 12 ядер загружены другими процессами, оставшиеся ядра (44 штуки) простаивают (в сервере 2 сокета с камнями по 14 физических ядер).
для теста из raid10 выдернули одну nvme, поставили ext4 (rw,noatime,nodiratime,data=ordered)
и эксперименты проводим на ней.
версия кх - 19.13.5.44, но вроде быв более свежих никаких серьёзных правок по производительности не было.

подскажите в чем может быть дело и куда смотреть?

4 ответов

12 просмотров

структура таблицы какая и какая длина primary key? в каком формате вставляете?

Загрузка одного ядра намекает на то что INSERT однопоточный, попробуйте вставлять в 2-10 потоков мы в 6 потоков вставляем в 1 сервер 200М метрик в минуту

А ваш прикладной софт точно может с такой скоростью данные поставлять? Возьмите файлик положите на сервер и скормите клиенту кликхауза, потом тоже самое в паралель в 16 потоков.

да вам наверное надо 40-60 потоков. И возьмите кх из pre-stable 20.... там парсинг файла многопоточный.

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
70
Здравствуйте. Задача состоит в том, чтобы сделать real-time чат в мобильном приложении. После передачи сообщения пользователем через веб-сокеты, для основного и долговременног...
🐾
5
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
падает джоба хотя уже была собрана на соседнем namespace, куда капать? │ │ Copying blob sha256:2fa066caddb8f09a71082b03aa43046f79346a01d9c89e06a1f508bb1207dba5 427 │ │ Copyin...
Andrei St
2
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Люди добрые, помогите с идеями, потому что свои закончились. У клиента падает софтина в момент инициализации модуля OtlEventMonitor на RegisterWindowMessage('Gp/OtlTaskEvents/...
Михаил Усков
7
Тут просто дело в том, что я не могу сейчас дать такие подробности из за того что рассчитать это всё нереально. Этого проекта который я хочу сделать ещё даже не существует) И ...
🐾
8
> Примечательно, что новый владелец удаляет из GitHub любые жалобы, указывающие на подозрительную активность или смену владельца, и, видимо, рассчитывает на то, что пользовате...
Alex Sherbakov
2
Карта сайта