Frequently Asked Questions about Erlang

3 Obtaining Erlang/OTP and books/articles about it

3.1  Where can I get Erlang/OTP?

Open Source Erlang/OTP can be downloaded from the open source Erlang site. The site provides full source code as well as binaries for Windows machines. This is probably the best place to go to make sure you're getting the latest version.

The Debian Distribution of GNU/Linux, and derivatives such as Ubuntu, includes various versions Erlang in different releases, under interpreters.

Precompiled ready-to-go installers for a variety of platforms are available from the Comprehensive Erlang Archive Network (CEAN). CEAN also provides dozens of Erlang applications.

For the BSDs, the 'ports' collection has up to date versions of Erlang.

Users within Ericsson can use Ericsson's internally supported version of Erlang from

3.2  What's the current version of (Open Source) Erlang?

Erlang/OTP 17.0 was released in April 2014.

Prior to 17.0, Erlang used a slightly unusual version numbering scheme, e.g. the previous version was called R16B-3.

Major releases typically come somewhere between 12 and 18 months apart.

Components of Erlang have their own version numbers, for instance the virtual machine in 17.0 has version 6.0.

3.3  Which licence is Open Source Erlang shipped with?

The Open Source Erlang Licence is essentially the Mozilla (Netscape) Public Licence with a few modifications to make it compatible with Swedish law.

As far as I understand, this means you can obtain Erlang for free, use it to build cool systems and sell them without Ericsson coming around to charge you money. For an authoritative statement, you'll need a lawyer.

3.4  Where is the Erlang documentation?

The language itself is best described by the Language Reference Manual.

The documentation delivered with open source erlang, as both man pages and html, is the most up-to-date reference to both the OTP libraries and Erlang itself. On unix systems, an easy way to read the man pages is erl -man gen_tcp .

3.5  Which book about Erlang should I read?

Different books are aimed at different audiences, so recommending one in particular is difficult. The currently available books in English, starting with the most recently published, are:

Introducing Erlang by Simon St. Laurent is a very gentle introduction to Erlang for beginners. It's available directly from the publisher.

Learn You Some Erlang for Great Good! by Fred Hebert is a beginners' book about Erlang, published in 2013. It's available directly from the publisher and also for reading online.

Erlang and OTP in Action by Martin Logan, Eric Merritt and Richard Carlsson was published in 2010. You can buy it from various online bookstores, or directly from the publisher.

Erlang Programming (A Concurrent Approach to Software Development) by Francesco Cesarini and Simon Thompson was published in 2009. Get it from Amazon etc or directly from the publisher.

Programming Erlang: Software for a Concurrent World (Joe Armstrong) is a book about Erlang written by one of the original inventors, published in 2007. You can buy it on paper from Amazon and other online bookstores, or directly from the publisher.

There are also some books in languages other than English:

French: Erlang Programmation (Mickaël Rémond) can be ordered from the publisher or via Amazon.

German: Erlang/OTP (Plattform für massiv-parallele und fehlertolerante System) (Pavlo Baron) can be ordered directly from the publisher or via Amazon.

Spanish: Erlang/OTP Un Mundo Concurrente (Manuel Rubio) can be ordered directly from the publisher.

Of historical interest only: Concurrent Programming in Erlang (2nd. Edition, 1993) (Armstrong, Virding, Wikström & Williams). Archaeologists can download the first half of the book from

Also only of historical interest: Maurice Castro's book, Erlang in Real Time (1998).

3.6  What advanced Erlang documentation is there?

The Standard Erlang spec aims to define the Erlang language. There is currently no compiler which actually implements everything exactly the way Standard Erlang specifies. This specification is quite precise; it's intended as a reference, not a bedtime read! Compiler and tool implementors will find this useful, as will advanced Erlang programmers.

Core Erlang is an effort to define an Erlang-like language which is nicer to compilers and language tools and can be automatically generated from Erlang. Erlang compilers from R10 onwards can generate Core Erlang from normal Erlang code. They can also generate .beam files from Core Erlang.

The Erlang Rationale is a short (13 page) discussion written by one of the original authors of Erlang about why some parts of Erlang became the way they are. It's a work in progress.

The proceedings from the Erlang User Conferences contain many interesting articles. The proceedings for each of the yearly conferences since 1999 are online.

The internals of the BEAM file format are described on Björn's homepage . Eventually this will/might include a description of the virtual machine's instructions. Björn also includes some benchmarks comparing different versions of the BEAM machine. You may also want to take a look at the beam_lib module.

Joe Armstrong's Thesis, Making reliable distributed systems in the presence of software errors contains a lot of interesting information, including a compact overview of the language, a number of case studies and some discussion of the language's evolution, somewhat similar to Bjarne Stroustrup's Design and Evolution of C++.

This Masters Thesis contains a good overview of some of Erlang's implementation aspects, including memory allocation (section 7).

Another Masters Thesis contains a good overview of Erlang's distribution mechanisms (Section 5).

The (Ex-Ericsson) computer science laboratory has a collection of papers about Erlang-related topics.

The source-code release includes a directory with some of the internal build documentation in the subdirectory erts/emulator/internal_doc/ .

The Trapexit wiki has a collection of HowTo documents showing how to do all manner of things from how to write a webserver in Erlang to how to write an Erlang Port program.

3.7  What documentation is there in related subjects?

There are a couple of books about specific types of applications which use Erlang as the main language in the book:

Building Web Applications with Erlang by Zachary Kessin

Handbook of Neuroevolution Through Erlang by Gene I. Sher

The standard text about data structures in functional languages is Purely Functional Data Structures by Chris Okasaki. The parts about laziness (about half of the book) do not apply to Erlang, but are interesting nonetheless. An early version of the book is available online, the book itself is available from many online booksellers.

Structure and Interpretation of Computer Programs is a standard introductory text to functional programming. It is available both on paper and online.

3.8  Is there public CVS/Git/your-favourite-vcs repository for the Erlang source?

As of R13B03 (November 2009), there is an official Git repository maintained (daily!) by the Erlang/OTP group. There is also an unofficial repository which includes history before the R13B03 release.

3.9  How can I contribute to Erlang?

When you write Erlang code you want to share, there are quite a number of ways to share it. The place to announce such things is the Erlang Questions mailing list, or, in the case of patches, the Erlang Patches mailing list. Where you put the actual code is up to you.

If your code is a correction, modification or extension to an existing part of OTP, the usual way of spreading it is via github, the wiki has instructions.

If your code is a new application or library, some common ways of distributing it are:

3.10  How can I propose changes to the language itself?

Even though Erlang is a fairly mature language with a large established code-base, changes and enhancements are still being incorporated. There is a mechanism called the Erlang Enhancement Proposal which formalises the process.

3.11  Where is Erlang discussed in the real world?


Erlang Factory organises regular Erlang conferences around the world. By tradition, the annual Erlang User Conference is held in May in Stockholm (Erlang's birthplace).

The programming conferences Strange Loop and Tech Mesh both featured presentations about aspects of Erlang in 2012.

Academic conferences about functional programming are also attended by a few Erlang users. The International Conference on Functional Programming usually includes an Erlang workshop.

Erlounge and User Groups

Every so often, someone puts out an invitation on erlang-questions to informally discuss Erlang over a few beers. Past Erlounges have been in Sweden (Stockholm), Scotland, the USA (Atlanta, New York, Chicago, North Carolina, Schaumburg, Seattle, SF Bay area, Arlington, Washington DC), France (Paris), China (I can't read the characters which described the location), Italy, Germany (Aachen), Poland (Krakow), New Zealand (Wellington) and others. There's a Trapexit page listing known usergroups.

3.12  Where is Erlang discussed online?

There are several mailing lists devoted to Erlang:


This is intended for general discussion about Erlang. Anyone can send mail to, and anyone can subscribe.


This list carries announcements about new releases of Erlang, patches, etc. All posts to erlang-announce also appear in erlang-questions.


This list is for patches to the Erlang distribution. At the time of writing, it is not archived.


This list is for bug reports.

Web forums and mailing list archives

The erlang-questions list is archived on the Erlang website.

The GMANE news/mail gateway acts as both an archive and a forum-style way of using the mailing list. It has Erlang Questions and Erlang Patches.

The trapexit site also has a forum interface to the mailing list.

IRC channel

There's an IRC channel, #erlang, on

3.13  Where can I find Erlang programmers/employers?

Posting a short note to is a good start, especially if the subject-line clearly identifies the post as a job request/advert.

There are several sites with a high concentration of Erlang jobs:

Several consultant groups have Erlang-certified people in Sweden, including ENEA data and Sjöland & Thyselius. take assignments worldwide. Process-one are based in France.

If you want to be listed here, send some mail to

Kontakten (Contact), an Ericsson-internal newspaper, may also be useful as it carries many job ads.