OTP расшифровывается как Open Telecom Platform. Это операционная система приложения и набор библиотек и процедур, используемых для создания крупномасштабных отказоустойчивых распределенных приложений. Если вы хотите программировать свои собственные приложения с использованием OTP, то основная идея, которую вы найдете очень полезной, — это поведение OTP. Поведение инкапсулирует общие поведенческие паттерны — воспринимайте его как структуру приложения, параметризованную модулем обратного вызова.
Мощность OTP зависит от таких свойств, как отказоустойчивость, масштабируемость, обновление динамического кода и т. Д., Которые могут быть предоставлены самим поведением. Итак, первая базовая концепция заключается в создании серверного компонента, который имитирует основы среды OTP, давайте рассмотрим следующий пример.
пример
-module(server). -export([start/2, rpc/2]). start(Name, Mod) -> register(Name, spawn(fun() -> loop(Name, Mod, Mod:init()) end)). rpc(Name, Request) -> Name ! {self(), Request}, receive {Name, Response} -> Response end. loop(Name, Mod, State) -> receive {From, Request} -> {Response, State1} = Mod:handle(Request, State), From ! {Name, Response}, loop(Name, Mod, State1) end.
Следующие вещи должны быть отмечены о вышеупомянутой программе —
-
Процесс, если он зарегистрирован в системе с использованием функции регистрации.
-
Процесс порождает функцию цикла, которая обрабатывает обработку.
Процесс, если он зарегистрирован в системе с использованием функции регистрации.
Процесс порождает функцию цикла, которая обрабатывает обработку.
Теперь давайте напишем клиентскую программу, которая будет использовать серверную программу.
пример
-module(name_server). -export([init/0, add/2, whereis/1, handle/2]). -import(server1, [rpc/2]). add(Name, Place) -> rpc(name_server, {add, Name, Place}). whereis(Name) -> rpc(name_server, {whereis, Name}). init() -> dict:new(). handle({add, Name, Place}, Dict) -> {ok, dict:store(Name, Place, Dict)}; handle({whereis, Name}, Dict) -> {dict:find(Name, Dict), Dict}.
Этот код фактически выполняет две задачи. Он служит в качестве модуля обратного вызова, который вызывается из кода серверной платформы, и в то же время содержит подпрограммы взаимодействия, которые будут вызываться клиентом. Обычное соглашение OTP состоит в том, чтобы объединить обе функции в одном модуле.
Итак, вот как нужно запустить вышеуказанную программу:
В erl сначала запустите серверную программу, выполнив следующую команду.
server(name_server,name_server)
Вы получите следующий вывод —
Выход
true
Затем выполните следующую команду
name_server.add(erlang,”Tutorialspoint”).
Вы получите следующий вывод —
Выход
Ok
Затем выполните следующую команду —
name_server.whereis(erlang).
Вы получите следующий вывод —