Drinking the Elixir
14 November 2015
Elixir is a new and exciting open source programming language with scope to become the next big language for the web. I’m here to evangelise and spread the word about Elixir.
Erlang, the secret sauce
Elixir is built on top of the mature Erlang virtual machine and inherits its best features. Erlang (itself a programming language) was originally developed in the 1980s by Ericsson for use in their telephone switches and has a history of stability in large scale distributed systems. The Erlang platform is widely considered to be awesome, yet it has never gained mainstream adoption. Despite this, the platform has a number of desirable properties:
- Concurrent – Erlang has an actor model for concurrency where lightweight processes run in parallel and communicate via message passing. This simplifies the development of concurrent applications, reduces errors and enables extreme scalability.
- Distributed – Processes can communicate easily across a distributed network of machines in the same way as local processes.
- Fault-tolerant – Errors will happen in any system. Erlang embraces this idea and enables developers to build systems that automatically recover from faults and self-heal.
- Hot code deploy – Erlang allows deployment of code into a running production system, without any downtime.
- Battle proven – Erlang has proven to scale. A notable example is WhatsApp, the popular instant messaging service able to handle millions of connections from a single server.
Introducing Elixir
Why use Elixir when Erlang is so awesome? Erlang is weird. It has a strange syntax, a steep learning curve and dated tooling. Elixir solves this by building on the best of Erlang. It combines Erlang features like pattern matching and immutability with aspects of other languages:
- A natural syntax inspired by Ruby.
- Lazy evaluation from Haskell.
- Protocols, macros and pipelines from Clojure.
Elixir does all of this really well too:
- Functional programming – A functional style of programming promotes the development of concise, reusable and maintainable code. Combined with immutable data structures, the developer can more easily reason about the code.
- Extensibility – Most of Elixir is written in itself using the metaprogramming capability. This enables anyone to extend the language natively by building DSLs and macros.
- Modern tooling – A modern build tool, package manager, doc generator and testing framework all come with Elixir. The community continues to innovate here building awesome tools and libraries.
- Full compatibility with Erlang – Elixir projects can leverage the large ecosystem of existing Erlang libraries and invoke their functions with no runtime cost.
The result of all of this is a truly modern, practical and performant language on a platform capable of supporting even the most ambitious projects.
Phoenix rises
A perfect fit for Elixir is web development. Phoenix is an amazing Elixir framework for building modern, real-time web applications. It gives developers a lightweight foundation to build interactive applications with massive scalability.
Developers build using the familiar MVC pattern seen in frameworks like Rails and Django. But unlike these, Phoenix is built for speed. Response times are measured in the microsecond. With Phoenix, you don’t have to sacrifice performance for the sake of productivity. You can have your cake and eat it.
Phoenix is designed with real-time applications in mind, taking full advantage of Elixir’s concurrency model. Technologies like WebSockets are supported out of the box, opening the door for a new type of web application.
With the help of Phoenix, Elixir is set to be the go-to language for the web and poised to kickstart a real-time web revolution.