इंटर प्रोसेस कम्युनिकेशन - ओवरव्यू
इंटर प्रोसेस कम्युनिकेशन (IPC) एक ऐसा तंत्र है जिसमें एक प्रक्रिया का संचार दूसरी प्रक्रिया के साथ होता है। यह आमतौर पर केवल एक प्रणाली में होता है।
संचार दो प्रकार के हो सकते हैं -
संबंधित प्रक्रियाओं के बीच केवल एक प्रक्रिया से शुरू करना, जैसे कि माता-पिता और बच्चे की प्रक्रिया।
असंबंधित प्रक्रियाओं, या दो या अधिक विभिन्न प्रक्रियाओं के बीच।
इस विषय पर आगे बढ़ने से पहले कुछ महत्वपूर्ण शब्द निम्नलिखित हैं, जिन्हें हमें जानना आवश्यक है।
Pipes- दो संबंधित प्रक्रियाओं के बीच संचार। तंत्र आधा द्वैध है जिसका अर्थ है पहली प्रक्रिया दूसरी प्रक्रिया के साथ संचार करती है। एक पूर्ण द्वैध को प्राप्त करने के लिए, दूसरी प्रक्रिया के लिए पहली प्रक्रिया के साथ संवाद करने के लिए एक और पाइप की आवश्यकता होती है।
FIFO- दो असंबंधित प्रक्रियाओं के बीच संचार। एफआईएफओ एक पूर्ण द्वैध है, जिसका अर्थ है कि पहली प्रक्रिया एक ही समय में दूसरी प्रक्रिया और इसके विपरीत के साथ संवाद कर सकती है।
Message Queues- पूर्ण द्वैध क्षमता के साथ दो या दो से अधिक प्रक्रियाओं के बीच संचार। प्रक्रियाएं संदेश पोस्ट करके और इसे कतार से बाहर निकालकर एक दूसरे के साथ संवाद करेंगी। एक बार पुनर्प्राप्त करने के बाद, संदेश कतार में उपलब्ध नहीं है।
Shared Memory- दो या अधिक प्रक्रियाओं के बीच संचार सभी प्रक्रियाओं के बीच स्मृति के एक साझा टुकड़े के माध्यम से प्राप्त किया जाता है। साझा मेमोरी को सभी प्रक्रियाओं तक पहुंच को सिंक्रनाइज़ करके एक दूसरे से संरक्षित करने की आवश्यकता है।
Semaphores- सेमीफोरर्स कई प्रक्रियाओं तक पहुंच को सिंक्रनाइज़ करने के लिए हैं। जब कोई प्रक्रिया मेमोरी (पढ़ने या लिखने के लिए) का उपयोग करना चाहती है, तो इसे एक्सेस (या संरक्षित) लॉक करना होगा और एक्सेस हटाए जाने पर जारी करना होगा। डेटा को सुरक्षित करने के लिए सभी प्रक्रियाओं को दोहराया जाना चाहिए।
Signals- सिग्नल सिग्नलिंग के माध्यम से कई प्रक्रियाओं के बीच संचार के लिए एक तंत्र है। इसका मतलब है कि एक स्रोत प्रक्रिया एक संकेत (संख्या द्वारा मान्यता प्राप्त) भेज देगी और गंतव्य प्रक्रिया तदनुसार इसे संभाल लेगी।
Note - इस ट्यूटोरियल के लगभग सभी प्रोग्राम लिनक्स ऑपरेटिंग सिस्टम (उबंटू में निष्पादित) के तहत सिस्टम कॉल पर आधारित हैं।