pmjoe

pmjoe

Elixir suitable for building a API gateway?

Is Elixir suitable for building a API gateway like Kong? The main driver is the latency, throughput can be archived with more machines, but latency don’t.

The server should have a very low latency, be stable and support plugins. I’m very inclined to use Go because it’s fast and easy. But i don’t know if i can have the same stability guarantees from Elixir.

Most Liked

NobbZ

NobbZ

Go gives you nothing near to the stability guarantees that a properly built elixir application gives you. Supervision trees are totally rocking.

I can’t say anything about response time comparison in both, since those really depends on how well the application is crafted, not that much the language.

I can tell though that the go runtime stops the world for garbage collection, while the BEAM does garbage collection on a per process base.

gon782

gon782

I would add Inspectability to that list. The amount of tooling you have out of the box to inspect a single process is far beyond what Go can give you. For any one of those multiplayer game rooms, chat rooms, what have you, you can open up observer and see exactly what the internal state is, in order to debug it (or just for shits and giggles).

Go doesn’t have a way to refer to single threads via a general identifier, much less a non-intrusive (or any) way to see what the internal state of a thread is. To inspect the state of something, you’ll have to actually make that whole business yourself, which will just be another point of failure for you. observer will tell you exactly what’s there and how it relates to the other processes in the process tree.

Qqwy

Qqwy

TypeCheck Core Team

An Elixir application will probably respond a lot better than a Go application when put under increased load.

Of course, what exactly happens in real life is something you can only find out by extensive benchmarking. I find the claim ‘in practice, Go has better latency’ very sketchy. It’s a nice benchmark that you linked to, but in real life, an application also performs some work besides immediately returning a response to a request. (Which this benchmark does not do)

That said, Elixir is definitely better than Go when talking about:

  • Stability. Even if Go becomes pre-emptive, it can by no means claim the same fault-tolerancy as Elixir does unless it will also start to work with the Actor Model. Also, Distributed Erlang (and the newer Swarm and Partisan) are absolutely amazing tools to manage multi-server scalability and fault tolerancy.
  • Hot-code reloading. AFAIK, Go is compiled and does not allow you to do this. Especially when you might want to include streaming features in your API, this is the difference between all in-progress API requests being broken or being able to continue along.
  • Stateful APIs. The ability to spin up GenServers that manage every need fo your user(s) in a specific context are conceptually really easy to understand, and are a lot faster than writing everything to a database in-between requests. This makes Elixir really well-suited for e.g. multiplayer games, communication platforms, etc.

Where Next?

Popular in Questions Top

siddhant3030
Hi, I have to write a raw query for one of my project. But till now I have used ecto queries and don’t have much experience writing raw ...
New
Darmani72
If I have a post route which an argument: post /my_post_route/:my_param1, MyController.my_post_handler How would get the post params ...
New
Fl4m3Ph03n1x
About me? ( if you have nothing better to do than reading about some random guy in the internet :stuck_out_tongue: ) Hello all, this is ...
New
New
pmjoe
I have a relationship of love and hate with Elixir. Lots of things are just absolutely right, but there are some things that are kind of ...
New
vonH
When I run the Plug and I recompile I wind up having to use Ctrl C to quit iex and start again. Witht the help of rlwrap I can use the cu...
New
Lily
In templates/appointment/index.html.eex: <%= for appointment <- @appointments do %> <tr> <td><%= appoi...
New
ycv005
I have followed this StackOverflow post to install the specific version of Erlang. And When I am running mix ecto.setup then getting fol...
New
bsollish-terakeet
Credo is smart enough to check for (something like) this: assert length(the_list) == 0 with this response: Checking if an enum is empt...
New
sergio_101
I am VERY much an elixir newbie. I have taken one elixir course and one phoenix course on Udemy. During that course, I saw the instructor...
New

Other popular topics Top

greenz1
I have a phoenix application from which a user can download multiple(5-6) files of size 1MB. I couldn’t find anything related to sending ...
New
electic
Hi, I am new to Elixir. I am trying to use the DateTime component to insert a date into MySQL however the there seems to be no way to fo...
New
jononomo
I am trying to figure out how Mix knows whether the environment is test, dev, or prod -- where is this set? Thanks.
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
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
chrismccord
This release brings a number of exciting features, including integration with the new Phoenix LiveDashboard and Phoenix LiveView. There h...
New
Qqwy
Original source of discussion: This topic on the Pragmatic Programmers' Functional Web Development with Elixir, OTP, and Phoenix forum. ...
New
AstonJ
Please see the new poll here: Which code editor or IDE do you use? (Poll) (2022 Edition) It’s been a while since we first asked this, I...
208 31107 143
New
romenigld
I am trying to run a deploy with docker and I successfully runned with this command: docker build -t romenigld/blog-prod . but when I t...
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