From Java

To Erlang

About Me

Developer Freelance in Paris

@rolios

o.gonthier@gmail.com

Gonthier Olivier

Context

Context

Team switch

Client side

Java

Android

IntelliJ

Server side

Erlang

MongooseIM

Vim

Erlang learning

And also:

-Functional principles by learning Haskell

-Scrum-mastering, continuous integration

Online training

Read books

Watch talks

Read code

Android team

Oh, you want to use a dead language?

Java is better

Erlang team

Oh, you was doing ugly fat Java! Beh
Erlang is better

 

Erlang in a nutshell

Disclaimer

Erlang: what's that?

VM-based, Functional, impure, 

Typed dynamically, Concurrent, Distributed,

Opinionated

Erlang is a general-purpose, concurrent, garbage-collected programming language and runtime system. (Wikipédia)

Created by Sony Ericsson in 1987
Open-Source since 1998

Erlang: usage

  • Created for Telecom needs
  • Ericson platform: 99.9999999% uptime
  • Used for xmpp servers: ejabberd, MongooseIM
  • RabbitMQ, CouchDB
  • WhatsApp backend

Facebook started his chat in erlang, dropped it for c++ in 2009, and then... Bought whatsapp, using erlang, 5 years later

What it looks like!

Syntax

-module(my_module).
-export([my_func/1, my_other_func/2, another_one/0]).

% A comment

%% A function returning its parameter
my_func(X) -> X.

%% A function using pattern matching
my_other_func(true, _) -> ok;
my_other_func(_, _) -> error.

%% A function with multiple clauses
another_one() -> 
    X = my_func(0),
    Y = other_module:other_func(),
    X+Y.
    
%% A function not exported
private_function() -> ok.

Java analogy

module = class; function = method; export = public

Pattern matching

% Matching on function definition
invert(true) -> false;
invert(false) -> true.

% Values passed in parameter are bound
add_one(X) -> X+1.

% Pattern matching using case syntax
case write_file("helloworld") of
    {ok, File} -> File;
    {error, Error} -> log_error(Error)
end.

% Matching bind variables
> X = 1.

% Binding can be done even with data structures
> {Y, [Z, B]} = {2, [3, true]}

% Bounded variable can't match other values
> X = 2.
** exception error: no match of right hand side value 2

% No problems if trying to bind the same value
> {X, Y} = {1, 2}.

Data types

Boolean: true, false

Numbers: 1, 0.5, 2.0e3, $A, 2#101001

Atoms: hello, this_is_an_atom, ok

Tuples: {1, 2}, {temp, {celsius, 21}}

List: [1,2], [true, 1, ok, {beer, blond}]

Strings: "hello", [96,97,98]

 

​Also: Binaries, PID, Fun, Map

Atoms

Atoms are a kind of simple "tags"

In use, it can be similar to Java enums or static values.

public static final int DECEMBER = 12;

public enum Day {
    SUNDAY, MONDAY, TUESDAY, WEDNESDAY,
    THURSDAY, FRIDAY, SATURDAY 
}

selectDay(25, SUNDAY, DECEMBER);
select_day(25, sunday, december).

They are often used to give context to values

{prices, [{beer, 2}, {vodka, 10}], euro}.

Strings

Beh.

> [104, 101, 108, 108, 111]
"hello"

> [X, Y] = "ab".
> X.
97

> [X, Y, 0].
[97, 98, 0]

Excuse me?

Alternative: bit strings

> <<"Hello world">>.

> <<A, B>> = <<"ab">>.
> A.
97

Concurrency

Lightweight processes, and Message Passing

-module(echo).
-export([go/0, loop/0]).
 
go() ->
	Pid2 = spawn(echo, loop, []),
	Pid2 ! {self(), hello},
	receive 
		{Pid2, Msg} ->
			io:format("P1 ~w~n",[Msg])
	end,
	Pid2 ! stop.

loop() ->
	receive
		{From, Msg} -> 
			From ! {self(), Msg},
			loop();
		stop ->
			true
	end.
Pid ! {MyPid, Msg} % Send message to Pid

Distributed system

-At the heart of the language-

Erlang VMs visible on network and sharing a specific cookie, are interconnected!

And you can send messages to other nodes transparently!

You can connect/disconnect nodes whenever you want

OTP

-Open Telecom Platform-

Abstract things we need often,

like server/client pattern

Supervision tree made easy

-behaviour(supervisor).
-behaviour(gen_server).
-behaviour(gen_event).
-behaviour(gen_fsm).

Erlang         philosophy

Let it crash!

But recover from it

No need of defensive programming

Kill yourself if you can't recover.

Think in terms of protocols

Message passing
Share nothing

Kill people not respecting the protocol.

Golden trinity

Tools

Eshell

REPL

Debug Console

$> erl
% Compile a module
c(my_module).

% Unbind var
f(X).

Hot reload

Good News: Hot reloading is available in Erlang!

Thoughts 

you don't need to reboot your app

static typing would have been complicated with this

Nothing to do, just compile and use your new .beam

Eunit

Or Junit with a 'E' instead of 'J'

-module(fibo).

-ifdef(EUNIT).
-include_lib("eunit/include/eunit.hrl").
-endif.

fib(0) -> 1;
fib(1) -> 1;
fib(N) when N > 1 -> fib(N-1) + fib(N-2).

fib_test_() ->
       [?_assert(fib(0) =:= 1),
	?_assert(fib(1) =:= 1),
	?_assert(fib(2) =:= 2),
	?_assert(fib(3) =:= 3),
	?_assert(fib(4) =:= 5),
	?_assert(fib(5) =:= 8),
	?_assertException(error, function_clause, fib(-1)),
	?_assert(fib(31) =:= 2178309)
       ].

Rebar

Maven/Gradle equivalent

$ rebar create-app appid=myapp
$ rebar get-deps
$ rebar compile
$ rebar eunit
$ rebar generate

Muptiple commands to compile/test/package etc.

{deps, [
    {em, ".*", {git, "https://github.com/sheyll/erlymock.git"}},
    {nano_trace, ".*", {git, "https://github.com/sheyll/nano_trace.git", {branch, "feature/rebar-migration"}}},
    {mochiweb, "2.3.2", {git, "https://github.com/mochi/mochiweb.git", {tag, "v2.3.2"}}},
    % Or specify a revision to refer a particular commit, useful if the project has only the master branch
    % {mochiweb, "2.3.2", {git, "https://github.com/mochi/mochiweb.git", "15bc558d8222b011e2588efbd86c01d68ad73e60"},

    % An example of a "raw" dependency:
    {rebar, ".*", {git, "git://github.com/rebar/rebar.git", {branch, "master"}}, [raw]}
   ]}.

Configuration is done in a rebar.config file

Dependencies are git repositories :(

Observer

A very useful debug console

> observer:start().

Supervision tree, tracing, systems statistics, consumption...

Other

Dialyzer: let you do a static analysis
Reltool: tool to make erlang releases
(used by rebar)

Erlang.mk: Alternative to rebar based on a makefile

WombatOAM: commercial product for system supervision

Gimme more Erlang!

Erlang: the movie

Erlang : The movie II - The sequel

If you want to hear about a new name for Erlang...

Good resources

Awesome book!

A good list of resources
 https://gist.github.com/macintux/6349828

Gonthier Olivier
@rolios
o.gonthier@gmail.com

From Java To Erlang

By Gonthier Olivier

From Java To Erlang

  • 3,141