-
Notifications
You must be signed in to change notification settings - Fork 11
Architecture
Hans Christian v. Stockhausen edited this page Jan 11, 2014
·
10 revisions
-
ed_sup
is the root supervisor -
ed_udp_server
accepts incoming queries via UDP -
ed_udp_handler_sup
spawns child worker processes to answer queries - 0.64.0 and 0.67.0 are examples of
ed_udp_handler_server
instances concurrently working on two DNS request -
ed_zone_sup
is responsible for supervising the zone subsystem -
ed_zone_registry_server
contains information about all zones registered with the server -
ed_zone_data_sup
supervises the actual zone servers - 0.43.0 is an example of a
ed_zone_data_server
(here the sample root zone from the end-to-end tests).
- A DNS query is received via UDP and accepted by
ed_udp_server
-
ed_udp_server
asksed_udp_handler_sup
to spawn a workered_udp_handler_server
to process the request -
ed_udp_handler_server
decodes the request and callsed_query_resolver
to answer the query -
ed_query_resolver
asksed_zone_registry_server
for the zone associated with the request - if a zone exists
ed_query_resolver
requests a copy of the zone data from the associateded_zone_data_server
-
ed_query_resolver
answers the query from the zone data, optionally making recursive calls to fetch additional details -
ed_udp_handler_server
encodes the answer data and sends it to the original requester via UDP.
This is my first "real" OTP application, so I am not claiming that this architecture is particularly suitable or finalised for that matter. Comments are certainly most welcome.
If you are new to OTP, please take a look at my tutorial here: http://blog.bot.co.za/en/article/349/an-erlang-otp-tutorial-for-beginners. It's become quite popular and I had to constantly refer to it as I built up the app.