Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 27 Nov 2010 21:21:51 +0200
From:      Kostik Belousov <kostikbel@gmail.com>
To:        "Carlos A. M. dos Santos" <unixmania@gmail.com>
Cc:        FreeBSD-Hackers <freebsd-hackers@freebsd.org>, Dimitry Andric <dim@freebsd.org>, d@delphij.net
Subject:   Re: Is it possible to have file removed upon process exit?
Message-ID:  <20101127192151.GL2392@deviant.kiev.zoral.com.ua>
In-Reply-To: <AANLkTikH_uD1-yUe6KTufBvs9zRdQ%2BiMVQWcavBYRXU9@mail.gmail.com>
References:  <4CEEC3BD.3080204@delphij.net> <4CF13D7A.4060904@FreeBSD.org> <AANLkTikH_uD1-yUe6KTufBvs9zRdQ%2BiMVQWcavBYRXU9@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help

--4xm7XMBDuRVjShWb
Content-Type: text/plain; charset=koi8-r
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

On Sat, Nov 27, 2010 at 05:07:15PM -0200, Carlos A. M. dos Santos wrote:
> On Sat, Nov 27, 2010 at 3:18 PM, Dimitry Andric <dim@freebsd.org> wrote:
> > On 2010-11-25 21:14, Xin LI wrote:
> >>
> >> For certain applications it is sometimes desirable to (e.g. for unix
> >> domain sockets) have file removed when the process quit, regardless
> >> whether the process is quit cleanly. =9AIs there a clean way to do thi=
s?
> >
> > Maybe your process could be the child of a parent which cleans up
> > afterwards? =9A(This is an analogy from real life. ;)
>=20
> #include <stdio.h>
> #include <stdlib.h>
> #include <unistd.h>
> #include <sys/types.h>
> #include <sys/wait.h>
>=20
> static char filename[] =3D "/tmp/tmpfXXXXXX";
> static int fd =3D 0;
>=20
> int main(void) {
> 	if ((fd =3D mkstemp(filename)) >=3D 0) {
> 		pid_t pid;
> 		if ((pid =3D fork()) > 0) {
> 			/* parent */
> 			wait(NULL);
> 			printf("unlinking '%s'\n", filename);
> 			unlink(filename);
> 			return EXIT_SUCCESS;
> 		} else {
> 			/* child */
> 			printf("file name is '%s'\n", filename);
> 			sleep(10);
> 			abort();
> 		}
> 	}
> 	return EXIT_FAILURE;
> }
This approach has usual problems of making a mess if the program
want to fork() for other reasons, since the child should continue
to execute a logic in your case, but cannot wait for already forked
processes.

Usual advice is to have child monitoring the liveness of the parent.
You can either create a pipe before fork and read(2) from it in child,
never writing from parent. read(2) will return when parent exits.
Or, periodically compare getppid() with 1 in child, and do the cleanup
when equal.

Usually, it is too much hassle to do any of the tricks, normal
system cleanup of /tmp on reboot is good enough.

--4xm7XMBDuRVjShWb
Content-Type: application/pgp-signature
Content-Disposition: inline

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.11 (FreeBSD)

iEYEARECAAYFAkzxWk8ACgkQC3+MBN1Mb4hFRACg24LrAWKaYm+Zln4xRowBI4ey
1sgAoNUUGfzBVfoWHJHLQUxiGv+0sU6M
=5nIm
-----END PGP SIGNATURE-----

--4xm7XMBDuRVjShWb--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20101127192151.GL2392>