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

А вот work_mem выделяется в момент запроса, и по окончании

запроса освобождается?
Я к тому, что если есть сессия, которая под какой-то запрос выделила 10Mb work_mem, запрос отработал, потом сессия висит в idle — эти 10mb будут всё ещё числиться за этой сессией?

4 ответов

7 просмотров

> а вот work_mem выделяется в момент запроса Да не work_mem выделяется, это просто "мягкое" ограничение на выделение локальной памяти одним узлом плана. ;) Так что эта память выделяется по мере надобности, а освобождается в т.ч. и в процессе выполнения запроса (но не всегда, да) . > и по окончании запроса освобождается? Да, должна (не считая всяких там WITH HOLD cursors и т.п. — но тут можно считать и так, что запрос ещё не отработал). > эти 10mb будут всё ещё числиться за этой сессией? Кем будут числиться? ;) Возврат памяти в OS — это инициатива [какой-то] libc, и это уж совсем другая история...

Ilya-Portnov Автор вопроса
Yaroslav Schekin
> а вот work_mem выделяется в момент запроса Да н...

» Да не work_mem выделяется Ну понятно, я имел ввиду — память в рамках work_mem * количество узлов » Кем будут числиться? ;) Ну например когда эти 10MB понадобятся соседней сессии — она сможет их использовать? Все эти приколы про то что не понятно как считать занятую память понятны. Но как не считай, если постгрес падает по OOM это значит что память кончилась :) значит кто-то её выделил...

У Postgres ведь какой-то свой аллокатор завязаный на MemoryContexts

Sergey Gr
У Postgres ведь какой-то свой аллокатор завязаный ...

Да. Как раз поэтому явным освобождением памяти большая часть кода не заморачивается вообще — контексты решают. Явное освобождением (или переносом выделения в контекст большей вложенности) разработчики PostgreSQL обычно занимаются только тогда, когда на практике выясняется, что какая-то обработка как-то слишком много памяти выделяет и долго не возвращает (при каких-то условиях).

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
Как попросить stack install делать executable без .exe на винде?
Danila Danko
9
Карта сайта