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

Можно как то обмануть планировщик запроса, чтоб симулировать ситуацию когда

нагрузка больше чем на тестовом стенде?

9 ответов

21 просмотр

pg-шный планировщик ничего не знает про нагрузку (афаик)... т.е. при прочих равных, при большой нагрузке и при малой выберет один и тот же план. а, ну единственное, под нагрузкой у вас visibility maps могут оказаться не обновлены, и вы вместо index-only scan получите index scan. Ну выключите автовакуум временно для эмуляции :)

Aleksandr-Danilov 🇺🇦 Автор вопроса
Ilya Portnov
pg-шный планировщик ничего не знает про нагрузку (...

я про такие вещи как например не 100к записей, а пару миллионов, и т.д.

Aleksandr Danilov 🇺🇦
я про такие вещи как например не 100к записей, а п...

а, статистику типа фейковую подсунуть? это да, было бы интересно...

Ilya Portnov
а, статистику типа фейковую подсунуть? это да, был...

а если пересчитать с низким defaul_statistics_target, мб она менее точной станет?)

Какой-то Хмырь
а если пересчитать с низким defaul_statistics_targ...

ну менее точной, но в количестве строк на два порядка не ошибётся.

Ilya Portnov
ну менее точной, но в количестве строк на два поря...

ну уехавшая стата и нагрузка-таки разные вещи. можно попробовать стейдж при типовой нагрузке придушить по процам и памяти. хз, правда, что это покажет)

А что Вам мешает (под superuser), если это всё равно тестовый сервер: UPDATE pg_class SET relpages = 200, reltuples = 232132 WHERE relname = 'a table name'; ну и так далее (есть и штатное средство для одной статистики — см. n_distinct в https://www.postgresql.org/docs/current/sql-altertable.html )? Базу поcле таких экспериментов лучше сжечь перезалить, на всякий случай. ;)

Aleksandr-Danilov 🇺🇦 Автор вопроса

что делают эти параметры?

Aleksandr Danilov 🇺🇦
что делают эти параметры?

См. https://www.postgresql.org/docs/current/using-explain.html Ну и там ещё описаны статистики, являющиеся фундаментом планирования — всё это можно поменять таким способом, насколько я помню (но вот писать MCV и гистограммы вручную — это морока, конечно... с другой стороны, их можно откуда-то содрать (если есть, откуда... например, если тест — это в 1000 раз уменьшенный (каким-то образом) production, то можно содрать оттуда)).

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта