Erlang-otp

提供:Dev Guides
移動先:案内検索

アーラン-OTP

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}.

このコードは実際に2つのタスクを実行します。 サーバーフレームワークコードから呼び出されるコールバックモジュールとして機能すると同時に、クライアントによって呼び出されるインターフェイスルーチンが含まれています。 通常のOTP規則では、同じモジュールで両方の機能を組み合わせます。

だからここに上記のプログラムを実行する必要がある方法です-

*erl* では、まず次のコマンドを実行してサーバープログラムを実行します。
server(name_server,name_server)

あなたは次の出力を取得します-

出力

true

次に、次のコマンドを実行します

name_server.add(erlang,”finddevguides”).

あなたは次の出力を取得します-

出力

Ok

次に、次のコマンドを実行します-

name_server.whereis(erlang).

あなたは次の出力を取得します-

出力

{ok,"finddevguides"}