Текущий архив: 2004.09.26;
Скачать: CL | DM;
ВнизQuery сжирает всю память Найти похожие ветки
← →
Desperado © (2004-08-29 11:14) [0]есть IBQuery с запросом select * from table;
table состоит из ID integer
NAME1 varchar(4096)
NAME2 varchar(2048)
в ней 10 записей.
После открытия Query Диспетчер задачь регистрирует выделение общей памяти объемом 6 метров. После закрытия Query - эти 6 метров освобождаются. В "процессах" процесс с Query сжирает всего несколько килобайт. Может ли Query сжирать столько памяти, и как этого избежать? В программе используется с десяток таких запросов, поэтому каждому п 6 метров- просто неприемлимо.
Конфигурация:
Delphi 5, SP1, SP2, IBX5.04
TIBQuery
← →
DiamondShark © (2004-08-29 11:27) [1]Открыть десять квери и посмотреть результат.
Казалось бы, что может быть проще?
← →
Desperado © (2004-08-29 11:37) [2]>Открыть десять квери и посмотреть результат.
>Казалось бы, что может быть проще?
Если бы все было так просто, я бы не спрашивал.
Как думаешь? как я заметил ошибку? Когда открыл десяток этих квери,да еще несколько раз в разных потоках, вот у меня и вылезло
Out of memory.
Вопрос был в том, нормально ли то, что квери жрет так много и как можно этого избежать.
← →
Desdechado © (2004-08-30 14:09) [3]квери при открытии вычитывает данные, информацию о транзакции, создает буфер регистрации изменении в данных
это может много места требовать, но не в 100 раз больше простых (4кб+2кб)*10записей
ищи, что еще делаешь
← →
Rule © (2004-08-30 14:31) [4]Не может он стого жрать это точно, смотри что там у тебя ещё
← →
s999 (2004-08-30 14:56) [5]
> Вопрос был в том, нормально ли то, что квери жрет так много
> и как можно этого избежать
А чего гадать то? Алгоритм выделения памяти в IBX вполне прозрачен:
DataSet при открытии рапределяет RecordSize*BufferChunks байт
Далее, допустим BufferChunks = 100. C сервера фетчится 101-я запись. Датасет распределяет (RecordSize*BufferChunks)*2 байт Делает он это через Realloc, поэтому, фактически, получается новое выделение с копированием предыдущего.
И так далее, то есть *3, *4, *5 ...
Засада еще здесь в том, что IBX-у нужна непрерывная память, поэтому "Out of memory" может случится раньше, чем реально память закончится.
Общепризнано, что используемая модель работы с памятью в IBX неудачна. В FibPlus вроде это уже переработано, да и Джеф (один из авторов IBX) неоднократно говорил, что собирается это сделать.
Но твоя проблема, скорее всего, из-за того, что сильно "запузырил" BufferChunks. Вот и получается, что записей всего 10, а памяти распределяется под 100000(или что там у тебя).
Страницы: 1 вся ветка
Текущий архив: 2004.09.26;
Скачать: CL | DM;
Память: 0.46 MB
Время: 0.034 c