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

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

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

9 ответов

7 просмотров

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, то можно содрать оттуда)).

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

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

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
Помогите, пожалуйста, делаю программу для для подсчёта корней квадратного уравнения, знаю, что есть куча недочётов, недоработок, но основная проблема в том, что почему-то при ...
NYC
13
#include <stdio.h> int main(void) { int n; scanf("%d", &n); int digits1[n] = {0}; int digits2[n] = {0}; я не могу таким образом заранее массив нулями заполнить?
Linus
12
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
читать файл максимально быстро? странный вопрос))
zamtmn
53
я про форму записи. смысл указывать что 8 байтный регистр 8 байт?
Aiwan \ (•◡•) / _bot
10
Вроде бы вопрос уже заезжанный, но тем не менее У меня есть функция menu() которая выводит набор возможных действий, а затем спрашивает у пользователя что он хотел бы сделать....
David Golovatin
3
а как бы вылезти из ИО, что то типа IO -> Ether или в какую сторону смотреть ? что то туплю
Fedor
14
Карта сайта