OTP
优质
小牛编辑
125浏览
2023-12-01
OTP代表开放电信平台。 它是一个应用程序操作系统和一组用于构建大规模,容错,分布式应用程序的库和过程。 如果您想使用OTP编写自己的应用程序,那么您将发现非常有用的核心概念是OTP行为。 行为封装了常见的行为模式 - 将其视为由回调模块参数化的应用程序框架。
OTP的强大功能来自于容错,可伸缩性,动态代码升级等属性,可以由行为本身提供。 因此,第一个基本概念是创建一个模仿OTP环境基础的服务器组件,让我们看一下相同的示例。
例子 (Example)
-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.
关于上述计划需要注意以下事项 -
使用寄存器功能在系统中注册的过程。
该过程产生一个处理处理的循环函数。
现在让我们编写一个将使用服务器程序的客户端程序。
例子 (Example)
-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)
您将获得以下输出 -
输出 (Output)
true
然后,运行以下命令
name_server.add(erlang,”IoWiki”).
您将获得以下输出 -
输出 (Output)
Ok
然后,运行以下命令 -
name_server.whereis(erlang).
您将获得以下输出 -
输出 (Output)
{ok,"IoWiki"}