शून्य-प्रतिलिपि

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

सिद्धांत
जीरो-कॉपी कंप्यूटर प्रोग्रामिंग तकनीकों का उपयोग तब किया जा सकता है जब एक उपयोक्ता स्थान  प्रक्रिया (यानी दो या अधिक थ्रेड (कंप्यूटिंग), आदि) के बीच डेटा का आदान-प्रदान किया जाता है और/या दो या दो से अधिक प्रक्रियाओं के बीच (निर्माता-उपभोक्ता समस्या भी देखें) और/या जब डेटा को कर्नेल स्पेस के अंदर या यूजर स्पेस प्रोसेस और ऑपरेटिंग सिस्टम (OS) के कर्नेल स्पेस भागों के बीच एक्सेस/कॉपी/स्थानांतरित किया जाना है।

आमतौर पर जब एक उपयोगकर्ता स्थान प्रक्रिया को अपने उच्च स्तरीय इंटरफ़ेस (कंप्यूटिंग) के माध्यम से या एक परिधीय उपकरण  (यानी एक  डिस्क भंडारण, एक नेटवर्क इंटरफ़ेस नियंत्रक, आदि) से डेटा पढ़ने या लिखने जैसे सिस्टम ऑपरेशंस को निष्पादित करना होता है या एक से डेटा ले जाना होता है। डिवाइस से दूसरे डिवाइस, आदि, इसे एक या एक से अधिक सिस्टम कॉल करने होते हैं जो कि ऑपरेटिंग सिस्टम द्वारा कर्नेल स्पेस में निष्पादित किए जाते हैं।

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

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

एक उदाहरण के रूप में, एक फ़ाइल को पढ़ने और फिर इसे एक नेटवर्क पर पारंपरिक तरीके से भेजने के लिए 2 अतिरिक्त डेटा प्रतियों की आवश्यकता होती है (कर्नेल से उपयोगकर्ता स्थान पर पढ़ने के लिए + 1 उपयोगकर्ता से कर्नेल स्थान पर लिखने के लिए) और प्रति पढ़ने/लिखने के चक्र में 4 संदर्भ स्विच. वे अतिरिक्त डेटा प्रतियां CPU का उपयोग करती हैं। उस फ़ाइल को फ़ाइल डेटा के एमएमएपी और राइट कॉल के चक्र का उपयोग करके भेजना, संदर्भ स्विच को प्रति राइट कॉल 2 तक कम कर देता है और उन पिछली 2 अतिरिक्त उपयोगकर्ता डेटा प्रतियों से बचता है। एक ही फाइल को जीरो कॉपी के जरिए भेजने से संदर्भ स्विच 2 प्रति सेंडफाइल कॉल में कम हो जाता है और सभी सीपीयू अतिरिक्त डेटा प्रतियां (उपयोगकर्ता और कर्नेल स्थान दोनों में) समाप्त हो जाती हैं।

जीरो-कॉपी प्रोटोकॉल विशेष रूप से बहुत हाई-स्पीड नेटवर्क के लिए महत्वपूर्ण होते हैं जिसमें नेटवर्क लिंक की क्षमता सीपीयू की प्रोसेसिंग क्षमता तक पहुंच जाती है या उससे अधिक हो जाती है। ऐसे मामले में सीपीयू अपना लगभग सारा समय हस्तांतरित डेटा की नकल करने में लगा सकता है, और इस तरह एक अड़चन बन जाता है जो संचार दर को लिंक की क्षमता से नीचे तक सीमित कर देता है। उद्योग में उपयोग किए जाने वाले अंगूठे का एक नियम यह है कि आने वाले डेटा के एक बिट को संसाधित करने के लिए मोटे तौर पर एक CPU घड़ी चक्र की आवश्यकता होती है।

हार्डवेयर कार्यान्वयन
एक प्रारंभिक कार्यान्वयन IBM OS/360 था जहां एक प्रोग्राम चैनल I/O को एक फ़ाइल या डिवाइस से डेटा के ब्लॉक को डेटा बफर में पढ़ने और डेटा को स्थानांतरित किए बिना उसी बफर से दूसरे को लिखने का निर्देश दे सकता है।

जीरो-कॉपी सॉफ़्टवेयर बनाने की तकनीकों में स्मृति प्रबंधन इकाई  (MMU) के माध्यम से  प्रत्यक्ष मेमोरी एक्सेस  (DMA)-आधारित कॉपी और मेमोरी-मैपिंग का उपयोग शामिल है। इन सुविधाओं के लिए विशिष्ट हार्डवेयर समर्थन की आवश्यकता होती है और आमतौर पर विशेष मेमोरी संरेखण आवश्यकताओं को शामिल किया जाता है।

विषम प्रणाली वास्तुकला (HSA) द्वारा उपयोग किया जाने वाला एक नया दृष्टिकोण सेंट्रल प्रोसेसिंग यूनिट और ग्राफ़िक्स प्रोसेसिंग युनिट  और अन्य प्रोसेसर के बीच  सूचक (कंप्यूटर प्रोग्रामिंग)  को पास करने की सुविधा प्रदान करता है। इसके लिए CPU और GPU के लिए एक समान मेमोरी एक्सेस की आवश्यकता होती है।

प्रोग्राम इंटरफेस
कई ऑपरेटिंग सिस्टम विशिष्ट एपीआई के माध्यम से उपयोगकर्ता डेटा और फ़ाइल सामग्री की शून्य-प्रतिलिपि का समर्थन करते हैं।

यहां सबसे लोकप्रिय ओएस में उपलब्ध कुछ प्रसिद्ध सिस्टम कॉल/एपीआई सूचीबद्ध हैं।

नोवेल नेटवेयर इवेंट कंट्रोल ब्लॉक्स (ईसीबी) के माध्यम से जीरो-कॉपी के एक फार्म का समर्थन करता है, एनसीओपीवाई देखें। DR-DOS के कुछ संस्करणों में आंतरिक DOS कमांड COPY (DOS कमांड) कमांड 1992 से जब COMMAND.COM यह पता लगाता है कि प्रतिलिपि की जाने वाली फ़ाइलें नेटवेयर फ़ाइल सर्वर पर संग्रहीत हैं, तो यह इसे भी आरंभ करता है, अन्यथा यह सामान्य फ़ाइल प्रतिलिपि पर वापस आ जाता है। DR DOS 6.0 (1991) और MS-DOS 6.0 (1993) के बाद से बाहरी DOS कमांड MOVE (DOS कमांड) कमांड आंतरिक रूप से एक RENAME (DOS कमांड) करता है (जिसके कारण फ़ाइल सिस्टम में केवल निर्देशिका प्रविष्टि को भौतिक रूप से कॉपी करने के बजाय संशोधित किया जा सकता है) फ़ाइल डेटा) जब स्रोत और गंतव्य एक ही लॉजिकल वॉल्यूम पर स्थित होते हैं।

लिनक्स कर्नेल विभिन्न सिस्टम कॉल्स के माध्यम से जीरो-कॉपी का समर्थन करता है, जैसे:
 * सेंडफाइल, सेंडफाइल64; * ब्याह (सिस्टम कॉल); * टी; * वीएमएसप्लिस; * प्रक्रिया_vm_readv; * प्रोसेस_वीएम_राइटव; * कॉपी_फाइल_रेंज; * पैकेट mmap के साथ कच्चे सॉकेट या एक्सप्रेस डेटा पाथ#AF XDP|AF_XDP.

उनमें से कुछ POSIX में निर्दिष्ट हैं और इस प्रकार बर्कले सॉफ्टवेयर वितरण कर्नेल या IBM AIX में भी मौजूद हैं, कुछ Linux कर्नेल API के लिए अद्वितीय हैं।

FreeBSD, NetBSD, OpenBSD, DragonFly BSD, आदि कम से कम इन सिस्टम कॉल्स के माध्यम से जीरो-कॉपी का समर्थन करते हैं:
 * लेख्यपत्र भेज दें; * लिखना, राईटव + एमएमएपी नेटवर्क सॉकेट में डेटा लिखते समय।

MacOS को कर्नेल के FreeBSD भाग के माध्यम से शून्य-प्रतिलिपि का समर्थन करना चाहिए क्योंकि यह समान सिस्टम कॉल प्रदान करता है (और इसके मैनुअल पृष्ठ अभी भी BSD टैग किए गए हैं) जैसे:
 * लेख्यपत्र भेज दें।

Oracle Solaris कम से कम इन सिस्टम कॉल के माध्यम से शून्य-प्रतिलिपि का समर्थन करता है:
 * लेख्यपत्र भेज दें; * सेंडफाइलव; * लिखना, राईटव + एमएमएपी।

Microsoft Windows कम से कम इस सिस्टम कॉल के माध्यम से शून्य-प्रतिलिपि का समर्थन करता है:
 * ट्रांसमिटफाइल।

जावा (प्रोग्रामिंग भाषा) इनपुट स्ट्रीम java.nio.channels.FileChannel's transferTo विधि के माध्यम से शून्य-कॉपी का समर्थन कर सकती है यदि अंतर्निहित ऑपरेटिंग सिस्टम भी शून्य कॉपी का समर्थन करता है।

रिमोट डायरेक्ट मेमोरी एक्सेस (रिमोट डायरेक्ट मेमोरी एक्सेस) प्रोटोकॉल जीरो-कॉपी तकनीकों पर गहराई से भरोसा करते हैं।

यह भी देखें

 * एएफ पीडीपी
 * संदर्भ द्वारा कॉल करें
 * डिवाइस ड्राइवर
 * अंतः स्थापित प्रणाली
 * इन्फिनिबैंड
 * संदर्भ का स्थान
 * एनसीओपीवाई
 * netsniff-एनजी
 * क्रमादेशित इनपुट / आउटपुट
 * सॉकेट डायरेक्ट प्रोटोकॉल
 * स्कैटर/इकट्ठा I/O