mpodkolzin

mpodkolzin

Elixir/Erlang message routing

Hi,

I’m new to the language, so sorry in advance if quesion if stupid. I have some production experience with Akka framework and it has out of the box quite a few routing strategies (e.g Round robin, consistent hashing, smalles mailbox etc) Does elixir/erlang offer something similar? Are there perhaps any known patterns/best practices of how to put together various process hierarchies and pass messages between them?

Thanks!
Max

Most Liked Responses

OvermindDL1

OvermindDL1

The EVM routes differently based on a few factors. Based on my knowledge:

  1. A message sent immediately activates the receiving process if no contention.
  2. A message is queued in its mailbox if the process is busy otherwise.
  3. If the process is ‘too’ busy then not only is the message queued but the sending process is also ‘slept’ for some-odd reductions to act as a throttle mechanism, this time increases the more busy the receiving process is.
  4. Or if the message is going over the network it is just blasted out and ‘forgotten’.

These are not things you should really think about 99% of the time though. If you want a specific routing strategy then you can add another actor/process between the senders/receivers to do that instead, but that is rarely ever done except in very specific situations.

The best pattern is of course just OTP itself. :slight_smile:

mpodkolzin

mpodkolzin

Thanks for clarification! OTP is fantastic, just wanted to have some more control on message passing. This makes implementing things like custom load balancing easier. I guess that might be good idea for 3-rd party routing library. Probably I will try to port something that they have in Akka.

Thanks again

OvermindDL1

OvermindDL1

More libraries are always useful!

The only real in-use routing libraries I’ve seen just implement priority messages, so higher priority ones are handled before lower priority, regardless of arrival time. It is pretty easy to implement that one, the others you mentioned would not be hard either. :slight_smile:

Where Next?

Popular in Questions Top

aadeshere1
I have a another noob question about loop. Since elixir is immutable, while loop is not directly possible. total = 10 while total != 0 ...
New
sergio
In Ruby, I can go: User.find_by(email: "foobar@email.com").update(email: "hello@email.com") How can I do something similar in Elixir? ...
New
marius95
Hello everyone, I try to use an Javascript Event Handler in my root.html.leex file. Therefore I created a function in the app.js file: ...
New
mcarvalho
What is the difference between System.get_env and Application.get_env? For example, what are best practices to use one versus another.
New
jerry
Good day to you all. I have been struggling to get a query involving like and ilike to work. Can anyone assist me on this, please? pro...
New
LegitStack
I’m trying to make a websocket server in Phoenix or raw Elixir. I heard about gun, I think I could use cowboy, but since I’m not that sma...
New
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
New
alice
Hey, Just curious what are the main benefits of Elixir compared to Clojure? When is Elixir more useful than Clojure and vice versa? Th...
New
freewebwithme
Using vs code and installed ElixirLS: support and debugger. And I got an error popped up on start up says Failed to run ‘elixir’ comma...
New
Qqwy
Original source of discussion: This topic on the Pragmatic Programmers’ Functional Web Development with Elixir, OTP, and Phoenix forum. ...
New

Other popular topics Top

aadeshere1
I have a another noob question about loop. Since elixir is immutable, while loop is not directly possible. total = 10 while total != 0 ...
New
marius95
Hello everyone, I try to use an Javascript Event Handler in my root.html.leex file. Therefore I created a function in the app.js file: ...
New
Nvim
Anybody knows a comprehensive comparison of Django and Phoenix, thanks for the help. Where are they similar? Where do they differ the m...
New
fireproofsocks
Forgive me if this is obvious, but how does one delete a database record WITHOUT selecting it first? Ecto.Repo — Ecto v3.14.0 has exampl...
New
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
New
SoCreat
i’m a new one to elixir which editor can i use vs code? or atom? Thanks! :smiley:
New
RisingFromAshes
I’ve read in another post that it may be possible with a router helper - but I couldn’t find an appropriate one, and tbh, I’m still just ...
New
jason.o
In the code below, if the create action is not set to accept “extra_key” as an input, it errors out with a message shown above. Is there ...
New
dblack
I’ve got an issue with an app and I’ve no idea of how to troubleshoot it. I’m hoping someone here might have seen something similar. I p...
New
svb
Hi! Currently I want to submit a form by pressing the Enter key. However, since my input field is of type “textarea” this is just adds a...
New

We're in Beta

About us Mission Statement