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

Добрый день! Подскажите, плз, можно ли как-то регулировать интенсивность выполнения

мутаций? Сейчас, при запуске одной умеренно тяжелой мутации, КХ, на сколько я понимаю, делает ее параллельно для нескольких партов, нагрузка на сервер сильно возрастает, и обычным запросам не хватает памяти, да и сами мутации изредка тоже фейлятся с нехваткой памяти.

12 ответов

12 просмотров

background_schedule_pool_size уменьшите в /etc/clickhouse-server/users.d/background_scheduled_pool_size.xml <yandex> <profiles> <default> <background_schedule_pool_size>2</background_schedule_pool_size> <background_pool_size>2</background_pool_size> </default> </profiles> </yandex> вообще как бы merge и мутации никакой особой памяти не занимают (ну буфера на чтение и распаковку где то мегабайт на 1 колонку и зависит от формата part) они диск жрут потребуется сервер рестартануть

сколько памяти и CPU ядер на сервере?

Ilia-Ablamonov Автор вопроса
Ilia-Ablamonov Автор вопроса
Slach [altinity]
background_schedule_pool_size уменьшите в /etc/cli...

в system.mutations.latest_fail_reason в процессе видел ошибки вида "не могу выделить 1-10гб"

Ilia Ablamonov
128гб, 48 логических ядра

тогда у вас проблема не в мутациях памяти для них навалом смотрите сколько памяти жралось в system.query_log по времени ошибок из latest_fail_time

Ilia Ablamonov
128гб, 48 логических ядра

смотрите по времени в system.metric_log CurrentMetric_* поля которые с памятью связаны также

Ilia Ablamonov
в system.mutations.latest_fail_reason в процессе в...

в мутациях нельзя использовать select, используйте словари

Ilia-Ablamonov Автор вопроса
Denny [Altinity]
в мутациях нельзя использовать select, используйте...

Не используем: заранее селектим 10к значений, а в мутации перечисляем их в where in [].

Ilia Ablamonov
Не используем: заранее селектим 10к значений, а в ...

это вам апгрейдится надо, это починено. НО, в любом случае будет проблема, вы же запускаете не одну мутацию, а сразу пачку и в каждой по 10к? ОНи объединяются в одну. Используйте engine=Join и в мутации joinGet (я использую mergtree таблицы, туда записываю id-шники, даже миллион, сверху словарь, и потом одной мутацией where dictGet)

Ilia-Ablamonov Автор вопроса
Ilia Ablamonov
Запускаем по одной, нам много не надо

запускаем это хорошо. А конца ждете?

Denny [Altinity]
это вам апгрейдится надо, это починено. НО, в люб...

"Используйте engine=Join и в мутации joinGet (я использую mergtree таблицы, туда записываю id-шники, даже миллион, сверху словарь, и потом одной мутацией where dictGet)" Попробовал, опять ошибка: Exception: Illegal type Nullable(Bool) of second argument of function dictGet, expected a const string or const tuple of const strings. В целевой таблице что ли дело. 🤔

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
А чем вам питонисты не угодили?😂
.
79
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
Какое виндузовое сообщение приходит TTabSheet, что риэлайняться контролы на нем, даже у которых парент другой? Ситуация: открываю форму - кнопок нет, перелистываю на другой т...
Катерина Свиридова
7
Карта сайта