DCN - क्लाइंट सर्वर मॉडल

दो दूरस्थ अनुप्रयोग प्रक्रियाएं मुख्य रूप से दो अलग-अलग फैशनों में संवाद कर सकती हैं:

  • Peer-to-peer: दोनों दूरस्थ प्रक्रियाएं समान स्तर पर निष्पादित हो रही हैं और वे कुछ साझा संसाधनों का उपयोग करके डेटा का आदान-प्रदान करते हैं।

  • Client-Server: एक दूरस्थ प्रक्रिया क्लाइंट के रूप में कार्य करती है और सर्वर के रूप में कार्य करने वाली किसी अन्य अनुप्रयोग प्रक्रिया से कुछ संसाधन का अनुरोध करती है।

क्लाइंट-सर्वर मॉडल में, कोई भी प्रक्रिया सर्वर या क्लाइंट के रूप में कार्य कर सकती है। यह मशीन का प्रकार, मशीन का आकार, या इसकी कंप्यूटिंग शक्ति नहीं है जो इसे सर्वर बनाता है; यह सेवारत अनुरोध की क्षमता है जो एक मशीन को सर्वर बनाती है।

एक सिस्टम सर्वर और क्लाइंट के रूप में एक साथ कार्य कर सकता है। अर्थात्, एक प्रक्रिया सर्वर के रूप में कार्य कर रही है और दूसरा ग्राहक के रूप में कार्य कर रहा है। यह भी हो सकता है कि क्लाइंट और सर्वर दोनों प्रोसेस एक ही मशीन पर रहते हों।

संचार

क्लाइंट-सर्वर मॉडल में दो प्रक्रियाएं विभिन्न तरीकों से बातचीत कर सकती हैं:

  • Sockets

  • दूरस्थ प्रक्रिया कॉल (RPC)

कुर्सियां

इस प्रतिमान में, सर्वर के रूप में कार्य करने वाली प्रक्रिया एक प्रसिद्ध (या क्लाइंट द्वारा ज्ञात) पोर्ट का उपयोग करके एक सॉकेट खोलती है और कुछ क्लाइंट अनुरोध आने तक इंतजार करती है। क्लाइंट के रूप में कार्य करने वाली दूसरी प्रक्रिया भी एक सॉकेट खोलती है, लेकिन आने वाले अनुरोध की प्रतीक्षा करने के बजाय, ग्राहक 'अनुरोधों को पहले' संसाधित करता है।

जब अनुरोध सर्वर तक पहुंच जाता है, तो इसे परोसा जाता है। यह या तो एक सूचना साझा करने या संसाधन अनुरोध हो सकता है।

दुरस्तह प्रकिया कॉल

यह एक तंत्र है जहां एक प्रक्रिया दूसरे के साथ प्रक्रिया कॉल के माध्यम से संपर्क करती है। एक प्रक्रिया (क्लाइंट) दूरस्थ होस्ट पर पड़ी प्रक्रिया को कॉल करती है। दूरस्थ होस्ट पर प्रक्रिया को सर्वर कहा जाता है। दोनों प्रक्रियाओं को आवंटित किए गए स्टब हैं। यह संचार निम्नलिखित तरीके से होता है:

  • क्लाइंट प्रक्रिया क्लाइंट स्टब को कॉल करती है। यह स्थानीय से संबंधित सभी मापदंडों को पास करता है।

  • सभी मापदंडों को तब पैक किया जाता है (मार्शेल्ड) और उन्हें नेटवर्क के दूसरी तरफ भेजने के लिए एक सिस्टम कॉल किया जाता है।

  • कर्नेल नेटवर्क पर डेटा भेजता है और दूसरा छोर उसे प्राप्त करता है।

  • दूरस्थ होस्ट सर्वर स्टब के लिए डेटा पास करता है जहां यह अनमर्सहेल्ड है।

  • मापदंडों को प्रक्रिया में पारित किया जाता है और फिर प्रक्रिया को निष्पादित किया जाता है।

  • परिणाम क्लाइंट को उसी तरीके से वापस भेजा जाता है।