From: Bernhard Bitsch <bbitsch@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: Stale pakfire lock-file causing pakfire to no longer work
Date: Thu, 15 Sep 2022 22:03:09 +0200 [thread overview]
Message-ID: <71fd83af-d174-30a1-d1f5-8ce0789fcbbf@ipfire.org> (raw)
In-Reply-To: <44a87a6c1fdba4c724e15a22467d2b5b4224577a.camel@sicho.home>
[-- Attachment #1: Type: text/plain, Size: 2367 bytes --]
Hi Robin,
Am 15.09.2022 um 21:43 schrieb Robin Roevens:
> Hi Bernhard
>
> Bernhard Bitsch schreef op do 15-09-2022 om 13:48 [+0200]:
>> Hi all,
>>
>> as an 'old real time programmer' this reminds me deeply at
>> Dijkstra/Hoare's "Dining philosophers problem".
>>
>> The check for presence of the lockfile and the generation of it are
>> not
>> 'atomic'. Means two programs can run in parallel.
> Indeed..
> In a shell script, a more atomic approach would be instead of using a
> lockfile, a lock-directory:
> 'mkdir' creates a directory only if it not already exists and if it
> does already exist, it will return an exit code. So here we have both
> checking and generating in one atomic operation.
> This is better explained here:
> https://wiki.bash-hackers.org/howto/mutex
>
> Not sure if this can be translated to Perl in an atomic way..
> I did find this perl code snippet however:
> ---
> use strict;
> use warnings;
> use Fcntl ':flock';
>
> flock(DATA, LOCK_EX|LOCK_NB) or die "There can be only one! [$0]";
>
>
> # mandatory line, flocking depends on DATA file handle
> __DATA__
> ---
> Which could be a possible solution, I think.
>
Looks promising. Will look into this.
> I also found this, which seems quiet promising:
> https://metacpan.org/pod/Script::Singleton
> to perform locking by using shared memory.
>
>>
>> I'll investigate this further. But the deletion of the lock should
>> happen anyways, as far I've seen till now.
> True, it should be deleted always and as said before, I could not
> reproduce this manually .. but my Zabbix agent seems to be able to
> trigger this problem at least once every 24h on my IPFire mini
> appliance, only by executing pakfire every 10 minutes. That is why I'm
> suspecting the abnormal termination of pakfire, leaving the lockfile in
> place, is actually caused by sudo.
>
> On the other hand.. this can also happen when pakfire is running and
> suddenly the power is cut.. then the lockfile will still be present
> when the machine is back up.. So I think, if we stay with the lockfile,
> we at least need some check for a stale lockfile, like checking if the
> process that created the lockfile still exists or not and removing it
> if not.
>
Because the lockfile is located in /tmp, I don't think it survives a reboot.
Regards
Bernhard
> Regards
> Robin
>
>>
>> Regards,
>> Bernhard
>>
>
next prev parent reply other threads:[~2022-09-15 20:03 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-14 19:48 Robin Roevens
2022-09-15 7:39 ` Peter Müller
2022-09-15 19:01 ` Robin Roevens
2022-09-15 19:09 ` Bernhard Bitsch
2022-09-15 11:48 ` Bernhard Bitsch
2022-09-15 19:43 ` Robin Roevens
2022-09-15 20:03 ` Bernhard Bitsch [this message]
2022-09-15 20:30 ` Robin Roevens
2022-09-15 23:27 ` Bernhard Bitsch
2022-09-17 21:56 ` Robin Roevens
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=71fd83af-d174-30a1-d1f5-8ce0789fcbbf@ipfire.org \
--to=bbitsch@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox