Re: mail alert

From: Christopher Browne <cbbrowne(at)ca(dot)afilias(dot)info>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: mail alert
Date: 2009-08-14 15:18:21
Message-ID: 87ab22qv9e.fsf@dba2.int.libertyrms.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

tim(at)tim-landscheidt(dot)de (Tim Landscheidt) writes:
> Alvaro Herrera <alvherre(at)commandprompt(dot)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 where there's a
lot of work to do (flooded queue?) so that processing takes longer
than the polling interval, leading to 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 processing new 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"

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message Christopher Browne 2009-08-14 15:21:23 Re: Field or record level encryption / decryption
Previous Message Tim Landscheidt 2009-08-14 14:53:16 Re: simple? query