एर्लैंग - ओटीपी

ओटीपी का मतलब ओपन टेलिकॉम प्लेटफॉर्म है। यह एक अनुप्रयोग ऑपरेटिंग सिस्टम और पुस्तकालयों और बड़े पैमाने पर निर्माण के लिए उपयोग की जाने वाली प्रक्रियाओं का एक सेट है, दोष-सहिष्णु, वितरित अनुप्रयोग। यदि आप ओटीपी का उपयोग करके अपने स्वयं के अनुप्रयोगों को प्रोग्राम करना चाहते हैं, तो केंद्रीय अवधारणा जो आपको बहुत उपयोगी लगेगी वह ओटीपी व्यवहार है। एक व्यवहार सामान्य व्यवहार पैटर्न को एनकोड करता है - इसे एक एप्लिकेशन फ्रेमवर्क के रूप में सोचें जो कि कॉलबैक मॉड्यूल द्वारा मानकीकृत है।

ओटीपी की शक्ति दोष सहिष्णुता, स्केलेबिलिटी, डायनेमिक-कोड अपग्रेड, और इसी तरह के गुणों से आती है, जो व्यवहार द्वारा ही प्रदान की जा सकती है। तो पहली मूल अवधारणा एक सर्वर घटक बनाना है जो एक ओटीपी वातावरण की मूल बातें की नकल करता है, आइए उसी के लिए निम्नलिखित उदाहरण देखें।

उदाहरण

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

यह कोड वास्तव में दो कार्य करता है। यह एक कॉलबैक मॉड्यूल के रूप में कार्य करता है जिसे सर्वर फ्रेमवर्क कोड से कहा जाता है, और एक ही समय में, इसमें इंटरफेसिंग रूटीन होता है जिसे क्लाइंट द्वारा बुलाया जाएगा। सामान्य ओटीपी सम्मेलन दोनों कार्यों को एक ही मॉड्यूल में संयोजित करना है।

तो यहां बताया गया है कि उपरोक्त कार्यक्रम को चलाने की आवश्यकता है -

में erl, पहले सर्वर प्रोग्राम को निम्न कमांड चलाकर चलाएं।

server(name_server,name_server)

आपको निम्न आउटपुट मिलेगा -

उत्पादन

true

उसके बाद, निम्न आदेश चलाएँ

name_server.add(erlang,”Tutorialspoint”).

आपको निम्न आउटपुट मिलेगा -

उत्पादन

Ok

फिर, निम्न कमांड चलाएँ -

name_server.whereis(erlang).

आपको निम्न आउटपुट मिलेगा -

उत्पादन

{ok,"Tutorialspoint"}