1gen_server(3) Erlang Module Definition gen_server(3)
2
3
4
6 gen_server - Generic server behavior.
7
9 This behavior module provides the server of a client-server relation. A
10 generic server process (gen_server) implemented using this module has a
11 standard set of interface functions and includes functionality for
12 tracing and error reporting. It also fits into an OTP supervision tree.
13 For more information, see section gen_server Behaviour in OTP Design
14 Principles.
15
16 A gen_server process assumes all specific parts to be located in a
17 callback module exporting a predefined set of functions. The relation‐
18 ship between the behavior functions and the callback functions is as
19 follows:
20
21 gen_server module Callback module
22 ----------------- ---------------
23 gen_server:start
24 gen_server:start_monitor
25 gen_server:start_link -----> Module:init/1
26
27 gen_server:stop -----> Module:terminate/2
28
29 gen_server:call
30 gen_server:send_request
31 gen_server:multi_call -----> Module:handle_call/3
32
33 gen_server:cast
34 gen_server:abcast -----> Module:handle_cast/2
35
36 - -----> Module:handle_info/2
37
38 - -----> Module:handle_continue/2
39
40 - -----> Module:terminate/2
41
42 - -----> Module:code_change/3
43
44 If a callback function fails or returns a bad value, the gen_server
45 process terminates.
46
47 A gen_server process handles system messages as described in sys(3).
48 The sys module can be used for debugging a gen_server process.
49
50 Notice that a gen_server process does not trap exit signals automati‐
51 cally, this must be explicitly initiated in the callback module.
52
53 Unless otherwise stated, all functions in this module fail if the spec‐
54 ified gen_server process does not exist or if bad arguments are speci‐
55 fied.
56
57 The gen_server process can go into hibernation (see erlang:hibernate/3)
58 if a callback function specifies 'hibernate' instead of a time-out
59 value. This can be useful if the server is expected to be idle for a
60 long time. However, use this feature with care, as hibernation implies
61 at least two garbage collections (when hibernating and shortly after
62 waking up) and is not something you want to do between each call to a
63 busy server.
64
65 If the gen_server process needs to perform an action immediately after
66 initialization or to break the execution of a callback into multiple
67 steps, it can return {continue,Continue} in place of the time-out or
68 hibernation value, which will immediately invoke the handle_continue/2
69 callback.
70
71 If the gen_server process terminates, e.g. as a result of a function in
72 the callback module returning {stop,Reason,NewState}, an exit signal
73 with this Reason is sent to linked processes and ports. See Processes
74 in the Reference Manual for details regarding error handling using exit
75 signals.
76
78 server_name() =
79 {local, LocalName :: atom()} |
80 {global, GlobalName :: term()} |
81 {via, RegMod :: module(), ViaName :: term()}
82
83 Name specification to use when starting a gen_server. See func‐
84 tions start/3,4, start_link/3,4, start_monitor/3,4, en‐
85 ter_loop/3,4,5, and the type server_ref() below.
86
87 {local,LocalName}:
88 Register the gen_server locally as LocalName using regis‐
89 ter/2.
90
91 {global,GlobalName}:
92 Register the gen_server process id globally as GlobalName
93 using global:register_name/2.
94
95 {via,RegMod,ViaName}:
96 Register the gen_server process with the registry repre‐
97 sented by RegMod. The RegMod callback is to export the func‐
98 tions register_name/2, unregister_name/1, whereis_name/1,
99 and send/2, which are to behave like the corresponding func‐
100 tions in global. Thus, {via,global,GlobalName} is a valid
101 reference equivalent to {global,GlobalName}.
102
103 server_ref() =
104 pid() |
105 (LocalName :: atom()) |
106 {Name :: atom(), Node :: atom()} |
107 {global, GlobalName :: term()} |
108 {via, RegMod :: module(), ViaName :: term()}
109
110 Server specification to use when addressing a gen_server. See
111 call/2,3, cast/2, send_request/2, check_response/2, wait_re‐
112 sponse/2, stop/2,3 and the type server_name() above.
113
114 It can be:
115
116 pid():
117 The gen_server's process identifier.
118
119 LocalName:
120 The gen_server is locally registered as LocalName with reg‐
121 ister/2.
122
123 {Name,Node}:
124 The gen_server is locally registered on another node.
125
126 {global,GlobalName}:
127 The gen_server is globally registered in global.
128
129 {via,RegMod,ViaName}:
130 The gen_server is registered in an alternative process reg‐
131 istry. The registry callback module RegMod is to export
132 functions register_name/2, unregister_name/1,
133 whereis_name/1, and send/2, which are to behave like the
134 corresponding functions in global. Thus, {via,global,Global‐
135 Name} is the same as {global,GlobalName}.
136
137 start_opt() =
138 {timeout, Timeout :: timeout()} |
139 {spawn_opt, SpawnOptions :: [proc_lib:spawn_option()]} |
140 enter_loop_opt()
141
142 Options that can be used when starting a gen_server server
143 through, for example, start_link/3,4.
144
145 {timeout,Timeout}:
146 How many milliseconds the gen_server process is allowed to
147 spend initializing or it is terminated and the start func‐
148 tion returns {error,timeout}.
149
150 {spawn_opt,SpawnOptions}:
151 The SpawnOptions option list is passed to the function used
152 to spawn the gen_server; see spawn_opt/2.
153
154 Note:
155 Using spawn option monitor is not allowed, it causes a badarg
156 failure.
157
158
159 enter_loop_opt():
160 See the type enter_loop_opt() below for more start options
161 that are also allowed by enter_loop/3,4,5.
162
163 enter_loop_opt() =
164 {hibernate_after, HibernateAfterTimeout :: timeout()} |
165 {debug, Dbgs :: [sys:debug_option()]}
166
167 Options that can be used when starting a gen_server server
168 through enter_loop/3-5 or the start functions such as
169 start_link/3,4.
170
171 {hibernate_after,HibernateAfterTimeout}:
172 Specifies that the gen_server process awaits any message for
173 HibernateAfterTimeout milliseconds and if no message is re‐
174 ceived, the process goes into hibernation automatically (by
175 calling proc_lib:hibernate/3).
176
177 {debug,Dbgs}:
178 For every entry in Dbgs, the corresponding function in
179 sys(3) is called.
180
181 start_ret() =
182 {ok, Pid :: pid()} | ignore | {error, Reason :: term()}
183
184 Return value from the start/3,4 and start_link/3,4 functions.
185
186 {ok,Pid}:
187 The gen_server process was succesfully created and initial‐
188 ized, with the process identifier Pid.
189
190 {error,{already_started,OtherPid}}:
191 A process with the specified ServerName exists already with
192 the process identifier OtherPid. This gen_server was not
193 started.
194
195 ignore:
196 Module:init/1 returned ignore, the gen_server process is
197 terminated. An exit signal normal is sent to linked pro‐
198 cesses and ports.
199
200 {error,Reason}:
201 Module:init/1 returned {stop,Reason} or failed with Reason.
202 The gen_server process is terminated and an exit signal with
203 the same Reason is sent to linked processes and ports.
204
205 start_mon_ret() =
206 {ok, {Pid :: pid(), MonRef :: reference()}} |
207 ignore |
208 {error, Reason :: term()}
209
210 Return value from the start_monitor/3,4 functions. The same as
211 type start_ret() except that for a succesful start it returns
212 both the process identifier Pid and a monitor/2,3 reference()
213 MonRef.
214
215 from() = {Client :: pid(), Tag :: reply_tag()}
216
217 Destination, given to the gen_server as the first argument to
218 the callback function Module:handle_call/3, to be used by the
219 when replying through reply/2 (instead of through the callback
220 function's return value) to the process Client that has called
221 the gen_server using call/2,3. Tag is a term that is unique for
222 this call/request instance.
223
224 reply_tag()
225
226 A handle that associates a reply to the corresponding request.
227
228 request_id()
229
230 An opaque request identifier. See send_request/2 for details.
231
232 request_id_collection()
233
234 An opaque collection of request identifiers (request_id()) where
235 each request identifier can be associated with a label chosen by
236 the user. For more information see reqids_new/0.
237
238 response_timeout() = timeout() | {abs, integer()}
239
240 Used to set a time limit on how long to wait for a response us‐
241 ing either receive_response/2, receive_response/3, wait_re‐
242 sponse/2, or wait_response/3. The time unit used is millisecond.
243 Currently valid values:
244
245 0..4294967295:
246 Timeout relative to current time in milliseconds.
247
248 infinity:
249 Infinite timeout. That is, the operation will never time
250 out.
251
252 {abs, Timeout}:
253 An absolute Erlang monotonic time timeout in milliseconds.
254 That is, the operation will time out when erlang:mono‐
255 tonic_time(millisecond) returns a value larger than or equal
256 to Timeout. Timeout is not allowed to identify a time fur‐
257 ther into the future than 4294967295 milliseconds. Identify‐
258 ing the timeout using an absolute timeout value is espe‐
259 cially handy when you have a deadline for responses corre‐
260 sponding to a complete collection of requests (re‐
261 quest_id_collection()) , since you do not have to recalcu‐
262 late the relative time until the deadline over and over
263 again.
264
265 format_status() =
266 #{state => term(),
267 message => term(),
268 reason => term(),
269 log => [sys:system_event()]}
270
271 A map that describes the gen_server status. The keys are:
272
273 state:
274 The internal state of the gen_server process.
275
276 message:
277 The message that caused the server to terminate.
278
279 reason:
280 The reason that caused the server to terminate.
281
282 log:
283 The sys log of the server.
284
285 New associations may be added to the status map without prior
286 notice.
287
289 abcast(Name :: atom(), Request :: term()) -> abcast
290
291 abcast(Nodes :: [node()], Name :: atom(), Request :: term()) ->
292 abcast
293
294 Sends an asynchronous request to the gen_server processes lo‐
295 cally registered as Name at the specified nodes. The function
296 returns immediately and ignores nodes that do not exist, or
297 where the gen_server Name does not exist. The gen_server pro‐
298 cesses call Module:handle_cast/2 to handle the request.
299
300 For a description of the arguments, see multi_call/2,3,4.
301
302 call(ServerRef :: server_ref(), Request :: term()) ->
303 Reply :: term()
304
305 call(ServerRef :: server_ref(),
306 Request :: term(),
307 Timeout :: timeout()) ->
308 Reply :: term()
309
310 Makes a synchronous call to the ServerRef of the gen_server
311 process by sending a request and waiting until a reply arrives
312 or a time-out occurs. The gen_server process calls Module:han‐
313 dle_call/3 to handle the request.
314
315 See also ServerRef's type server_ref().
316
317 Request is any term that is passed as the first argument to Mod‐
318 ule:handle_call/3.
319
320 Timeout is an integer that specifies how many milliseconds to
321 wait for a reply, or the atom infinity to wait indefinitely. De‐
322 faults to 5000. If no reply is received within the specified
323 time, this function exits the calling process with an exit term
324 containing Reason = timeout as described below.
325
326 Note:
327 Before OTP 24, if the caller uses (try...)catch to avoid process
328 exit, and the server happens to just be late with the reply, it
329 may arrive to the process message queue any time later. The
330 calling process must therefore after catching a time-out exit be
331 prepared to receive garbage message(s) on the form {reference(),
332 _} and deal with them appropriately (discard them) so they do
333 not clog the process message queue or gets mistaken for other
334 messages.
335
336 Starting with OTP 24, gen_server:call uses process aliases, so
337 late replies will not be received.
338
339
340 The return value Reply is passed from the return value of Mod‐
341 ule:handle_call/3.
342
343 This call may exit the calling process with an exit term on the
344 form {Reason, Location} where Location = {gen_server,call,Ar‐
345 gList} and Reason can be (at least) one of:
346
347 timeout:
348 The call was aborted after waiting Timeout milliseconds for
349 a reply, as described above.
350
351 noproc:
352 The ServerRef refers to a server by name (it is not a pid())
353 and looking up the server process failed, or the pid() was
354 already terminated.
355
356 {nodedown,Node}:
357 The ServerRef refers to a server on the remote node Node and
358 the connection to that node failed.
359
360 calling_self:
361 A call to self() would hang indefinitely.
362
363 shutdown
364 : The server was stopped during the call by its supervisor.
365 See also stop/3.
366
367 normal
368 {shutdown,Term}
369 : The server stopped during the call by returning {stop,Rea‐
370 son,_} from its Module:handle_call/3 callback, without re‐
371 plying. See also stop/3.
372
373 _OtherTerm:
374 The server process exited during the call, with reason Rea‐
375 son. Either by returning {stop,Reason,_} from its Mod‐
376 ule:handle_call/3 callback (without replying), by raising an
377 exception, or due to getting an exit signal it did not trap.
378
379 cast(ServerRef :: server_ref(), Request :: term()) -> ok
380
381 Sends an asynchronous request to the ServerRef of the gen_server
382 process and returns ok immediately, ignoring if the destination
383 node or gen_server process does not exist. The gen_server
384 process calls Module:handle_cast/2 to handle the request.
385
386 See also ServerRef's type server_ref().
387
388 Request is any term that is passed as the first argument to Mod‐
389 ule:handle_cast/2.
390
391 check_response(Msg, ReqId) -> Result
392
393 Types:
394
395 Msg = term()
396 ReqId = request_id()
397 Response =
398 {reply, Reply :: term()} |
399 {error, {Reason :: term(), server_ref()}}
400 Result = Response | no_reply
401
402 Check if Msg is a response corresponding to the request identi‐
403 fier ReqId. The request must have been made by send_request/2,
404 and it must have been made by the same process calling this
405 function.
406
407 If Msg is a response corresponding to ReqId the response is re‐
408 turned; otherwise, no_reply is returned and no cleanup is done,
409 and thus the function must be invoked repeatedly until a re‐
410 sponse is returned.
411
412 The return value Reply is passed from the return value of Mod‐
413 ule:handle_call/3.
414
415 The function returns an error if the gen_server died before a
416 reply was sent.
417
418 check_response(Msg, ReqIdCollection, Delete) -> Result
419
420 Types:
421
422 Msg = term()
423 ReqIdCollection = request_id_collection()
424 Delete = boolean()
425 Response =
426 {reply, Reply :: term()} |
427 {error, {Reason :: term(), server_ref()}}
428 Result =
429 {Response,
430 Label :: term(),
431 NewReqIdCollection :: request_id_collection()} |
432 no_request | no_reply
433
434 Check if Msg is a response corresponding to a request identifier
435 saved in ReqIdCollection. All request identifiers of ReqIdCol‐
436 lection must correspond to requests that have been made using
437 send_request/2 or send_request/4, and all request must have been
438 made by the process calling this function.
439
440 The Label in the response equals the Label associated with the
441 request identifier that the response corresponds to. The Label
442 of a request identifier is associated when saving the request id
443 in a request identifier collection, or when sending the request
444 using send_request/4.
445
446 Compared to check_response/2, the returned result associated
447 with a specific request identifier or an exception associated
448 with a specific request identifier will be wrapped in a 3-tuple.
449 The first element of this tuple equals the value that would have
450 been produced by check_response/2, the second element equals the
451 Label associated with the specific request identifier, and the
452 third element NewReqIdCollection is a possibly modified request
453 identifier collection.
454
455 If ReqIdCollection is empty, the atom no_request will be re‐
456 turned. If Msg does not correspond to any of the request identi‐
457 fiers in ReqIdCollection, the atom no_reply is returned.
458
459 If Delete equals true, the association with Label will have been
460 deleted from ReqIdCollection in the resulting NewReqIdCollec‐
461 tion. If Delete equals false, NewReqIdCollection will equal Re‐
462 qIdCollection. Note that deleting an association is not for free
463 and that a collection containing already handled requests can
464 still be used by subsequent calls to check_response/3, re‐
465 ceive_response/3, and wait_response/3. However, without deleting
466 handled associations, the above calls will not be able to detect
467 when there are no more outstanding requests to handle, so you
468 will have to keep track of this some other way than relying on a
469 no_request return. Note that if you pass a collection only con‐
470 taining associations of already handled or abandoned requests to
471 check_response/3, it will always return no_reply.
472
473 enter_loop(Module :: module(),
474 Options :: [enter_loop_opt()],
475 State :: term()) ->
476 no_return()
477
478 enter_loop(Module :: module(),
479 Options :: [enter_loop_opt()],
480 State :: term(),
481 ServerName :: server_name() | pid()) ->
482 no_return()
483
484 enter_loop(Module :: module(),
485 Options :: [enter_loop_opt()],
486 State :: term(),
487 Timeout :: timeout()) ->
488 no_return()
489
490 enter_loop(Module :: module(),
491 Options :: [enter_loop_opt()],
492 State :: term(),
493 Hibernate :: hibernate) ->
494 no_return()
495
496 enter_loop(Module :: module(),
497 Options :: [enter_loop_opt()],
498 State :: term(),
499 Cont :: {continue, term()}) ->
500 no_return()
501
502 enter_loop(Module :: module(),
503 Options :: [enter_loop_opt()],
504 State :: term(),
505 ServerName :: server_name() | pid(),
506 Timeout :: timeout()) ->
507 no_return()
508
509 enter_loop(Module :: module(),
510 Options :: [enter_loop_opt()],
511 State :: term(),
512 ServerName :: server_name() | pid(),
513 Hibernate :: hibernate) ->
514 no_return()
515
516 enter_loop(Module :: module(),
517 Options :: [enter_loop_opt()],
518 State :: term(),
519 ServerName :: server_name() | pid(),
520 Cont :: {continue, term()}) ->
521 no_return()
522
523 Makes an existing process a gen_server process. Does not return,
524 instead the calling process enters the gen_server process re‐
525 ceive loop and becomes a gen_server process. The process must
526 have been started using one of the start functions in
527 proc_lib(3). The user is responsible for any initialization of
528 the process, including registering a name for it.
529
530 This function is useful when a more complex initialization pro‐
531 cedure is needed than the gen_server process behavior provides.
532
533 Module, Options, and ServerName have the same meanings as when
534 calling start[_link|_monitor]/3,4 or it can be self() for an
535 anonymous server, which is the same as calling an enter_loop/3,4
536 function without a ServerName argument. However, if ServerName
537 is specified (and not as self()), the process must have been
538 registered accordingly before this function is called.
539
540 State, Timeout, Hibernate and Cont have the same meanings as in
541 the return value of Module:init/1, which is not called when en‐
542 ter_loop/3,4,5 is used. Note that to adhere to the gen_server
543 Behaviour such a callback function needs to be defined, and it
544 might as well be the one used when starting the gen_server
545 process through proc_lib, and then be the one that calls en‐
546 ter_loop/3,4,5. But if such a Module:init/1 function in for ex‐
547 ample error cases cannot call enter_loop/3,4,5, it should return
548 a value that follows the type specification for Module:init/1
549 such as ignore, although that value will be lost when returning
550 to the spawning function.
551
552 This function fails if the calling process was not started by a
553 proc_lib start function, or if it is not registered according to
554 ServerName.
555
556 multi_call(Name :: atom(), Request :: term()) ->
557 {Replies :: [{Node :: node(), Reply :: term()}],
558 BadNodes :: [node()]}
559
560 multi_call(Nodes :: [node()], Name :: atom(), Request :: term()) ->
561 {Replies :: [{Node :: node(), Reply :: term()}],
562 BadNodes :: [node()]}
563
564 multi_call(Nodes :: [node()],
565 Name :: atom(),
566 Request :: term(),
567 Timeout :: timeout()) ->
568 {Replies :: [{Node :: node(), Reply :: term()}],
569 BadNodes :: [node()]}
570
571 Makes a synchronous call to all gen_server processes locally
572 registered as Name at the specified nodes, by first sending the
573 request to the nodes, and then waiting for the replies. The
574 gen_server processes on the nodes call Module:handle_call/3 to
575 handle the request.
576
577 The function returns a tuple {Replies,BadNodes}, where Replies
578 is a list of {Node,Reply} tuples, and BadNodes is a list of
579 nodes that either did not exist, where Name was not a registered
580 gen_server, or where it did not reply.
581
582 Nodes is a list of node names to which the request is to be
583 sent. Default value is the list of all known nodes
584 [node()|nodes()].
585
586 Name is the locally registered name for each gen_server process.
587
588 Request is any term that is passed as the first argument to Mod‐
589 ule:handle_call/3.
590
591 Timeout is an integer that specifies how many milliseconds to
592 wait for all replies, or the atom infinity to wait indefinitely,
593 which is the default. If no reply is received from a node within
594 the specified time, the node is added to BadNodes.
595
596 When a reply Reply is received from the gen_server process at a
597 node Node, {Node,Reply} is added to Replies. Reply is passed
598 from the return value of Module:handle_call/3.
599
600 Warning:
601 If one of the nodes cannot process monitors, for example, C or
602 Java nodes, and the gen_server process is not started when the
603 requests are sent, but starts within 2 seconds, this function
604 waits the whole Timeout, which may be infinity.
605
606 This problem does not exist if all nodes are Erlang nodes.
607
608
609 To prevent late answers (after the time-out) from polluting the
610 message queue of the caller, a middleman process is used to do
611 the calls. Late answers are then discarded when they arrive to a
612 terminated process.
613
614 receive_response(ReqId, Timeout) -> Result
615
616 Types:
617
618 ReqId = request_id()
619 Timeout = response_timeout()
620 Response =
621 {reply, Reply :: term()} |
622 {error, {Reason :: term(), server_ref()}}
623 Result = Response | timeout
624
625 Receive a response corresponding to the request identifier Re‐
626 qId. The request must have been made by send_request/2, and it
627 must have been made by the same process calling this function.
628
629 Timeout specifies how long to wait for a response. If no re‐
630 sponse is received within the specified time, the function re‐
631 turns timeout. Assuming that the server executes on a node sup‐
632 porting aliases (introduced in OTP 24) the request will also be
633 abandoned. That is, no response will be received after a time‐
634 out. Otherwise, a stray response might be received at a later
635 time.
636
637 The return value Reply is passed from the return value of Mod‐
638 ule:handle_call/3.
639
640 The function returns an error if the gen_server died before a
641 reply was sent.
642
643 The difference between receive_response/2 and wait_response/2 is
644 that receive_response/2 abandons the request at timeout so that
645 a potential future response is ignored, while wait_response/2
646 does not.
647
648 receive_response(ReqIdCollection, Timeout, Delete) -> Result
649
650 Types:
651
652 ReqIdCollection = request_id_collection()
653 Timeout = response_timeout()
654 Delete = boolean()
655 Response =
656 {reply, Reply :: term()} |
657 {error, {Reason :: term(), server_ref()}}
658 Result =
659 {Response,
660 Label :: term(),
661 NewReqIdCollection :: request_id_collection()} |
662 no_request | timeout
663
664 Receive a response corresponding to a request identifier saved
665 in ReqIdCollection. All request identifiers of ReqIdCollection
666 must correspond to requests that have been made using send_re‐
667 quest/2 or send_request/4, and all request must have been made
668 by the process calling this function.
669
670 The Label in the response equals the Label associated with the
671 request identifier that the response corresponds to. The Label
672 of a request identifier is associated when adding the request id
673 in a request identifier collection, or when sending the request
674 using send_request/4.
675
676 Compared to receive_response/2, the returned result associated
677 with a specific request identifier will be wrapped in a 3-tuple.
678 The first element of this tuple equals the value that would have
679 been produced by receive_response/2, the second element equals
680 the Label associated with the specific request identifier, and
681 the third element NewReqIdCollection is a possibly modified re‐
682 quest identifier collection.
683
684 If ReqIdCollection is empty, the atom no_request will be re‐
685 turned.
686
687 Timeout specifies how long to wait for a response. If no re‐
688 sponse is received within the specified time, the function re‐
689 turns timeout. Assuming that the server executes on a node sup‐
690 porting aliases (introduced in OTP 24) all requests identified
691 by ReqIdCollection will also be abandoned. That is, no responses
692 will be received after a timeout. Otherwise, stray responses
693 might be received at a later time.
694
695 The difference between receive_response/3 and wait_response/3 is
696 that receive_response/3 abandons the requests at timeout so that
697 potential future responses are ignored, while wait_response/3
698 does not.
699
700 If Delete equals true, the association with Label will have been
701 deleted from ReqIdCollection in the resulting NewReqIdCollec‐
702 tion. If Delete equals false, NewReqIdCollection will equal Re‐
703 qIdCollection. Note that deleting an association is not for free
704 and that a collection containing already handled requests can
705 still be used by subsequent calls to receive_response/3,
706 check_response/3, and wait_response/3. However, without deleting
707 handled associations, the above calls will not be able to detect
708 when there are no more outstanding requests to handle, so you
709 will have to keep track of this some other way than relying on a
710 no_request return. Note that if you pass a collection only con‐
711 taining associations of already handled or abandoned requests to
712 receive_response/3, it will always block until a timeout deter‐
713 mined by Timeout is triggered.
714
715 reply(Client :: from(), Reply :: term()) -> ok
716
717 This function can be used by a gen_server process to explicitly
718 send a reply to a client that called call/2,3 or
719 multi_call/2,3,4, when the reply cannot be passed in the return
720 value of Module:handle_call/3.
721
722 Client must be the From argument provided to the handle_call
723 callback function. Reply is any term passed back to the client
724 as the return value of call/2,3 or multi_call/2,3,4.
725
726 reqids_add(ReqId :: request_id(),
727 Label :: term(),
728 ReqIdCollection :: request_id_collection()) ->
729 NewReqIdCollection :: request_id_collection()
730
731 Saves ReqId and associates a Label with the request identifier
732 by adding this information to ReqIdCollection and returning the
733 resulting request identifier collection.
734
735 reqids_new() -> NewReqIdCollection :: request_id_collection()
736
737 Returns a new empty request identifier collection. A request
738 identifier collection can be utilized in order the handle multi‐
739 ple outstanding requests.
740
741 Request identifiers of requests made by send_request/2 can be
742 saved in a request identifier collection using reqids_add/3.
743 Such a collection of request identifiers can later be used in
744 order to get one response corresponding to a request in the col‐
745 lection by passing the collection as argument to receive_re‐
746 sponse/3, wait_response/3, or, check_response/3.
747
748 reqids_size/1 can be used to determine the amount of request
749 identifiers in a request identifier collection.
750
751 reqids_size(ReqIdCollection :: request_id_collection()) ->
752 integer() >= 0
753
754 Returns the amount of request identifiers saved in ReqIdCollec‐
755 tion.
756
757 reqids_to_list(ReqIdCollection :: request_id_collection()) ->
758 [{ReqId :: request_id(), Label :: term()}]
759
760 Returns a list of {ReqId, Label} tuples which corresponds to all
761 request identifiers with their associated labels present in the
762 ReqIdCollection collection.
763
764 send_request(ServerRef :: server_ref(), Request :: term()) ->
765 ReqId :: request_id()
766
767 Sends an asynchronous call request Request to the gen_server
768 process identified by ServerRef and returns a request identifier
769 ReqId. The return value ReqId shall later be used with re‐
770 ceive_response/2, wait_response/2, or check_response/2 to fetch
771 the actual result of the request. Besides passing the request
772 identifier directly to these functions, it can also be saved in
773 a request identifier collection using reqids_add/3. Such a col‐
774 lection of request identifiers can later be used in order to get
775 one response corresponding to a request in the collection by
776 passing the collection as argument to receive_response/3,
777 wait_response/3, or check_response/3. If you are about to save
778 the request identifier in a request identifier collection, you
779 may want to consider using send_request/4 instead.
780
781 The call gen_server:receive_response(gen_server:send_re‐
782 quest(ServerRef, Request), Timeout) can be seen as equivalent to
783 gen_server:call(ServerRef, Request, Timeout), ignoring the error
784 handling.
785
786 The gen_server process calls Module:handle_call/3 to handle the
787 request.
788
789 See the type server_ref() for the possible values for ServerRef.
790
791 Request is any term that is passed as the first argument to Mod‐
792 ule:handle_call/3.
793
794 send_request(ServerRef :: server_ref(),
795 Request :: term(),
796 Label :: term(),
797 ReqIdCollection :: request_id_collection()) ->
798 NewReqIdCollection :: request_id_collection()
799
800 Sends an asynchronous call request Request to the gen_server
801 process identified by ServerRef. The Label will be associated
802 with the request identifier of the operation and added to the
803 returned request identifier collection NewReqIdCollection. The
804 collection can later be used in order to get one response corre‐
805 sponding to a request in the collection by passing the collec‐
806 tion as argument to receive_response/3, wait_response/3, or,
807 check_response/3.
808
809 The same as calling gen_server:reqids_add(gen_server:send_re‐
810 quest(ServerRef, Request), Label, ReqIdCollection), but calling
811 send_request/4 is slightly more efficient.
812
813 start(Module :: module(),
814 Args :: term(),
815 Options :: [start_opt()]) ->
816 start_ret()
817
818 start(ServerName :: server_name(),
819 Module :: module(),
820 Args :: term(),
821 Options :: [start_opt()]) ->
822 start_ret()
823
824 Creates a standalone gen_server process, that is, a gen_server
825 process that is not part of a supervision tree and thus has no
826 supervisor.
827
828 Other than that see start_link/3,4.
829
830 start_link(Module :: module(),
831 Args :: term(),
832 Options :: [start_opt()]) ->
833 start_ret()
834
835 start_link(ServerName :: server_name(),
836 Module :: module(),
837 Args :: term(),
838 Options :: [start_opt()]) ->
839 start_ret()
840
841 Creates a gen_server process as part of a supervision tree. This
842 function is to be called, directly or indirectly, by the super‐
843 visor. For example, it ensures that the gen_server process is
844 linked to the supervisor.
845
846 The gen_server process calls Module:init/1 to initialize. To en‐
847 sure a synchronized startup procedure, start_link/3,4 does not
848 return until Module:init/1 has returned.
849
850 Using the argument ServerName creates a gen_server with a regis‐
851 tered name. See type server_name() for different name registra‐
852 tions. If no ServerName is provided, the gen_server process is
853 not registered.
854
855 Module is the name of the callback module.
856
857 Args is any term that is passed as the argument to Mod‐
858 ule:init/1.
859
860 See type start_opt() for Options when starting the gen_server
861 process.
862
863 See type start_ret() for a description this function's return
864 values.
865
866 start_monitor(Module :: module(),
867 Args :: term(),
868 Options :: [start_opt()]) ->
869 start_mon_ret()
870
871 start_monitor(ServerName :: server_name(),
872 Module :: module(),
873 Args :: term(),
874 Options :: [start_opt()]) ->
875 start_mon_ret()
876
877 Creates a standalone gen_server process, that is, a gen_server
878 process that is not part of a supervision tree (and thus has no
879 supervisor) and atomically sets up a monitor to the newly cre‐
880 ated server.
881
882 Other than that see start_link/3,4. Note that the return value
883 for a successful start differs in that it returns a monitor ref‐
884 erence. See type start_mon_ret().
885
886 If the start is not successful, the caller will be blocked until
887 the monitor's 'DOWN' message has been received and removed from
888 the message queue.
889
890 stop(ServerRef :: server_ref()) -> ok
891
892 stop(ServerRef :: server_ref(),
893 Reason :: term(),
894 Timeout :: timeout()) ->
895 ok
896
897 Orders the generic server specified by ServerRef to exit with
898 the specified Reason, default 'normal', and waits for it to ter‐
899 minate. The gen_server process calls Module:terminate/2 before
900 exiting.
901
902 The function returns ok if the server terminates with the ex‐
903 pected reason. Any other reason than normal, shutdown, or {shut‐
904 down,Term} causes an error report to be issued using logger(3).
905 An exit signal with the same reason is sent to linked processes
906 and ports.
907
908 Timeout is an integer that specifies how many milliseconds to
909 wait for the server to terminate, or the atom infinity to wait
910 indefinitely, which is the default. If the server has not termi‐
911 nated within the specified time, the call exits the calling
912 process with reason timeout.
913
914 If the process does not exist, the call exits the calling
915 process with reason noproc, and with reason {nodedown,Node} if
916 the connection fails to the remote Node where the server runs.
917
918 wait_response(ReqId, WaitTime) -> Result
919
920 Types:
921
922 ReqId = request_id()
923 WaitTime = response_timeout()
924 Response =
925 {reply, Reply :: term()} |
926 {error, {Reason :: term(), server_ref()}}
927 Result = Response | timeout
928
929 Wait for a response corresponding to the request identifier Re‐
930 qId. The request must have been made by send_request/2, and it
931 must have been made by the same process calling this function.
932
933 WaitTime specifies how long to wait for a reply. If no reply is
934 received within the specified time, the function returns timeout
935 and no cleanup is done, and thus the function can be invoked re‐
936 peatedly until a reply is returned.
937
938 The return value Reply is passed from the return value of Mod‐
939 ule:handle_call/3.
940
941 The function returns an error if the gen_server died before a
942 reply was sent.
943
944 The difference between receive_response/2 and wait_response/2 is
945 that receive_response/2 abandons the request at time-out so that
946 a potential future response is ignored, while wait_response/2
947 does not.
948
949 wait_response(ReqIdCollection, WaitTime, Delete) -> Result
950
951 Types:
952
953 ReqIdCollection = request_id_collection()
954 WaitTime = response_timeout()
955 Delete = boolean()
956 Response =
957 {reply, Reply :: term()} |
958 {error, {Reason :: term(), server_ref()}}
959 Result =
960 {Response,
961 Label :: term(),
962 NewReqIdCollection :: request_id_collection()} |
963 no_request | timeout
964
965 Wait for a response corresponding to a request identifier saved
966 in ReqIdCollection. All request identifiers of ReqIdCollection
967 must correspond to requests that have been made using send_re‐
968 quest/2 or send_request/4, and all request must have been made
969 by the process calling this function.
970
971 The Label in the response equals the Label associated with the
972 request identifier that the response corresponds to. The Label
973 of a request identifier is associated when saving the request id
974 in a request identifier collection, or when sending the request
975 using send_request/4.
976
977 Compared to wait_response/2, the returned result associated with
978 a specific request identifier or an exception associated with a
979 specific request identifier will be wrapped in a 3-tuple. The
980 first element of this tuple equals the value that would have
981 been produced by wait_response/2, the second element equals the
982 Label associated with the specific request identifier, and the
983 third element NewReqIdCollection is a possibly modified request
984 identifier collection.
985
986 If ReqIdCollection is empty, no_request will be returned. If no
987 response is received before the WaitTime timeout has triggered,
988 the atom timeout is returned. It is valid to continue waiting
989 for a response as many times as needed up until a response has
990 been received and completed by check_response(), receive_re‐
991 sponse(), or wait_response().
992
993 The difference between receive_response/3 and wait_response/3 is
994 that receive_response/3 abandons requests at timeout so that a
995 potential future responses are ignored, while wait_response/3
996 does not.
997
998 If Delete equals true, the association with Label will have been
999 deleted from ReqIdCollection in the resulting NewReqIdCollec‐
1000 tion. If Delete equals false, NewReqIdCollection will equal Re‐
1001 qIdCollection. Note that deleting an association is not for free
1002 and that a collection containing already handled requests can
1003 still be used by subsequent calls to wait_response/3, check_re‐
1004 sponse/3, and receive_response/3. However, without deleting han‐
1005 dled associations, the above calls will not be able to detect
1006 when there are no more outstanding requests to handle, so you
1007 will have to keep track of this some other way than relying on a
1008 no_request return. Note that if you pass a collection only con‐
1009 taining associations of already handled or abandoned requests to
1010 wait_response/3, it will always block until a timeout determined
1011 by WaitTime is triggered and then return no_reply.
1012
1014 The following functions are to be exported from a gen_server callback
1015 module.
1016
1018 Module:code_change(OldVsn, State, Extra) -> {ok, NewState} | {error,
1019 Reason}
1020
1021 Types:
1022
1023 OldVsn = Vsn | {down, Vsn}
1024 Vsn = term()
1025 State = NewState = term()
1026 Extra = term()
1027 Reason = term()
1028
1029 Note:
1030 This callback is optional, so callback modules need not export
1031 it. If a release upgrade/downgrade with Change={advanced,Extra}
1032 specified in the appup file is made when code_change/3 isn't im‐
1033 plemented the process will crash with an undef exit reason.
1034
1035
1036 This function is called by a gen_server process when it is to
1037 update its internal state during a release upgrade/downgrade,
1038 that is, when the instruction {update,Module,Change,...}, where
1039 Change={advanced,Extra}, is specifed in the appup file. For more
1040 information, see section Release Handling Instructions in OTP
1041 Design Principles.
1042
1043 For an upgrade, OldVsn is Vsn, and for a downgrade, OldVsn is
1044 {down,Vsn}. Vsn is defined by the vsn attribute(s) of the old
1045 version of the callback module Module. If no such attribute is
1046 defined, the version is the checksum of the Beam file.
1047
1048 State is the internal state of the gen_server process.
1049
1050 Extra is passed "as is" from the {advanced,Extra} part of the
1051 update instruction.
1052
1053 If successful, the function must return the updated internal
1054 state.
1055
1056 If the function returns {error,Reason}, the ongoing upgrade
1057 fails and rolls back to the old release.
1058
1059 Module:format_status(Status) -> NewStatus
1060
1061 Types:
1062
1063 Status = format_status()
1064 NewStatus = format_status()
1065
1066 Note:
1067 This callback is optional, so callback modules need not export
1068 it. The gen_server module provides a default implementation of
1069 this function that returns the callback module state.
1070
1071 If this callback is exported but fails, to hide possibly sensi‐
1072 tive data, the default function will instead return the fact
1073 that format_status/1 has crashed.
1074
1075
1076 This function is called by a gen_server process in the following
1077 situations:
1078
1079 * sys:get_status/1,2 is invoked to get the gen_server status.
1080
1081 * The gen_server process terminates abnormally and logs an er‐
1082 ror.
1083
1084 This callback is used to limit the status of the process re‐
1085 turned by sys:get_status/1,2 or sent to logger.
1086
1087 The callback gets a map Status describing the current status and
1088 shall return a map NewStatus with the same keys, but it may
1089 transform some values.
1090
1091 Two possible use cases for this callback is to remove sensitive
1092 information from the state to prevent it from being printed in
1093 log files, or to compact large irrelevant status items that
1094 would only clutter the logs.
1095
1096 Example:
1097
1098 format_status(Status) ->
1099 maps:map(
1100 fun(state,State) ->
1101 maps:remove(private_key, State);
1102 (message,{password, _Pass}) ->
1103 {password, removed};
1104 (_,Value) ->
1105 Value
1106 end, Status).
1107
1108
1109 Module:format_status(Opt, [PDict, State]) -> Status
1110
1111 Types:
1112
1113 Opt = normal | terminate
1114 PDict = [{Key, Value}]
1115 State = term()
1116 Status = term()
1117
1118 Warning:
1119 This callback is deprecated, in new code use format_status/1.
1120 If a format_status/1 callback exists, then this function will
1121 never be called.
1122
1123
1124 Note:
1125 This callback is optional, so callback modules need not export
1126 it. The gen_server module provides a default implementation of
1127 this function that returns the callback module state.
1128
1129
1130 This function is called by a gen_server process in the following
1131 situations:
1132
1133 * One of sys:get_status/1,2 is invoked to get the gen_server
1134 status. Opt is set to the atom normal.
1135
1136 * The gen_server process terminates abnormally and logs an er‐
1137 ror. Opt is set to the atom terminate.
1138
1139 This function is useful for changing the form and appearance of
1140 the gen_server status for these cases. A callback module wishing
1141 to change the sys:get_status/1,2 return value, as well as how
1142 its status appears in termination error logs, exports an in‐
1143 stance of format_status/2 that returns a term describing the
1144 current status of the gen_server process.
1145
1146 PDict is the current value of the process dictionary of the
1147 gen_server process..
1148
1149 State is the internal state of the gen_server process.
1150
1151 The function is to return Status, a term that changes the de‐
1152 tails of the current state and status of the gen_server process.
1153 There are no restrictions on the form Status can take, but for
1154 the sys:get_status/1,2 case (when Opt is normal), the recom‐
1155 mended form for the Status value is [{data, [{"State", Term}]}],
1156 where Term provides relevant details of the gen_server state.
1157 Following this recommendation is not required, but it makes the
1158 callback module status consistent with the rest of the
1159 sys:get_status/1,2 return value.
1160
1161 One use for this function is to return compact alternative state
1162 representations to avoid that large state terms are printed in
1163 log files.
1164
1165 Module:handle_call(Request, From, State) -> Result
1166
1167 Types:
1168
1169 Request = term()
1170 From = from()
1171 State = term()
1172 Result = {reply,Reply,NewState}
1173 | {reply,Reply,NewState,Timeout}
1174 | {reply,Reply,NewState,hibernate}
1175 | {reply,Reply,NewState,{continue,Continue}}
1176 | {noreply,NewState}
1177 | {noreply,NewState,Timeout}
1178 | {noreply,NewState,hibernate}
1179 | {noreply,NewState,{continue,Continue}}
1180 | {stop,Reason,Reply,NewState}
1181 | {stop,Reason,NewState}
1182 Reply = term()
1183 NewState = term()
1184 Timeout = timeout()
1185 Continue = term()
1186 Reason = term()
1187
1188 Whenever a gen_server process receives a request sent using
1189 call/2,3 or multi_call/2,3,4, this function is called to handle
1190 the request.
1191
1192 State is the internal state of the gen_server process, and New‐
1193 State a possibly updated one.
1194
1195 Request is passed from the same argument provided to call or
1196 multi_call.
1197
1198 The return value Result is interpreted as follows:
1199
1200 {reply,Reply,NewState}
1201 {reply,Reply,NewState,_}: The Reply value is sent back to
1202 the client request and there becomes its return value.
1203
1204 The gen_server process continues executing with the possibly
1205 updated internal state NewState.
1206
1207 {noreply,NewState}
1208 {noreply,NewState,_}: The gen_server process continues exe‐
1209 cuting with the possibly updated internal state NewState.
1210
1211 A reply to the client request has to be created by calling
1212 reply(From, Reply), either in this or in a later callback.
1213
1214 {reply,_,_,Timeout}
1215 {noreply,_,Timeout}: If an integer Timeout is provided, a
1216 time-out occurs unless a request or a message is received
1217 within that many milliseconds. A time-out is represented by
1218 the atom timeout to be handled by the Module:handle_info/2
1219 callback function. Timeout =:= infinity can be used to wait
1220 indefinitely, which is the same as returning a value without
1221 a Timeout member.
1222
1223 {reply,_,_,hibernate}
1224 {noreply,_,hibernate}: The process goes into hibernation
1225 waiting for the next message to arrive (by calling
1226 proc_lib:hibernate/3).
1227
1228 {reply,_,_,{continue,Continue}}
1229 {noreply,_,{continue,Continue}}: The process will execute
1230 the Module:handle_continue/2 callback function, with Con‐
1231 tinue as the first argument.
1232
1233 {stop,Reason,NewState}
1234 {stop,Reason,Reply,NewState}: The gen_server process will
1235 call Module:terminate(Reason,NewState) and then terminate.
1236
1237 {stop,_,Reply,_} will create a reply to the client request
1238 just as {reply,Reply,...} while {stop,_,_} will not, so just
1239 as for {noreply,NewState,...} a reply has to be created by
1240 calling reply(From, Reply) before returning {stop,_,_}.
1241
1242 Module:handle_cast(Request, State) -> Result
1243
1244 Types:
1245
1246 Request = term()
1247 State = term()
1248 Result = {noreply,NewState}
1249 | {noreply,NewState,Timeout}
1250 | {noreply,NewState,hibernate}
1251 | {noreply,NewState,{continue,Continue}}
1252 | {stop,Reason,NewState}
1253 NewState = term()
1254 Timeout = timeout()
1255 Continue = term()
1256 Reason = term()
1257
1258 Whenever a gen_server process receives a request sent using
1259 cast/2 or abcast/2,3, this function is called to handle the re‐
1260 quest.
1261
1262 For a description of the arguments and possible return values,
1263 see Module:handle_call/3.
1264
1265 Module:handle_continue(Continue, State) -> Result
1266
1267 Types:
1268
1269 Continue = term()
1270 State = term()
1271 Result = {noreply,NewState}
1272 | {noreply,NewState,Timeout}
1273 | {noreply,NewState,hibernate}
1274 | {noreply,NewState,{continue,Continue}}
1275 | {stop,Reason,NewState}
1276 NewState = term()
1277 Timeout = timeout()
1278 Continue = term()
1279 Reason = normal | term()
1280
1281 Note:
1282 This callback is optional, so callback modules need to export it
1283 only if they return one of the tuples containing {continue,Con‐
1284 tinue} from another callback. If such a {continue,_} tuple is
1285 used and the callback is not implemented, the process will exit
1286 with undef error.
1287
1288
1289 This function is called by a gen_server process whenever a pre‐
1290 vious callback returns one of the tuples containing {continue,
1291 Continue}. handle_continue/2 is invoked immediately after the
1292 previous callback, which makes it useful for performing work af‐
1293 ter initialization or for splitting the work in a callback in
1294 multiple steps, updating the process state along the way.
1295
1296 For a description of the other arguments and possible return
1297 values, see Module:handle_call/3.
1298
1299 Module:handle_info(Info, State) -> Result
1300
1301 Types:
1302
1303 Info = timeout | term()
1304 State = term()
1305 Result = {noreply,NewState}
1306 | {noreply,NewState,Timeout}
1307 | {noreply,NewState,hibernate}
1308 | {noreply,NewState,{continue,Continue}}
1309 | {stop,Reason,NewState}
1310 NewState = term()
1311 Timeout = timeout()
1312 Reason = normal | term()
1313
1314 Note:
1315 This callback is optional, so callback modules need not export
1316 it. The gen_server module provides a default implementation of
1317 this function that logs about the unexpected Info message, drops
1318 it and returns {noreply, State}.
1319
1320
1321 This function is called by a gen_server process when a time-out
1322 occurs or when it receives any other message than a synchronous
1323 or asynchronous request (or a system message).
1324
1325 Info is either the atom timeout, if a time-out has occurred, or
1326 the received message.
1327
1328 For a description of the other arguments and possible return
1329 values, see Module:handle_call/3.
1330
1331 Module:init(Args) -> Result
1332
1333 Types:
1334
1335 Args = term()
1336 Result = {ok,State}
1337 | {ok,State,Timeout}
1338 | {ok,State,hibernate}
1339 | {ok,State,{continue,Continue}}
1340 | {stop,Reason}
1341 | ignore
1342 State = term()
1343 Timeout = timeout()
1344 Reason = term()
1345
1346 Whenever a gen_server process is started using start/3,4,
1347 start_monitor/3,4, or start_link/3,4, this function is called by
1348 the new process to initialize.
1349
1350 Args is the Args argument provided to the start function.
1351
1352 The return value Result is interpreted as follows:
1353
1354 {ok,State}
1355 {ok,State,_}: Initialization was succesful and State is the
1356 internal state of the gen_server process.
1357
1358 {ok,_,Timeout}
1359 {ok,_,hibernate}
1360 {ok,_,{continue,Continue}}: See the corresponding return
1361 values from Module:handle_call/3 for a description of this
1362 tuple member.
1363
1364 {stop,Reason}
1365 ignore: Initialization failed. An exit signal with this Rea‐
1366 son (or with reason normal if ignore is returned) is sent to
1367 linked processes and ports, notably to the process starting
1368 the gen_server when start_link/3,4 is used.
1369
1370 Module:terminate(Reason, State)
1371
1372 Types:
1373
1374 Reason = normal | shutdown | {shutdown,term()} | term()
1375 State = term()
1376
1377 Note:
1378 This callback is optional, so callback modules need not export
1379 it. The gen_server module provides a default implementation
1380 without cleanup.
1381
1382
1383 This function is called by a gen_server process when it is about
1384 to terminate. It is to be the opposite of Module:init/1 and do
1385 any necessary cleaning up. When it returns, the gen_server
1386 process terminates with Reason. The return value is ignored.
1387
1388 Reason is a term denoting the stop reason and State is the in‐
1389 ternal state of the gen_server process.
1390
1391 Reason depends on why the gen_server process is terminating. If
1392 it is because another callback function has returned a stop tu‐
1393 ple {stop,..}, Reason has the value specified in that tuple. If
1394 it is because of a failure, Reason is the error reason.
1395
1396 If the gen_server process is part of a supervision tree and is
1397 ordered by its supervisor to terminate, this function is called
1398 with Reason=shutdown if the following conditions apply:
1399
1400 * The gen_server process has been set to trap exit signals.
1401
1402 * The shutdown strategy as defined in the child specification
1403 of the supervisor is an integer time-out value, not bru‐
1404 tal_kill.
1405
1406 Even if the gen_server process is not part of a supervision
1407 tree, this function is called if it receives an 'EXIT' message
1408 from its parent. Reason is the same as in the 'EXIT' message.
1409
1410 Otherwise, the gen_server process terminates immediately.
1411
1412 Notice that for any other reason than normal, shutdown, or
1413 {shutdown,Term}, see stop/3, the gen_server process is assumed
1414 to terminate because of an error, and an error report is issued
1415 using logger(3).
1416
1417 When the gen_server process exits, an exit signal with the same
1418 reason is sent to linked processes and ports.
1419
1421 gen_event(3), gen_statem(3), proc_lib(3), supervisor(3), sys(3)
1422
1423
1424
1425Ericsson AB stdlib 4.3.1.3 gen_server(3)