प्रतिक्रियाशील धाराएँ: Difference between revisions

From Vigyanwiki
No edit summary
Line 21: Line 21:
विनिर्देश का अभिप्राय कई अनुरूप [[कार्यान्वयन]] के निर्माण की अनुमति देना है, जो नियमों का पालन करने के आधार पर एक स्ट्रीम अनुप्रयोग के संपूर्ण प्रसंस्करण ग्राफ में उल्लिखित लाभों और विशेषताओं को संरक्षित करते हुए, सुचारू रूप से [[ इंटरोऑपरेबिलिटी ]] करने में सक्षम होंगे। निःशुल्क उपलब्ध [[प्रौद्योगिकी अनुकूलता किट]] <ref name="rs-tck">{{cite web|url=https://github.com/reactive-streams/reactive-streams-jvm/tree/master/tck|title=प्रतिक्रियाशील धाराएँ टीसीके|website=[[GitHub]] }}</ref> विनिर्देश के साथ विकसित किया गया था जो विनिर्देश के कार्यान्वयनकर्ताओं को यह सत्यापित करने की अनुमति देता है कि क्या वे संभावित संतति स्थितियों की जांच सहित सभी नियमों और आवश्यकताओं का आवरण करते हैं।
विनिर्देश का अभिप्राय कई अनुरूप [[कार्यान्वयन]] के निर्माण की अनुमति देना है, जो नियमों का पालन करने के आधार पर एक स्ट्रीम अनुप्रयोग के संपूर्ण प्रसंस्करण ग्राफ में उल्लिखित लाभों और विशेषताओं को संरक्षित करते हुए, सुचारू रूप से [[ इंटरोऑपरेबिलिटी ]] करने में सक्षम होंगे। निःशुल्क उपलब्ध [[प्रौद्योगिकी अनुकूलता किट]] <ref name="rs-tck">{{cite web|url=https://github.com/reactive-streams/reactive-streams-jvm/tree/master/tck|title=प्रतिक्रियाशील धाराएँ टीसीके|website=[[GitHub]] }}</ref> विनिर्देश के साथ विकसित किया गया था जो विनिर्देश के कार्यान्वयनकर्ताओं को यह सत्यापित करने की अनुमति देता है कि क्या वे संभावित संतति स्थितियों की जांच सहित सभी नियमों और आवश्यकताओं का आवरण करते हैं।


प्रतिक्रियाशील धाराएँ का दायरा [[अप्लिकेशन प्रोग्रामिंग अंतरफलक]], विधियों और प्रोटोकॉल का एक न्यूनतम सेट है। जो गैर-अवरुद्ध बैक प्रेशर के साथ डेटा की अतुल्यकालिक धाराओं को प्राप्त करने के लिए आवश्यक संचालन और इकाइयों का वर्णन करता है। {{sfn|Walls|2019|loc=§10.1.1 Defining Reactive Streams|pp=243-245}} [[अंतिम उपयोगकर्ता]] |अंत-उपयोगकर्ता [[डोमेन-विशिष्ट भाषा|डोमेन-विशिष्ट लैंग्वेज]] या प्रोटोकॉल बाइंडिंग [[एपीआई]] को अभिप्रायपूर्वक भिन्न-भिन्न कार्यान्वयन को प्रोत्साहित करने और सक्षम करने के चक्र से बाहर रखा गया है। जो संभावित रूप से अपने प्लेटफ़ॉर्म के मुहावरों के लिए यथासंभव सही रहने के लिए विभिन्न [[प्रोग्रामिंग भाषा|प्रोग्रामिंग लैंग्वेजओं]] ओं का उपयोग करते हैं।
प्रतिक्रियाशील धाराएँ का दायरा [[अप्लिकेशन प्रोग्रामिंग अंतरफलक]], विधियों और प्रोटोकॉल का एक न्यूनतम सेट है। जो गैर-अवरुद्ध बैक प्रेशर के साथ डेटा की अतुल्यकालिक धाराओं को प्राप्त करने के लिए आवश्यक संचालन और इकाइयों का वर्णन करता है। {{sfn|Walls|2019|loc=§10.1.1 Defining Reactive Streams|pp=243-245}} [[अंतिम उपयोगकर्ता]] [[डोमेन-विशिष्ट भाषा|डोमेन-विशिष्ट लैंग्वेज]] या प्रोटोकॉल बाइंडिंग [[एपीआई]] को अभिप्रायपूर्वक भिन्न-भिन्न कार्यान्वयन को प्रोत्साहित करने और सक्षम करने के चक्र से बाहर रखा गया है। जो संभावित रूप से अपने प्लेटफ़ॉर्म के मुहावरों के लिए यथासंभव सही रहने के लिए विभिन्न [[प्रोग्रामिंग भाषा|प्रोग्रामिंग लैंग्वेजओं]] ओं का उपयोग करते हैं।


== जावा मानक में समावेश ==
== जावा मानक में समावेश ==

Revision as of 15:36, 1 August 2023

Reactive Streams
Initial release15 May 2015; 9 years ago (2015-05-15)
Stable release
1.0.3 / 23 August 2019; 5 years ago (2019-08-23)
Repositorygithub.com/reactive-streams/reactive-streams-jvm
Written inJava (Scala, Groovy, Kotlin), .NET
Websitereactive-streams.org

प्रतिक्रियाशील धाराएँ गैर-अवरुद्ध बैक प्रेशर के साथ अतुल्यकालिक धारा प्रसंस्करण के लिए एक मानक प्रदान करने की एक पहल है। [1][2]

उत्पत्ति

प्रतिक्रियाशील धाराएँ की शुरुआत 2013 के अंत में नेटफ्लिक्स, पिवोटल और लाइटबेंड के अभियन्ताओ के बीच एक पहल के रूप में हुई। कुछ शुरुआती चर्चाएं 2013 में लाइटबेंड में प्ले और अक्का टीमों के बीच प्रारंभ हुईं। [3][4] लाइटबेंड प्रतिक्रियाशील धाराएँ के मुख्य योगदानकर्ताओं में से एक है। [5] अन्य योगदानकर्ताओं में रेड हैट, ओरेकल, ट्विटर और स्प्रे.आईओ सम्मलित हैं।[6]

लक्ष्य

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

विनिर्देश का अभिप्राय कई अनुरूप कार्यान्वयन के निर्माण की अनुमति देना है, जो नियमों का पालन करने के आधार पर एक स्ट्रीम अनुप्रयोग के संपूर्ण प्रसंस्करण ग्राफ में उल्लिखित लाभों और विशेषताओं को संरक्षित करते हुए, सुचारू रूप से इंटरोऑपरेबिलिटी करने में सक्षम होंगे। निःशुल्क उपलब्ध प्रौद्योगिकी अनुकूलता किट [1] विनिर्देश के साथ विकसित किया गया था जो विनिर्देश के कार्यान्वयनकर्ताओं को यह सत्यापित करने की अनुमति देता है कि क्या वे संभावित संतति स्थितियों की जांच सहित सभी नियमों और आवश्यकताओं का आवरण करते हैं।

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

जावा मानक में समावेश

सफल सिद्ध होने और पर्याप्त लाइब्रेरी और विक्रेताओं द्वारा अपनाए जाने पर, आधिकारिक जावा मानक लाइब्रेरी में भविष्य में सम्मलित करने के इरादे से विनिर्देश विकसित किया गया।

[1] जेएसआर 166 के नेता डौग ली द्वारा प्रतिक्रियाशील धाराएँ को जावा (सॉफ़्टवेयर प्लेटफ़ॉर्म) 9 का खंड बनने का प्रस्ताव दिया गया था। [3] एक नए प्रवाह वर्ग के रूप में[4] इसमें वर्तमान में प्रतिक्रियाशील धाराएँ द्वारा प्रदान किए गए इंटरफेस सम्मलित होंगे। [5][6] प्रतिक्रियाशील धाराएँ की सफल 1.0 रिलीज और बढ़ती स्वीकार्यता के बाद, प्रस्ताव को स्वीकार कर लिया गया और जेडीके संवर्धन प्रस्ताव जे.ई.पी-266 के माध्यम से प्रतिक्रियाशील धाराएँ को जावा (सॉफ्टवेयर प्लेटफॉर्म) में सम्मलित किया गया।[6][7]

गोद लेना

30 अप्रैल, 2015 को जेवीएम के लिए प्रतिक्रियाशील धाराएँ का संस्करण 1.0.0 जारी किया गया था,[5][8][9] जावा एपीआई सहित,[10] एक पाठ्य विशिष्टता,[11] एक प्रौद्योगिकी अनुकूलता किट और कार्यान्वयन उदाहरण। यह 1.0.0 के लिए टीसीके द्वारा सत्यापित अनेक अनुरूप कार्यान्वयनों के साथ आता है, जो वर्णानुक्रम में सूचीबद्ध हैं:[9]

अन्य कार्यान्वयनों में अपाचे कैसेंड्रा,[21] इलास्टिक्ससर्च,[22] अपाचे काफ्का,[23] समानांतर ब्रह्मांड क्वासर,[24] प्ले फ्रेमवर्क,[25] शस्त्रागार.[26]

स्प्रिंग 5 को प्रतिक्रियाशील धाराएँ संगत प्रतिक्रिया आन्तरक पर बनाने की घोषणा की गई है।

अमेज़ॅन (कंपनी) ने घोषणा की कि उसकी अमेज़न वेब सेवाएँ सॉफ़्टवेयर विकास किट संस्करण 2.0 में अपने क्लाइंट लाइब्रेरी में स्ट्रीमिंग क्षमताएं प्रदान करने के लिए प्रतिक्रियाशील धाराएँ का समर्थन करेगी। [27]

प्रतिक्रियाशील धाराएँ 1.0.1 9 अगस्त, 2017 को जारी किया गया है, जिसमें विनिर्देशन सटीकता, टीसीके सुधार और अन्य स्पष्टीकरण में विभिन्न सुधार सम्मलित हैं। विनिर्देश और इंटरफ़ेस 1.0.0 संस्करण के साथ पूरी तरह से पीछे की ओर संगत रहे, चूंकि इसका उद्देश्य भविष्य के कार्यान्वयनकर्ताओं के लिए अपनाने को सुव्यवस्थित करना और साथ ही ओपनजेडीके द्वारा निर्धारित कुछ अतिरिक्त आवश्यकताओं के साथ संरेखित करना था। [28]


पोर्ट ऐन्ड इन्फ्लूअन्स

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


उद्धरण

  1. "प्रतिक्रियाशील धाराएँ टीसीके". GitHub.
  2. 2.0 2.1 Walls 2019, pp. 243–245, §10.1.1 Defining Reactive Streams.
  3. "jdk9 Candidate classes Flow and SubmissionPublisher". Archived from the original on 2015-01-20. Retrieved 2015-12-23.
  4. "java.util.concurrent.Flow". Archived from the original on 2016-02-03. Retrieved 2015-12-23.
  5. 5.0 5.1 Reactive Streams Releases First Stable Version for JVM
  6. 6.0 6.1 JEP 266: More Concurrency Updates
  7. JEP 266: More Concurrency Updates
  8. Reactive Streams 1.0.0 – a new standard in reactive data processing
  9. 9.0 9.1 Reactive Streams 1.0.0 is here!
  10. Java API
  11. Reactive Streams for the JVM specification
  12. InfoQ: Reactive Streams with Akka Streams
  13. "अक्का स्ट्रीम के पीछे डिज़ाइन सिद्धांत". Archived from the original on 2016-01-12. Retrieved 2015-12-23.
  14. MongoDB Reactive Streams Java Driver
  15. Ratpack: The Reactive Streams API
  16. Reactor 2.0.0.RC1 with native Reactive Streams support now available!
  17. Advanced RxJava: The Reactive-Streams API (part 1)
  18. Slick 3: Reactive Streams for Asynchronous Database Access in Scala
  19. Slick 3.0.0
  20. Vert.x Reactive Streams Integration
  21. Accessing Cassandra in a Reactive Way
  22. elastic4s — Non blocking, type safe DSL and Scala client for Elasticsearch
  23. Reactive Streams for Apache Kafka
  24. "क्वासर और प्रतिक्रियाशील धाराएँ". Archived from the original on 2015-10-04. Retrieved 2015-12-24.
  25. Play Framework — Reactive Streams integration (experimental)
  26. Armeria - Completely asynchronous and reactive
  27. "AWS SDK for Java 2.0 developer preview announcement".
  28. "Reactive Streams 1.0.1 Release Announcement".
  29. "रिएक्टिव स्ट्रीम .NET". GitHub.
  30. "Elixir blog: Announcing GenStage".


संदर्भ

  •  This article incorporates text from www.reactive-streams.org, which is released under a CC0 1.0 Universal (CC0 1.0) Public Domain Dedication.