aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/guide/embedded.asciidoc
blob: 55c018b13fbcf53f9d5525f9834fa5569e8056d1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
== Embedded mode

Embedded mode allows you to insert Ranch listeners directly
in your supervision tree. This allows for greater fault tolerance
control by permitting the shutdown of a listener due to the
failure of another part of the application and vice versa.

=== Embedding

To embed Ranch in your application you can simply add the child specs
to your supervision tree. This can all be done in the `init/1` function
of one of your application supervisors.

Ranch requires at the minimum two kinds of child specs for embedding.
First, you need to add `ranch_sup` to your supervision tree, only once,
regardless of the number of listeners you will use. Then you need to
add the child specs for each listener.

Ranch has a convenience function for getting the listeners child specs
called `ranch:child_spec/5`, that works like `ranch:start_listener/5`,
except that it doesn't start anything, it only returns child specs.

As for `ranch_sup`, the child spec is simple enough to not require a
convenience function.

The following example adds both `ranch_sup` and one listener to another
application's supervision tree.

.Embed Ranch directly in your supervision tree

[source,erlang]
----
init([]) ->
	RanchSupSpec = {ranch_sup, {ranch_sup, start_link, []},
		permanent, 5000, supervisor, [ranch_sup]},
	ListenerSpec = ranch:child_spec(echo, 100,
		ranch_tcp, [{port, 5555}],
		echo_protocol, []
	),
	{ok, {{one_for_one, 10, 10}, [RanchSupSpec, ListenerSpec]}}.
----

Remember, you can add as many listener child specs as needed, but only
one `ranch_sup` spec!

It is recommended that your architecture makes sure that all listeners
are restarted if `ranch_sup` fails. See the Ranch internals chapter for
more details on how Ranch does it.