From: | Philippe Lang <philippe(dot)lang(at)attiksystem(dot)ch> |
---|---|
To: | "pgsql-general(at)postgresql(dot)org" <pgsql-general(at)postgresql(dot)org> |
Subject: | Re: Non-reentrant plperlu function & concurrent access |
Date: | 2010-08-17 08:15:37 |
Message-ID: | 8AE5A725DAF7364F97FF75D99E45B6575B98401F@SBS1.attiksystem.local |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
> Hi,
>
> I have a non-reentrant plperlu function, which does no database
> modification. It basically stores input data into a file, calls a unix
> shell command, and reads the result back from another file.
>
> I don't really care about database isolation here, phantom reads and
> such. It is not likely to be a problem. What could be a problem, is if
> another call to this function is fired while another one is running.
>
> In this specific case, I could solve the problem by generating random
> input and ouput filenames, but I would prefer a more general solution,
> like using some sort of mutex for the function. What is the best way to
> do that under Postgresql? Although not designed for this (if I
> understand correctly), would a "serializable" isolation level help
> here?
I answer to my own post, sorry...
Maybe Postgresql functions "pg_try_advisory_lock_shared" and "pg_advisory_unlock_shared" are the solution?
-------------------------------------------------------------
Attik System web : http://www.attiksystem.ch
Philippe Lang phone: +41 26 422 13 75
rte de la Fonderie 2 gsm : +41 79 351 49 94
1700 Fribourg pgp : http://keyserver.pgp.com
From | Date | Subject | |
---|---|---|---|
Next Message | Maurice Gittens | 2010-08-17 08:32:12 | Why No WHERE clause for INSERT statements |
Previous Message | Philippe Lang | 2010-08-17 07:12:35 | Non-reentrant plperlu function & concurrent access |