xgeek116

xgeek116

Elixir Phoenix use cases ? Why start using it?

Hello,

We have been using Elixir and Phoneix for creating REST APIs for a few months now.

But I can’t see the benefits of this switch (from nodejs / Nestjs) in terms of performance, speed etc ?

So :

  1. Can you please tell me why are you using it ? (did you switch from another technology ?)
  2. What are the major benefits ? To explore them
  3. Is there a specific domain to used it in ? (AI, mailing etc.) ?
  4. In terms of deployment, scaling etc. Do you find it efficient ?

Many thanks

Most Liked

derpycoder

derpycoder

Take it from someone who has been in the deep muddy water of JavaScript development, both in frontend and backend, Elixir & Phoenix are better duo than anything I came across.

Let me answer each of your question, one by one.

  1. I switched form Node.js. I used it along with Socket IO to make presence tracking app and distributed locking.

    • The Node.js environment is riddled with memory leak. (The only Node.js program without memory leak is a Hello World program) (Elixir & Phoenix app have per process garbage collection, so memory won’t bloat for entire application)
    • It is opaque, i.e. You can’t inspect what’s happening inside in production. (You can with Elixir & Phoenix, you can even terminate a single process that might be causing trouble, without crashing the whole server!)
    • It’s not multi threaded, so you have to run multiple instances using PM2 or Docker. (Elixir & Phoenix have that natively)
    • Multiple Node.js instances don’t communicate with each other, instead you have to host a separate Redis instance, and use its PubSub mechanism or use some other message queue. (Elixir & Phoenix run on top of BEAM virtual machine, which has those primitives built in!!)
    • JavaScript is an unreliable mess, which you will replace with TypeScript anyway, which is just a fake type checker. (With Elixir, you won’t need Type checking whatsoever, because of the first class testing features and type checkers don’t prevent all bugs anyways, just type bugs)
  2. a. Major benefits:

    • The Phoenix Framework has Live View, which is like next level compared to the terrible Single Page Application. (I can fill a page about how it’s a mind-blowing piece of tech if you want to know)
    • Elixir has LiveBooks, where you can learn, make Machine Learning models, even create business intelligence tools, because it can connect directly to all other Elixir Phoenix nodes with ease.
    • Elixir has Pipelining, i.e. |>, for better readable and maintainable code.
     def on_mount(:only_admin, _params, session, socket) do
      {:cont, socket}
        |> assign_user(session)
        |> verify_user()
        |> verify_lock()
        |> verify_email()
        |> verify_role(~w(super_admin admin)a)
        |> subscribe_user()
     end
  1. b. Some other benefits:
    • The paradigm for coding is functional, and not OOP, so you won’t drown in the rabbit hole of Design Patterns.
    • Elixir has pattern matching, which eases error handling and reduces lines of code we have to write:
   def env(atom) when is_atom(atom), do: Application.get_env(:derpy_coder, :environment) == to_string(atom)
   def env(str) when is_binary(str), do: Application.get_env(:derpy_coder, :environment) == str
   def env(list) when is_list(list), do: Application.get_env(:derpy_coder, :environment) in list
  1. Domains:

    • The language and the BEAM virtual machine lend themselves to soft real time application really well.
    • Better & Modern web applications. See: Phoenix Framework
    • Soft Realtime, collaborative applications. See: Phoenix LiveView
    • Internet of Things using Nerves project. See: Nerves Project
    • Mobile Application. See: Phoenix LiveView Native
    • Desktop Application. See: Elixir Desktop
    • Artificial Intelligence training and serving. Elixir Nx, Axon
    • Here’s a list of Awesome Collections: Awesome Elixir, Awesome Phoenix LiveView
  2. Deployment

    • It takes up less memory, compared to Java or Node based apps.
    • It uses less server resources and just one instance deployed onto a server can utilise all cores of that machine. So you don’t have to use a tool like PM2 to run multiple instances like in case of Nodejs.
    • There was a blog post about how a company using Ruby, with 80 servers came down to only 5 after switching to Elixir.
    • Discord uses Elixir, and WhatsApp used to use it.
    • Current build process can output single binary, so you can deploy it in a old school way like I prefer, or you can Dockerize it to run it inside Kubernetes, or throw the binary at Hashicorp Nomad for orchestrating standalone binaries.
    • Separately deployed nodes can communicate with each other, without using ETCD or Redis or Kafka separately, it’s built in.
    • With fly .io, you can deploy your server to the edge, as if it’s a CDN, except your code is running closer to the user, and you won’t have to deal with any extra tech layer. See: LiveBeats.

I have been falling down the rabbit hole of Front End frameworks, for what feels like forever. It was like a never ending Distro hopping. Everything that comes out in front end space solves one or the other problem, but leaves out a gaping hole behind them.

For instance, React, solved some problem, but left open the server side rendering. So Next.js came along.

REST api felt unwieldy, so GraphQL came along, now state needs to be maintained in both backend and front end. So you end up with business logic scattered across both places.

Routing story gets bad or has several fragmented implementation. State management remains a mess.

Then someone from business comes along and asks you to make some of it real time, and now you are caught in the JavaScript web hell.

The 2 ton heavy npm package gets replaced by pnpm, which breaks everything. You can’t reliably run a Node.js project after a hiatus.

Webpack bundler keeps getting slower, so you move to something else, which has some other headache of its own.

Believe me when I say, you are saving yourself a ton of headache and sparing yourself from paying technical debt by moving to Elixir/Phoenix.

It saved me from yak shaving me life away.


See the following talks to get a visual explanation of all the things I pointed out:

P.S. I would have put a lot more links, but new users are not allowed to add more than 5 links. (I started learning Elixir & Phoenix 3 or 4 months back and joined the forum today :sweat_smile:)

Sebb

Sebb

  so_survery_get(:techs, :webfw, 2022) #=> %{
    dotnet: ["Blazor", "ASP.NET Core", "ASP.NET"],
    elixir: ["Phoenix"],
    js: ["React.js", "Node.js", "Vue.js", "Next.js", "Svelte", "Angular",
     "Express", "Nuxt.js", "Angular.js", "jQuery", "Deno", "Gatsby", "Fastify"],
    php: ["Laravel", "Symfony"],
    python: ["Django", "Flask", "FastAPI"],
    ruby: ["Ruby on Rails"],
    scala: ["Play Framework"]
  }
  |> filter(fn {lang, _} -> not microsoft?(lang) end) #=> [
    elixir: ["Phoenix"],
    js: ["React.js", "Node.js", "Vue.js", "Next.js", "Svelte", "Angular",
     "Express", "Nuxt.js", "Angular.js", "jQuery", "Deno", "Gatsby", "Fastify"],
    php: ["Laravel", "Symfony"],
    python: ["Django", "Flask", "FastAPI"],
    ruby: ["Ruby on Rails"],
    scala: ["Play Framework"]
  ]
  |> filter(fn {lang, _} -> functional?(lang) end) #=> [
    elixir: ["Phoenix"],
    scala: ["Play Framework"]
  ]
  |> filter(fn {lang, _} -> can_normal_people_understand?(lang) end) #=> [
    elixir: ["Phoenix"]
  ]
dimitarvp

dimitarvp

Elixir and Phoenix are good for:

  • Any web app with server-side rendering.
  • Any web app with client-side rendering (you can use partial hydration with JSON API server that Phoenix can also do). Phoenix integrates well with every frontend framework but you’ll have to do some plumbing with webpack, rollup, esbuild and others.
  • Any API server (REST and GraphQL through HTTP[S] are best supported though we have functional libraries for gRPC as well).
  • Any long-term persistent servers – general background workers, crawlers, data collectors and aggregators, and many others.
  • Any app backend that requires persistent bi-directional connections to its clients. Phoenix’s WebSockets support is very good.
  • And lately some ML is on the rise though I’m not sure how well-supported it is at the moment.

You can use Elixir for likely no less than 80% of all possible projects out there.

It’s at least as fast as the hot paths in JS, so it’s pretty fast. We’re talking average 15-35 milliseconds per request in a web app even when DB is involved.

As others mentioned it’s no C/C++ or Rust but (a) you can use these in your super hot paths if you want, and (b) most apps don’t need such a beastly speed so you’re 98% likely to get away with pure Elixir.

Elixir is a secret weapon. Many people can’t see that because they want to arrive at an already super popular ecosystem. Rest assured however, companies using Elixir are very happy with their choice, and they can get away with hiring less devs, too.

12
Post #5

Where Next?

Popular in Questions Top

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
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
lucidguppy
I have a super simple question about elixir - how would I take a file like this foo bar baz and output a new file that enumerates th...
New
Qqwy
Original source of discussion: This topic on the Pragmatic Programmers’ Functional Web Development with Elixir, OTP, and Phoenix forum. ...
New
nobody
Hi! In PHP: $_SERVER[‘SERVER_ADDR’] - in Elixir? Searched the docs for ip address and the web, no good results. Thanks!
New
rms.mrcs
Hi, I need to transform a list of numbers into a map where the keys are the indexes and the values are the original values of the list. ...
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
komlanvi
Hi everyone, I was playing with phoenix liveView but I run into an issue. I have a form and want to validate each input text when the te...
New
shijith.k
I am trying to start a new phoenix project with elixir 1.9, but mix phx.new does not work. It says that ** (Mix) The task "phx.new" could...
New
PeterCarter
There are pre-rolled solutions for other frameworks that do work. However, Phoenix does not seem to have these. Have people had good expe...
New

Other popular topics Top

sen
Hi All, I set a environment variables in dev.exs , like below code. when i start server, how can i set the ${enable} value? thanks. d...
New
TunkShif
This post is an instruction guide to help you setup your Neovim for Elixir development from scratch. It includes general information on h...
274 41539 114
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
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
JorisKok
I have a server on AWS, and was running a load test using artillery. When looking at the Phoenix dashboard I see the Ports going to 100% ...
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
Qqwy
Original source of discussion: This topic on the Pragmatic Programmers’ Functional Web Development with Elixir, OTP, and Phoenix forum. ...
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
Brian
What is the proper way to load a module from a file in to IEX? In the python world, doing something like this pretty standard: from ....
New
joaquinalcerro
Hi there, I am working with Ecto-Postgresql and I need to call all of the records from a specific table but the table has 40,000 records...
New

We're in Beta

About us Mission Statement