ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] IPC и сборка мусора
@ 2003-09-07 10:31 Denis Ovsienko
  2003-09-07 13:19 ` Dmitry V. Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Denis Ovsienko @ 2003-09-07 10:31 UTC (permalink / raw)
  To: devel


Целью данного письма является показать, что можно программировать IPC так,
чтобы не оставлять мусор, причём это не особенности замшелых ядер,
описанные в устаревших книжках. Вот текст программы:
#include <string.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>

#define SIZE 1024

int main (int argc, char * argv[])
{
        key_t key = ftok (argv[0], 1);
        int shmid = shmget (key, SIZE, IPC_CREAT | 0600);
        void * memory = NULL;
        if (shmid == -1) return 1;
        memory = shmat (shmid, NULL, 0);
        if (argc >= 2 && !strcmp (argv[1], "rm")) shmctl (shmid, IPC_RMID,
NULL);
        return 0;
}

Вот 3 последовательных запуска. Прошу обратить внимание на уже
существующий до запуска сегмент: nattch=2, status=dest. После двух shmdt()
либо после простого завершения 2-х подсоединённых процессов сегмент будет
удалён. Но вернёмся к тесту:

[pilot@m46 devel]$ ipcs

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 27131910   pilot     777        393216     2          dest

------ Semaphore Arrays --------
key        semid      owner      perms      nsems

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages

[pilot@m46 devel]$ ./IPCtest rm
[pilot@m46 devel]$ ipcs

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 27131910   pilot     777        393216     2          dest

------ Semaphore Arrays --------
key        semid      owner      perms      nsems

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages

[pilot@m46 devel]$ ./IPCtest
[pilot@m46 devel]$ ipcs

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x0102be47 53968897   pilot     600        1024       0
0x00000000 27131910   pilot     777        393216     2          dest

------ Semaphore Arrays --------
key        semid      owner      perms      nsems

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages

[pilot@m46 devel]$ ./IPCtest rm
[pilot@m46 devel]$ ipcs

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 27131910   pilot     777        393216     2          dest

------ Semaphore Arrays --------
key        semid      owner      perms      nsems

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages

[pilot@m46 devel]$ uname -a
Linux m46.pilot 2.4.20-alt5-pim #1 Tue Apr 22 22:09:54 EEST 2003 i686
unknown unknown GNU/Linux

Вот и всё, и не нужно говорить, что это не работает. Точно такое же
поведение можно ожидать и на других POSIX-системах. ALTLinux Master
2.2, ядро 2.4.20-alt5-up с включенным IGMP+PIM.

--
    DO4-UANIC


^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [devel] IPC и сборка мусора
  2003-09-07 10:31 [devel] IPC и сборка мусора Denis Ovsienko
@ 2003-09-07 13:19 ` Dmitry V. Levin
  2003-09-07 15:01   ` Denis Ovsienko
  0 siblings, 1 reply; 6+ messages in thread
From: Dmitry V. Levin @ 2003-09-07 13:19 UTC (permalink / raw)
  To: ALT Devel discussion list

[-- Attachment #1: Type: text/plain, Size: 1040 bytes --]

On Sun, Sep 07, 2003 at 01:31:35PM +0300, Denis Ovsienko wrote:
[...]
> Вот и всё, и не нужно говорить, что это не работает. Точно такое же

Это не работает.  Точнее говоря, приведённый тест не имеет никакого
отношения к обсуждаемой задаче.

Цитирую susv3/functions/semctl.html:
IPC_RMID
Remove the semaphore identifier specified by semid from the system and
destroy the set of semaphores and semid_ds data structure associated with
it.

Цитирую susv3/functions/shmctl.html:
IPC_RMID
Remove the shared memory identifier specified by shmid from the system and
destroy the shared memory segment and shmid_ds data structure associated
with it.

Цитирую susv3/functions/msgctl.html:
IPC_RMID
Remove the message queue identifier specified by msqid from the system and
destroy the message queue and msqid_ds data structure associated with it.

Короче говоря, IPC_RMID сразу уничтожает ресурс.  Ни о какой уборке мусора
не может быть и речи.  Все остальные процессы, обращающиеся к этому
ресурсу, получают (в лучшем случае) ошибку EIDRM.


--
ldv

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [devel] IPC и сборка мусора
  2003-09-07 13:19 ` Dmitry V. Levin
@ 2003-09-07 15:01   ` Denis Ovsienko
  2003-09-07 15:26     ` Dmitry V. Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Denis Ovsienko @ 2003-09-07 15:01 UTC (permalink / raw)
  To: ALT Devel discussion list


> Это не работает.  Точнее говоря, приведённый тест не имеет никакого
> отношения к обсуждаемой задаче.
Работает. Имеет. Либо задача решается не теми средствами.

> Короче говоря, IPC_RMID сразу уничтожает ресурс.  Ни о какой уборке мусора
> не может быть и речи.  Все остальные процессы, обращающиеся к этому
> ресурсу, получают (в лучшем случае) ошибку EIDRM.
Это не так, и даже из лога сессии это видно. Установка флага SHM_DEST не
мешает другим процессам вызывать shmat(), я это проверял практически. И не
уничтожает ресурс, пока счётчик присоединённых процессов больше нуля.

--
    DO4-UANIC


^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [devel] IPC и сборка мусора
  2003-09-07 15:01   ` Denis Ovsienko
@ 2003-09-07 15:26     ` Dmitry V. Levin
  2003-09-08  9:35       ` Denis Ovsienko
  0 siblings, 1 reply; 6+ messages in thread
From: Dmitry V. Levin @ 2003-09-07 15:26 UTC (permalink / raw)
  To: ALT Devel discussion list


[-- Attachment #1.1: Type: text/plain, Size: 1747 bytes --]

On Sun, Sep 07, 2003 at 06:01:36PM +0300, Denis Ovsienko wrote:
> > Это не работает.  Точнее говоря, приведённый тест не имеет никакого
> > отношения к обсуждаемой задаче.
> Работает. Имеет. Либо задача решается не теми средствами.

На самом деле задача формулируется так:
гарантировать освобождение ресурсов по окончании сборки.
Другими словами, на клиента рассчитывать нельзя.

> > Короче говоря, IPC_RMID сразу уничтожает ресурс.  Ни о какой уборке мусора
> > не может быть и речи.  Все остальные процессы, обращающиеся к этому
> > ресурсу, получают (в лучшем случае) ошибку EIDRM.
> Это не так, и даже из лога сессии это видно. Установка флага SHM_DEST не
> мешает другим процессам вызывать shmat(), я это проверял практически. И не
> уничтожает ресурс, пока счётчик присоединённых процессов больше нуля.

Как всегда, истина где-то посередине.
То, что работает с shm, не работает с sem и msg.

Вот пример того, что происходит с очередями:

[user@localhost user]$ ipcs -q

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages    

[user@localhost user]$ ./msgtest &
[1] 32040
[user@localhost user]$ ./msgtest &
[2] 32041
[user@localhost user]$ ipcs -q

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages    
0x01070367 3866624    user       600        0            0           

[user@localhost user]$ ./msgtest rm
[user@localhost user]$ ./msgtest: msgsnd: Invalid argument
[2]+  Exit 1                  ./msgtest
./msgtest: msgsnd: Invalid argument
[1]-  Exit 1                  ./msgtest
ipcs -q

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages    

P.S. fakeroot использует только sem и msg.


-- 
ldv

[-- Attachment #1.2: msgtest.c --]
[-- Type: text/plain, Size: 741 bytes --]

#include <errno.h>
#include <error.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/msg.h>

#define SIZE 1024

struct msgbuf
{
	long    mtype;
	char    mtext[SIZE];
};

int
main (int argc, const char *argv[])
{
	key_t   key = ftok (argv[0], 1);
	int     msqid = msgget (key, IPC_CREAT | 0600);

	if (msqid == -1)
		error (1, errno, "msgget");

	if (argc >= 2 && !strcmp (argv[1], "rm"))
	{
		if (msgctl (msqid, IPC_RMID, 0) == -1)
			error (1, errno, "msgctl");
		return 0;
	}

	for (;;)
	{
		struct msgbuf msg;

		sleep (1);
		msg.mtype = 1;
		if (msgsnd (msqid, &msg, SIZE, 0) == -1)
			error (1, errno, "msgsnd");
		if (msgrcv (msqid, &msg, SIZE, 1, 0) == -1)
			error (1, errno, "msgrcv");
	}
	return 0;
}

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [devel] IPC и сборка мусора
  2003-09-07 15:26     ` Dmitry V. Levin
@ 2003-09-08  9:35       ` Denis Ovsienko
  2003-09-08 10:17         ` Dmitry V. Levin
  0 siblings, 1 reply; 6+ messages in thread
From: Denis Ovsienko @ 2003-09-08  9:35 UTC (permalink / raw)
  To: ALT Devel discussion list


> На самом деле задача формулируется так:
> гарантировать освобождение ресурсов по окончании сборки.
> Другими словами, на клиента рассчитывать нельзя.
Ясно.

> Как всегда, истина где-то посередине.
Пожалуй, действительно.

> То, что работает с shm, не работает с sem и msg.
>
> Вот пример того, что происходит с очередями:
[...]
> P.S. fakeroot использует только sem и msg.
А fifo-файлами здесь обойтись нельзя? Проще будет чистить.

--
    DO4-UANIC


^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [devel] IPC и сборка мусора
  2003-09-08  9:35       ` Denis Ovsienko
@ 2003-09-08 10:17         ` Dmitry V. Levin
  0 siblings, 0 replies; 6+ messages in thread
From: Dmitry V. Levin @ 2003-09-08 10:17 UTC (permalink / raw)
  To: ALT Devel discussion list

[-- Attachment #1: Type: text/plain, Size: 736 bytes --]

On Mon, Sep 08, 2003 at 12:35:10PM +0300, Denis Ovsienko wrote:
> > На самом деле задача формулируется так:
> > гарантировать освобождение ресурсов по окончании сборки.
> > Другими словами, на клиента рассчитывать нельзя.
> Ясно.
> 
> > Как всегда, истина где-то посередине.
> Пожалуй, действительно.
> 
> > То, что работает с shm, не работает с sem и msg.
> >
> > Вот пример того, что происходит с очередями:
> [...]
> > P.S. fakeroot использует только sem и msg.
> А fifo-файлами здесь обойтись нельзя? Проще будет чистить.

Насколько я понимаю, fakeroot'у нельзя использовать файловые дескрипторы.
Видимо, авторы считают, что приложение может легко и не задумываясь эти
дескрипторы закрыть.  Думаю, что они (авторы) правы.


-- 
ldv

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2003-09-08 10:17 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-09-07 10:31 [devel] IPC и сборка мусора Denis Ovsienko
2003-09-07 13:19 ` Dmitry V. Levin
2003-09-07 15:01   ` Denis Ovsienko
2003-09-07 15:26     ` Dmitry V. Levin
2003-09-08  9:35       ` Denis Ovsienko
2003-09-08 10:17         ` Dmitry V. Levin

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git