in reply to Temporary files and cleaning up after an interruption
I was thinking of typical solutions for this problem:
You could spawn a child that deamonizes itself (so signals to the parent don't get sent to the child), ignores all the signals it can (so no need for signal handlers and the problems they cause in Perl), and then waits for the parent to exit.
Ah, but how does a child wait for a parent to exit? Well, just have the parent flock() the temporary file before creating the child and pass a handle for the temporary file to the child and the child can block on flock() waiting for the parent to close the file. If the parent dies suddenly, the operating system will still close the file, which releases the lock and causes the child to wake up and delete the file.
To prevent a race condition, I'd have the parent not even try to delete the file (otherwise a new invocation of the script might pick the same file name while a previous child is just getting around to deleting what it considers to be an old file). So in your case (of renaming the file), the parent should just create an extra link (though this makes the script less portable).
If you have trouble coding this, then let me/us know.
- tye (but my friends call me "Tye")
|
---|
Replies are listed 'Best First'. | |
---|---|
Re: Temporary files and cleaning up after an interruption
by Dominus (Parson) on Jan 05, 2001 at 08:38 UTC | |
by Dominus (Parson) on Jan 05, 2001 at 08:45 UTC | |
by tye (Sage) on Jan 05, 2001 at 10:23 UTC |