go ahead... be a heretic | |
PerlMonks |
Re^2: Will these functions for use with Storable properly lock my file?by nysus (Parson) |
on Aug 04, 2021 at 01:43 UTC ( [id://11135600]=note: print w/replies, xml ) | Need Help?? |
_retrieve() leaks the bareword file handle LOCK, the lock file is kept locked until some other code explicitly closes that handle. _store() closes a bareword file handle never opened there. Yes, I realize this is a litle precarious. It relies on my code always calling _retrieve() followed by _store(() at some point. It also counts on the lock getting removed when the process. Wasn't sure how else I could get around this. If you have two instances running in parallel, and one chooses to write (calling _store()) without prior read, while the other chooses to read (calling _retrieve()), the writer will simply damage the data on disk while the reader assumes to be safe because it holds a lock. The writer doesn't even get an error, because close lacks error checks. Instant loss of data. (And trust me in that regard, Murphy will make sure that your data is damaged at the most inconvienient moment in time, causing the maximum damage.) Yes. Bu tin my case, the processes are always upating the existing data in the file. I tried Storable's lock functions first. They didn't work in my case (though it entirely possible I wasn't using them right. It seemed to me that something like this was happening:
But again, maybe I was using the lock functions wrong. Not sure.
$PM = "Perl Monk's";
In Section
Seekers of Perl Wisdom
|
|