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

Привет. Очень мне нравится Clickhouse, но от его более широкого использования

останавливает низкое кол-во запросов в секунду. Может есть какие-то способы увеличить rps для простых запросов вроде SELECT col1,col2,col3 FROM table WHERE id=123456 ?

6 ответов

26 просмотров

кликхаус не для точечных запросов в принципе

https://altinity.com/blog/clickhouse-in-the-storm-part-2 Но строго говоря ТОЛЬКО для таких запросов кх не подходит

у таблицы ORDER BY id ? у тебя тут проблема в том что не работает partition prunning и получается full scan по primary key и для каждого парта приходится делать o(log n) поиск с точностью до гранулы где твой id лежит потом читать гранулу... чем больше партов, тем медленнее потому что получается P * o (log n(p)) и я не уверен. но оно не в паралели ищет (хотя наверное могло бы?)

то есть при самых идеальных условиях читаться будет с диска минимум один сжатый блок записей (65535 строк) если не ошибаюсь... и потом фильтроваться...

не знаю ваших бюджетов, но если это прям критично, думаю, можно попробовать закупиться оперативкой и выгрузить данные в memory table ) https://clickhouse.com/docs/en/engines/table-engines/special/memory/ "Normally, using this table engine is not justified. However, it can be used for tests, and for tasks where maximum speed is required on a relatively small number of rows (up to approximately 100,000,000)."

ivan
не знаю ваших бюджетов, но если это прям критично,...

возможно словарь побыстрее, там в хэш таблице хранится. А в Memory engine ключ не задаётся, подразумевается что фулскан будет всегда

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта