RE: Copy data to DSA area
| От | Ideriha, Takeshi | 
|---|---|
| Тема | RE: Copy data to DSA area | 
| Дата | |
| Msg-id | 4E72940DA2BF16479384A86D54D0988A7DB7C199@G01JPEXMBKW04 обсуждение исходный текст | 
| Ответ на | RE: Copy data to DSA area ("Ideriha, Takeshi" <ideriha.takeshi@jp.fujitsu.com>) | 
| Ответы | Re: Copy data to DSA area | 
| Список | pgsql-hackers | 
>From: Ideriha, Takeshi [mailto:ideriha.takeshi@jp.fujitsu.com] >Sent: Friday, April 26, 2019 11:50 PM >To: 'Kyotaro HORIGUCHI' <horiguchi.kyotaro@lab.ntt.co.jp>; >thomas.munro@enterprisedb.com; robertmhaas@gmail.com >Cc: pgsql-hackers@postgresql.org >Subject: RE: Copy data to DSA area > >Hi, I've updated Thomas's quick PoC. Hi. I've rebased the patch to fit the core code rather than extension. Regarding shared memory context (ShmContext), I added three APIs: - CreatePermShmContext create "permanent" context located in shared memory - CreateTempShmContext Create "temporary" context located in local memory, Which has buffer to keep track of possible memory leak objects - ChangeToPermShmContext Change allocated objects parent to permanent context When you allocate something, add an object in the Temp ShmContext, and re-parent it to Perm ShmContext after it becomes not leaked. Current method of keeping track of objects and freeing them at rollback works well for the case where delete both the parent object and child object, which is pointed by parent. This is because no dangling pointer remains after rollback. If child object is freed but parent object was already allocated in the permeant context, this object has a dangling pointer. But if an object is pointed by already permanent object, this means that just allocated object won't be leaked. So in such cases we could skip temporary allocation and allocate it directory to permanent context. At rollback case, we could just leave it in the shared memory and could make upper layer function handle its "ghost" object in a good way. I cannot see the solution around here clearly. Do you have any thoughts? MemoryContextMethods are not fully supported but some methods like stats() might be needed. Current test case is very simple and same as previous one but implemented as isolation test. It checks if interger can be set in shared memory and get it by another process. Actually, current test case doesn't cover all possible case so more cases should be added. I'll add this coming CF. P.S Thomas, thank you for taking some time at PGCon to discuss this item and shared catalog cache. It was very helpful. I'm going to submit email about shared catcache soon. Regards, Takeshi Ideriha
Вложения
В списке pgsql-hackers по дате отправления: