Re: mail alert - Mailing list pgsql-sql

From Christopher Browne
Subject Re: mail alert
Date
Msg-id 87ab22qv9e.fsf@dba2.int.libertyrms.com
Whole thread Raw
In response to mail alert  (Jan Verheyden <jan.verheyden@uz.kuleuven.ac.be>)
List pgsql-sql
tim@tim-landscheidt.de (Tim Landscheidt) writes:
> Alvaro Herrera <alvherre@commandprompt.com> wrote:
>
>>> > It's on Windows
>
>>> I'd go with notify and a listener written in C using c-client to send
>>> emails, but only because I've used those before.
>
>> I wouldn't write it in C but rather Perl or Python, but whatever suits
>> your fancy should work (Visual Basic anyone?).  The advantages to using
>> a listener program instead of doing it in a trigger or something like
>> that are:
>
>> - transaction semantics are kept; you don't send an email only to find
>> out your transaction has been rolled back for whatever reason, and then
>> send a second email when the transaction is replayed
>
>> - you don't block the database system just because your mail server is
>> down
>
>> - the email can be sent on whatever schedule fits the listener program
>
>> - the listener client can run elsewhere, not only in the database server
>
>> - any further external processing can take place at that time, without
>> bothering the database server
>
>> - other stuff I don't recall ATM
>
> The main disadvantage in using a listener is that it is your
> responsibility to make sure that the listener is listening
> 24/7 - from before the database accepts other connections,
> through network failures, bugs, etc. - otherwise notifica-
> tions will be lost. Therefore I find it much more reliable
> (and easier to program) to copy the relevant data to a table
> "mailqueue" (or whatever) and then process that queue every
> other minute.

Actually, I don't think there's any real disagreement here...
- The *important* bit is to make sure that the data required to  generate the email is queued in the database.
- Whether you poll or use notify/listen is *way* less important.

You could implement the "listener process" a number of ways:
 - It could be a "cron" that wakes up every so often   to do whatever work is outstanding
 - It could be a "polling daemon" that sleeps for a while between   iterations.
   That seems a little nicer than the "cron" approach in that it   eliminates a troublesome scenario, namely the case
wherethere's a   lot of work to do (flooded queue?)  so that processing takes longer   than the polling interval,
leadingto the risk that a second "cron"   starts up while the previous one is still working.
 
 - It could be a "listening daemon" that listens for notifications to   indicate that work is outstanding
   That is a little better than the "polling daemon" in that it doesn't   need to wait the full polling period to start
processingnew work.
 

Any of those three approaches are quite viable, as long as you're
careful to cover scenarios like:- daemon falling over- accidentally starting multiple "queue processors"
-- 
output = reverse("ofni.sailifa.ac" "@" "enworbbc")
Christopher Browne
"Bother,"  said Pooh,  "Eeyore, ready  two photon  torpedoes  and lock
phasers on the Heffalump, Piglet, meet me in transporter room three"


pgsql-sql by date:

Previous
From: Tim Landscheidt
Date:
Subject: Re: simple? query
Next
From: Christopher Browne
Date:
Subject: Re: Field or record level encryption / decryption