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

Подскажите, если запросу требуется для выполнения 150мб work_mem, а в

настройках выставлено 100мб. Временный файл будет 50 или 150 мегабайт ?

9 ответов

5 просмотров
Wadik-Wadkovich Автор вопроса

Ни кто не может подсказать как правильно ?

Wadik Wadkovich
Ни кто не может подсказать как правильно ?

Это сложный вопрос, врать не хочется. Если я правильно помню, то многие коллекции умеют "продолжаться" на диске, когда достигнут лимит по памяти, т.е. "чаще 50"

мне кажется 150. Оно на этапе планирования если подумает, что в workmem не уместится то другой план создаст, где временная таблица используется

Mike Wazowski
мне кажется 150. Оно на этапе планирования если по...

Я тоже хотел так написать. Это правда, но на этапе планирования объёмы известны только очень приблизительно. Превышение лимита всегда может случиться уже во время выполнения

alex che
Я тоже хотел так написать. Это правда, но на этапе...

ну так work_mem это и не гарантия ж, просто пожелание :)

alex che
Я тоже хотел так написать. Это правда, но на этапе...

С точки зрения здравого смысла, такой подход малоэффективный. Ну типо превысил я на 1 мб ограничение, его и вытеснил на диск, смысл перекачивать все нужные данные на диск "рядом", если их все равно нужно считать в память

Виктор Ткаченко
С точки зрения здравого смысла, такой подход малоэ...

1. Ну а что делать, если в ограничение work_mem хочется уложиться, а угадывать заранее мы не умеем? 2. Я предположил, что то, что уже в памяти не будет сбрасываться на диск, а коллекция будет работать в режиме половина-здесь-половина-там

Зависит от того, как используется память данным узлом плана, насколько я помню. К примеру, tuplestores (используемые в Materialize и CTE) сбрасывают всё целиком (т.е. в этом случае было бы ближе к 150 MB). > А на то, что у меня temp_fail меньше чем work_mem повлияло что - то другое Формат (и размер) tuples в памяти и на диске не один и тот же.

alex che
1. Ну а что делать, если в ограничение work_mem хо...

Мне кажется тут человек в принципе не с того конца заходит. Postgres не говорит что именно он будет держать в work mem. И пытаться понять сколько нужно дискового пространства на один запрос, это неблагодарное занятие. Правильный ответ: это пытаться управлять объемом workmem на уровне сессии (если запрос сильно отличается от остальных по ресурсам).

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

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

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
А что ты вообще делаешь ?
Yesgoter
13
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
18
что это и почему оно? executor.start_polling(bot, skip_updates=True, on_startup=on_startup, File "/usr/local/lib/python3.10/dist-packages/aiogram/utils/executor.py", line 4...
𐌍𐌄 ᕓ𐌄𐌓𐌌Ꝋ𐌓𐌄
2
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
Подскажите, почему в правом коде с1 дополняется до 8байт, а не до 4?
Sergey
9
Карта сайта