Elixir 1.6
Chapter 21
OTP: Applications
Application
In the OTP world an application is a bundle of code that comes with a descriptor.
That descriptor tells the runtime what
dependencies the code has,
what global names it registers,
and so on. In fact, an OTP application is more like a dynamic link library or a shared object than a conventional application.
It might help to see the word application and think of it as a component or service.
The Application Specification File
Every now and then mix will talk about a file called name.app, where name is your application’s name.
This file is called an application specification and is used to define your application to the runtime environment.
When you run your application this file is consulted to get things loaded.
Sequence Program already OTP App
Our sequence program from last chapter is already an OTP application.
def application do
[
mod: { Sequence.Application, [] },
extra_applications: [:logger],
]
end
This says that the top-level module of our application is called Sequence. OTP assumes this module will implement a start function, and it will pass that function an empty list as a parameter.
/mix.exs
Sequence OTP Appliction
Let's change the default value from mix.exs
def application do
[
mod: { Sequence.Application, 456 },
extra_applications: [:logger],
]
end
The mod: option tells OTP the module that is the main entry point for our app. OTP will call this modules start function.
Sequence OTP Appliction
defmodule Sequence.Application do
@moduledoc false
use Application
def start(_type, initial_number) do
children = [
{ Sequence.Stash, initial_number},
{ Sequence.Server, nil},
]
opts = [strategy: :rest_for_one, name: Sequence.Supervisor]
Supervisor.start_link(children, opts)
end
end
Modify Sequence module like this:
Sequence OTP Appliction
$ iex -S mix
Compiling 5 files (.ex)
Generated sequence app
iex> Sequence.Server.next_number
456
Sequence OTP Appliction
Let's add another option to application.
defmodule Sequence.MixProject do
use Mix.Project
def application do
[
mod: {
Sequence.Application, 456
},
registered: [
Sequence.Server,
],
extra_applications: [:logger],
]
end
end
The registered: option lists the names that our application will register. This ensures each name is unique across all loaded applications in a node or cluster.
Sequence OTP Appliction
We can also set up the env:
# Configuration for the OTP application
def application do
[
mod: { Sequence, [] },
env: [initial_number: 456],
registered: [ Sequence.Server ]
]
end
# Application.get_env can retrieve values anywhere in the code
defmodule Sequence do
use Application
def start(_type, _args) do
Sequence.Supervisor.start_link(
Application.get_env(:sequence, :initial_number)
)
end
end
Supervision Is the Basis of Reliability
We can also set up the env:
# Configuration for the OTP application
def application do
[
mod: { Sequence, [] },
env: [initial_number: 456],
registered: [ Sequence.Server ]
]
end
defmodule Sequence do
use Application
def start(_type, _args) do
Sequence.Supervisor.start_link(
Application.get_env(:sequence, :initial_number)
)
end
end
Thank You
Programming Elixir 1.6 Chapter 21
By Dustin McCraw
Programming Elixir 1.6 Chapter 21
- 941