Re: Suspending SELECTs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jan 17, 2006 at 09:06:53PM +0100, Alessandro Baretta wrote:
> Craig A. James wrote:
> >
> >Alessandro Baretta <a.baretta@xxxxxxxxxxxxxxx> writes:
> >
> >I think you're trying to do something at the wrong layer of your 
> >architecture.  This task normally goes in your middleware layer, not 
> >your database layer.
> 
> I am developing my applications in Objective Caml, and I have written the 
> middleware layer myself. I could easily implement a cursor-pooling 
> strategy, but there is no perfect solution to the problem of guaranteeing 
> that cursors be closed. Remember that web applications require the user to 
> "open a session" by connecting the appropriate HTTP resource, but users as 
> never required to log out. Hence, in order to eventually reclaim all 
> cursors, I must use magical "log-out detection" algorithm, which is usually 
> implemented with a simple timeout. This guarantees the required property of 
> safety (the population of cursors does not diverge) but does not guarantee 
> the required property of liveness (a user connecting to the application, 
> who has opened a session but has not logged out, and thus possesses a 
> session token, should have access the execution context identified by his 
> token).

With some "AJAX magic", it would probably be pretty easy to create an
application that let you know very quickly if a user left the
application (ie: browsed to another site, or closed the browser).
Essentially, you should be able to set it up so that it will ping the
application server fairly frequently (like every 10 seconds), so you
could drastically reduce the timeout interval.
-- 
Jim C. Nasby, Sr. Engineering Consultant      jnasby@xxxxxxxxxxxxx
Pervasive Software      http://pervasive.com    work: 512-231-6117
vcard: http://jim.nasby.net/pervasive.vcf       cell: 512-569-9461


[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux