'after' in gen_server

Rick Pettit rpettit@REDACTED
Thu Mar 23 22:35:21 CET 2006


On Thu, Mar 23, 2006 at 04:26:22PM -0500, orbitz@REDACTED wrote:
> I want to do it from all callbacks.  Basically I want to make it so if 
> the server is idle for X amount of time, then that means something is 
> wrong and I need to do something to figure out what is wrong.

Then have your callbacks set a gen_server "idle timeout" by way of the
gen_server timeout mechanism, and service timeouts in handle_info/2.

It is as simple as passing a timeout value in the return value from your
callbacks--Module:init/1, Module:handle_call/3, Module:handle_cast/2, etc.

-Rick

> On Mar 23, 2006, at 11:04 AM, Rick Pettit wrote:
> 
> >On Thu, Mar 23, 2006 at 10:42:04AM -0500, orbitz@REDACTED wrote:
> >>I am reworking a bit of code into gen_server pattern.  In this code I
> >>have a typical loop construct.  In this I want to perform an action if
> >>no messages have been receive in a certain amount of time, to do this 
> >>I
> >>simply have after sometimeout ->.  Is there any equivalence of this in
> >>gen_server?
> >
> >If I understand you correctly, all you need to do is set a timeout when
> >returning from one of the gen_server callback functions.
> >
> >For example, instead of returning {ok,State} from Module:init/1, return
> >{ok,State,TimeoutMs}. You can do this for all the gen_server callback
> >routines (at least handle_call/handle_cast, etc).
> >
> >This effectively sets a timer which will expire if no message is 
> >received
> >by the gen_server before TimeoutMs has elapsed. If/when the timer does
> >expire, you receive a 'timeout' message in Module:handle_info/2.
> >
> >-Rick
> >
> >P.S. Since gen_server abstracts the server receive loop, I (as a 
> >general rule
> >     of thumb) *never* call receive in a gen_server callback module.
> >
> >>It has been suggested that I use a timer and record when the last
> >>message has come in and when the timer signals check against that
> >>message.  This seems a poor solution.  Another suggestions was to use 
> >>a
> >>gen_fsm with a timeout, but this seem a bit much just to get an 
> >>'after'
> >>mechanism. Any other suggestions?  Perhaps my disregard of gen_fsm is 
> >>a
> >>bit hasty?
> >
> 



More information about the erlang-questions mailing list