अक्का (टूलकिट)

From Vigyanwiki
Akka
Original author(s)Jonas Bonér
Developer(s)Lightbend
Initial releaseJuly 2009 (2009-07)
Stable release
2.6.19 / March 21, 2022; 2 years ago (2022-03-21)[1]
Written inScala
Operating systemCross-platform
PlatformJava Virtual Machine
Licensemultiple
Websiteakka.io

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

जावा (प्रोग्रामिंग लैंग्वेज) और स्काला (प्रोग्रामिंग लैंग्वेज) दोनों के लिए लैंग्वेज बाइंडिंग उपस्थित हैं। अक्का स्काला में लिखा गया है, और स्काला 2.10 के अनुसार, स्काला स्टैंडर्ड लाइब्रेरी में एक्टर्स को अक्का के पक्ष में डेप्रिकेट किया गया है।[3]

इतिहास

इसी प्रकार फिलिप हॉलर द्वारा लिखित एक एक्टर इम्प्लीमेंटेशन, स्काला 2.1.7 के भाग के रूप में जुलाई 2006 में ड्राईवेन किया गया था।[4] 2008 तक स्काला काम्प्लेक्स सर्वर ऍप्लिकेशन्स में उपयोग के लिए अट्रक्टिंग अटेंशन कर रहा था, लेकिन कॉन्करेन्सी अभी भी सामान्यतः थ्रेड बनाकर प्राप्त की जाती थी, जो मेमोरी साझा करती थी और लॉक का उपयोग करके आवश्यक होने पर सिंक्रनाइज़ होती थी। उस दृष्टिकोण की कठिनाइयों से अवगत और अत्यधिक कॉन्करेन्सी, इवेंट-ड्राईवेन ऍप्लिकेशन्स को लिखने के लिए एर्लांग प्रोग्रामिंग लैंग्वेज के लाइब्रेरी सपोर्ट से प्रेरित होकर, स्वीडिश प्रोग्रामर जोनास बोनर ने स्काला और जावा में समान क्षमताओं को लाने के लिए अक्का बनाया था, इसी प्रकार बोनर ने 2009 के प्रारंभिक में अक्का पर काम करना प्रारंभ किया था।[5] और उसी वर्ष जून में इसके लिए अपना दृष्टिकोण लिखा,[6] पहली पब्लिक रिलीज़ अक्का 0.5 थी, जिसकी घोषणा जनवरी 2010 में की गई थी। इसी प्रकार अक्का अब प्ले फ्रेमवर्क और स्काला प्रोग्रामिंग लैंग्वेज के साथ लाइटबैंड प्लेटफॉर्म का भाग है।

सितंबर 2022 में, लाइटबैंड ने घोषणा की कि अक्का अपने लाइसेंस को फ्री सॉफ्टवेयर लाइसेंस, अपाचे लाइसेंस 2.0 से एक प्रोप्रीएटरी सॉफ्टवेयर सोर्स-उपलब्ध लाइसेंस में परिवर्तित कर देता है। जिसे बिज़नेस सोर्स लाइसेंस (बीएसएल) के रूप में जाना जाता है। इसी प्रकार बीएसएल के अनुसार कोई भी नवीनतम कोड तीन साल के पश्चात अपाचे लाइसेंस के अनुसार उपलब्ध हो जाता है।

विशिष्ठ सुविधाएं

अक्का एक्टर्स पर आधारित ऍप्लिकेशन्स को भिन्न करने वाले मुख्य बिंदु हैं:

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

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

परियोजना संरचना

विक्टर क्लैंग सितंबर 2011 में अक्का परियोजना के लिए तकनीकी प्रमुख बन गए थे, इसी प्रकार जब दिसंबर 2012 में विक्टर लाइटबैंड में इंजीनियरिंग के निदेशक बने, तो रोलैंड कुह्न अक्का के लिए तकनीकी प्रमुख बन गए थे, विकास का मुख्य भाग लाइटबैंड में नियोजित एक कोर टीम द्वारा किया जाता है,[7] जो एक सक्रिय समुदाय द्वारा समर्थित है।[8] वर्तमान जोर क्लस्टर (कंप्यूटिंग) सपोर्ट बढ़ाने पर है।

अन्य लाइब्रेरीों से संबंध

अक्का के आसपास एक पारिस्थितिकी मैकेनिज्म बनाने के लिए अन्य रूपरेखाएँ और टूलकिट इमरज्ड् हैं:

  • स्प्रे टूलकिट[9] को अक्का का उपयोग करके इम्प्लिमेंटेड किया गया है, और इसमें एक एचटीटीपी सर्वर के साथ-साथ संबंधित सुविधाएं भी सम्मलित हैं, जैसे कि रेस्टफुल अप्लिकेशन प्रोग्रामिंग इंटरफ़ेस बनाने के लिए एक डोमेन-विशिष्ट लैंग्वेज (डीएसएल) होता है।
  • वेब एप्लिकेशन विकसित करने के लिए प्ले फ्रेमवर्क अक्का के साथ एकीकरण प्रदान करता है।[10]
  • संस्करण 1.6 तक, स्पार्क (क्लस्टर कंप्यूटिंग फ्रेमवर्क) ने नोड्स के बीच संचार के लिए अक्का का उपयोग किया था।[11]
  • सोको वेब सर्वर लाइब्रेरी अक्का ऍप्लिकेशन्स के लिए रेस्ट एपीआई के इम्प्लीमेंटेशन का सपोर्ट करती है।[12]
  • इवेंट सोर्स[13] लाइब्रेरी अक्का एक्टर्स के लिए इवेंट-ड्राईवेन आर्किटेक्चर (डोमेन-ड्राईवेन डिज़ाइन भी देख सकते है) सपोर्ट प्रदान करती है।
  • लोड-परीक्षण वेब सर्वर के लिए गैटलिंग (सॉफ्टवेयर) स्ट्रेस परीक्षण उपकरण अक्का पर बनाया गया है।[14]
  • स्कालाट्रा वेब फ्रेमवर्क अक्का के साथ एकीकरण की प्रस्तुत करता है।[15]
  • वाडिन वेब ऐप डेवलपमेंट फ्रेमवर्क अक्का के साथ एकीकृत हो सकता है।[16]
  • अपाचे फ़्लिंक (डिस्ट्रीब्यूशन स्ट्रीम और बैच डेटा प्रोसेसिंग के लिए प्लेटफ़ॉर्म) आरपीसी सिस्टम अक्का का उपयोग करके बनाया गया है।[17] लेकिन v1.14 से भिन्न किया गया है।[18]
  • प्रतिक्रियाशील माइक्रोसर्विसेज के निर्माण के लिए लैगोम फ्रेमवर्क अक्का के शीर्ष पर लागू किया गया है।[19]

GitHub पर 250 से अधिक पब्लिक प्रोजेक्ट्स पंजीकृत हैं, जो अक्का का उपयोग करती हैं।[20]

अक्का के बारे में प्रकाशन

अक्का के बारे में कई किताबें हैं जैसे:

  • अक्का एसेंशियल्स[21]
  • अक्का कोड उदाहरण
  • अक्का कंकरेंसी[22]
  • जैएक्शन में अक्का[23]
  • इफेक्टिव अक्का[24]
  • अक्का 2.0 के साथ कंपोजेबल फ्यूचर्स, जिसमें जावा, स्काला और अक्का कोड उदाहरण सम्मलित हैं[25]

इसी प्रकार अक्का इसमें भी सम्मलित हैं:

  • पी. हॉलर की "एक्टर्स इन स्काला"[26]
  • एन. रायचौधुरी की "स्काला इन एक्शन"[27]
  • डी. वैम्पलर की "जावा डेवलपर्स के लिए फंक्शनल प्रोग्रामिंग"[28]
  • ए अलेक्जेंडर की "स्काला कुकबुक"[29]
  • वी. सुब्रमण्यम की "प्रोग्रामिंग कॉनकरेंसी ऑन द जेवीएम"[30]
  • एम. बर्नहार्ट का "रिएक्टिव वेब एप्लिकेशन"[31]

अक्का के व्यावसायिक उपयोग का वर्णन करने वाले कई वेब लेखों के अतिरिक्त,[32][33] इसके बारे में अवलोकन लेख भी हैं।[34][35]

संदर्भ

  1. Akka Team. "Akka 2.6.19 Released". Retrieved 5 August 2022.
  2. Akka Team. "स्काला अभिनेता परिचय". Retrieved 17 September 2018.
  3. Jovanovic, Vojin. "स्काला एक्टर्स माइग्रेशन गाइड". Archived from the original on 5 December 2013. Retrieved 13 March 2013.
  4. "स्काला संस्करण इतिहास - पुराने संस्करण". scala-lang.org. 2009-02-16. Archived from the original on 2013-01-04.
  5. Jonas Bonér (2009-02-16). "init प्रोजेक्ट सेटअप". github.com.
  6. Jonas Bonér (2009-07-12). "v0.5". github.com.
  7. "एक टीम के रूप में". akka.io. Retrieved 6 June 2013.
  8. "योगदानकर्ताओं की सूची के रूप में". github.com. Retrieved 6 June 2013.
  9. Doenitz, Mathias. "स्प्रे टूलकिट". spray.io. Retrieved 6 June 2013.
  10. "Play framework documentation: Integrating with Akka". playframework.com. Retrieved 6 June 2013.
  11. "स्पार्क परियोजना स्रोत". github.com. Retrieved 6 June 2013.
  12. "सोको वेब सर्वर". sockoweb.org. Retrieved 6 June 2013.
  13. "इवेंटसोर्स्ड लाइब्रेरी". eligosource. Retrieved 6 June 2013.
  14. "गैटलिंग तनाव परीक्षण उपकरण". github.com. Retrieved 6 June 2013.
  15. "जैसे-स्कैलाट्रा". scalatra.org. Retrieved 2022-10-06.
  16. "अक्का में वादिन". Vaadin.com. Retrieved 26 April 2014.
  17. "अपाचे फ्लिंक - जीत के लिए लाइक करें!". flink.apache.org. Retrieved 2 December 2015.
  18. "Apache Flink: Scala Free in One Fifteen". flink.apache.org. Retrieved 2022-04-22.
  19. "Lagom - Integrating with Akka".
  20. Tasharofi, Samira. "GitHub पर एक अभिनेता प्रोजेक्ट कॉर्पस के रूप में". cs.illinois.edu. Archived from the original on 2012-10-30. Retrieved 2013-06-06.
  21. Gupta, Munish K. (2012). आवश्यक चीजों की तरह. Packt Publishing. p. 334. ISBN 978-1849518284.
  22. Wyatt, Derek (2013). कॉन्करेंसी की तरह. Artima. p. 521. ISBN 978-0981531663.
  23. Roestenburg, Raymond (2013). जैसा कि एक्शन में है. Manning Publications. p. 475. ISBN 978-1617291012.
  24. Allen, Jamie (2013). के रूप में प्रभावी. O'Reilly Media. p. 74. ISBN 978-1449360078.
  25. Slinn, Michael (2012). Composable Futures with Akka 2.0. Micronautics Research. p. 178. ISBN 978-0984278923.
  26. Haller, Philipp (2012). स्काला में अभिनेता. Artima. p. 169. ISBN 978-0981531656.
  27. Raychaudhuri, Nilanjan (2013). एक्शन में स्काला. Manning Publications. p. 416. ISBN 978-1935182757.
  28. Wampler, Dean (2011). जावा डेवलपर्स के लिए कार्यात्मक प्रोग्रामिंग. O'Reilly Media. pp. 90. ISBN 978-1449311032.
  29. Alexander, Alvin (2013). स्काला कुकबुक. O'Reilly Media. p. 722. ISBN 978-1449339616.
  30. Subramaniam, Venkat (2011). Programming Concurrency on the JVM: Mastering Synchronization, STM, and Actors. Pragmatic Bookshelf. pp. 280. ISBN 978-1934356760.
  31. Bernhardt, Manuel (2016). Reactive Web Applications: Covers Play, Akka and Reactive Streams. Manning Publications. p. 328. ISBN 9781633430099.
  32. Darrow, Barb (25 June 2012). "जुनिपर नेटवर्क स्काला के साथ साइन इन करता है". gigaom.com. Retrieved 8 June 2013.
  33. Ross, David. "स्काला, अक्का और प्ले के साथ क्लाउट एपीआई को स्केल करना". Retrieved 8 June 2013.
  34. Haines, Stephen (May 8, 2013). "Open source Java projects: Akka". JavaWorld. Retrieved 2020-07-15.
  35. "Java Magazin 6.13". jaxenter.de. Archived from the original on 13 August 2013. Retrieved 8 June 2013.


बाहरी संबंध