एन्ट्रॉपी (कंप्यूटिंग): Difference between revisions
(Created page with "{{Short description|Computing concept}} {{other uses|Entropy (disambiguation)}} कम्प्यूटिंग में, एन्ट्रापी एक ऑप...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{Short description|Computing concept}} | {{Short description|Computing concept}} | ||
{{other uses| | {{other uses|एन्ट्रॉपी (डिसऐम्बिगुएशन)}} | ||
[[ कम्प्यूटिंग ]] में, एन्ट्रापी एक ऑपरेटिंग सिस्टम या एप्लिकेशन द्वारा क्रिप्टोग्राफी या अन्य उपयोगों में उपयोग के लिए एकत्र की गई | [[ कम्प्यूटिंग |कम्प्यूटिंग]] में, एन्ट्रापी एक ऑपरेटिंग सिस्टम या एप्लिकेशन द्वारा क्रिप्टोग्राफी या अन्य उपयोगों में उपयोग के लिए रैंडमनैस एकत्र की गई है जिसके लिए रैंडम डेटा की आवश्यकता होती है। यह रैंडमनैस अक्सर हार्डवेयर स्रोतों (पंखे के शोर या एचडीडी में भिन्नता) से एकत्र की जाती है, या तो पहले से मौजूद स्रोतों जैसे कि माउस मूवमेंट या विशेष रूप से प्रदान किए गए रैंडमनैस जनरेटर से भी एकत्र कर सकते है, एन्ट्रापी की कमी परफॉरमेंस और सिक्योरिटी पर नेगेटिव प्रभाव डाल सकती है। | ||
== [[लिनक्स कर्नेल]] == | == [[लिनक्स कर्नेल]] == | ||
लिनक्स कर्नेल [[कीबोर्ड (कंप्यूटिंग)]] टाइमिंग, [[माउस (कंप्यूटिंग)]] मूवमेंट और इंटीग्रेटेड ड्राइव इलेक्ट्रॉनिक्स (आईडीई) टाइमिंग से एन्ट्रापी उत्पन्न करता है और [[विशेष फ़ाइल]]ों /dev/random और /dev/ के माध्यम से अन्य ऑपरेटिंग सिस्टम प्रक्रियाओं के लिए | लिनक्स कर्नेल [[कीबोर्ड (कंप्यूटिंग)]] टाइमिंग, [[माउस (कंप्यूटिंग)]] मूवमेंट और इंटीग्रेटेड ड्राइव इलेक्ट्रॉनिक्स (आईडीई) टाइमिंग से एन्ट्रापी उत्पन्न करता है और [[विशेष फ़ाइल]]ों /dev/random और /dev/ के माध्यम से अन्य ऑपरेटिंग सिस्टम प्रक्रियाओं के लिए रैंडम वर्ण डेटा उपलब्ध कराता है। urandom. यह क्षमता लिनक्स संस्करण 1.3.30 में पेश की गई थी।<ref>[http://linux.die.net/man/4/random random(4) - Linux man page] {{Webarchive|url=https://web.archive.org/web/20071011084043/http://linux.die.net/man/4/random |date=2007-10-11 }} (die.net)</ref> | ||
कुछ लिनक्स कर्नेल पैच हैं जो किसी को अधिक एन्ट्रापी स्रोतों का उपयोग करने की अनुमति देते हैं।<ref>{{Cite web|url=https://ramcq.net/2005/09/25/missing-entropy/|title=Robotic Tendencies » Missing entropy|access-date=2023-05-23|archive-date=2022-12-06|archive-url=https://web.archive.org/web/20221206164925/https://ramcq.net/2005/09/25/missing-entropy/|url-status=live}}</ref> Audio_entropyd परियोजना,<ref>{{Cite web|url=https://www.vanheusden.com/aed/|title=ऑडियो एन्ट्रॉपी डेमॉन|date=March 23, 2021|archive-url=https://web.archive.org/web/20210323204108/https://www.vanheusden.com/aed/ |archive-date=2021-03-23 }}</ref> जो कुछ ऑपरेटिंग सिस्टम जैसे कि [[फेडोरा (ऑपरेटिंग सिस्टम)]] में शामिल है, ऑडियो डेटा को एन्ट्रापी स्रोत के रूप में उपयोग करने की अनुमति देता है।<ref>{{Cite web|url=https://admin.fedoraproject.org/pkgdb/packages/name/audio-entropyd|title=Fedora Package Database – audio-entropyd}}{{Dead link|date=August 2019 |bot=InternetArchiveBot |fix-attempted=yes }}</ref> video_entropyd भी उपलब्ध हैं,<ref>{{Cite web|url=https://www.vanheusden.com/ved/|title=video_entropyd|date=March 23, 2021|archive-url=https://web.archive.org/web/20210323190233/https://www.vanheusden.com/ved/ |archive-date=2021-03-23 }}</ref> जो एक वीडियो-स्रोत और एन्ट्रॉपीब्रोकर से | कुछ लिनक्स कर्नेल पैच हैं जो किसी को अधिक एन्ट्रापी स्रोतों का उपयोग करने की अनुमति देते हैं।<ref>{{Cite web|url=https://ramcq.net/2005/09/25/missing-entropy/|title=Robotic Tendencies » Missing entropy|access-date=2023-05-23|archive-date=2022-12-06|archive-url=https://web.archive.org/web/20221206164925/https://ramcq.net/2005/09/25/missing-entropy/|url-status=live}}</ref> Audio_entropyd परियोजना,<ref>{{Cite web|url=https://www.vanheusden.com/aed/|title=ऑडियो एन्ट्रॉपी डेमॉन|date=March 23, 2021|archive-url=https://web.archive.org/web/20210323204108/https://www.vanheusden.com/aed/ |archive-date=2021-03-23 }}</ref> जो कुछ ऑपरेटिंग सिस्टम जैसे कि [[फेडोरा (ऑपरेटिंग सिस्टम)]] में शामिल है, ऑडियो डेटा को एन्ट्रापी स्रोत के रूप में उपयोग करने की अनुमति देता है।<ref>{{Cite web|url=https://admin.fedoraproject.org/pkgdb/packages/name/audio-entropyd|title=Fedora Package Database – audio-entropyd}}{{Dead link|date=August 2019 |bot=InternetArchiveBot |fix-attempted=yes }}</ref> video_entropyd भी उपलब्ध हैं,<ref>{{Cite web|url=https://www.vanheusden.com/ved/|title=video_entropyd|date=March 23, 2021|archive-url=https://web.archive.org/web/20210323190233/https://www.vanheusden.com/ved/ |archive-date=2021-03-23 }}</ref> जो एक वीडियो-स्रोत और एन्ट्रॉपीब्रोकर से रैंडम डेटा की गणना करता है,<ref>{{Cite web|url=https://www.vanheusden.com/entropybroker/|title=एन्ट्रॉपी ब्रोकर|date=May 29, 2020|archive-url=https://web.archive.org/web/20200529190837/https://www.vanheusden.com/entropybroker/ |archive-date=2020-05-29 }}</ref> जिसमें ये तीनों शामिल [[है]]ं और इनका उपयोग एन्ट्रापी डेटा को उन प्रणालियों में वितरित करने के लिए किया जा सकता है जो इनमें से किसी को भी चलाने में सक्षम नहीं हैं (जैसे [[आभाषी दुनिया]])। इसके अलावा, कोई [[हेज्ड]] टू पूल एन्ट्रॉपी के माध्यम से HAVEGE एल्गोरिदम का उपयोग कर सकता है।<ref>{{cite web|title=haveged – A simple entropy daemon|url=http://www.issihosts.com/haveged/|accessdate=3 April 2011|archive-date=27 October 2012|archive-url=https://web.archive.org/web/20121027075229/http://www.issihosts.com/haveged/|url-status=live}}</ref> कुछ प्रणालियों में, नेटवर्क इंटरप्ट का उपयोग एन्ट्रापी स्रोत के रूप में भी किया जा सकता है।<ref>{{Cite web|url=https://linuxlink.timesys.com/docs/about_entropy|title=Entropy and Random Devices {{pipe}} LinuxLink by TimeSys – Your Embedded Linux Resource|access-date=2007-10-15|archive-date=2016-04-02|archive-url=https://web.archive.org/web/20160402010703/https://linuxlink.timesys.com/docs/about_entropy|url-status=dead}}</ref> | ||
== ओपनबीएसडी कर्नेल == | == ओपनबीएसडी कर्नेल == | ||
{{main | OpenBSD security features}} | {{main | OpenBSD security features}} | ||
[[ओपनबीएसडी]] ने क्रिप्टोग्राफी को अपने मुख्य लक्ष्यों में से एक के रूप में एकीकृत किया है और हमेशा एन्क्रिप्शन के लिए अपनी एन्ट्रापी को बढ़ाने पर काम किया है, लेकिन इसके कर्नेल के विभिन्न आंतरिक संचालन सहित ओएस के कई हिस्सों को | [[ओपनबीएसडी]] ने क्रिप्टोग्राफी को अपने मुख्य लक्ष्यों में से एक के रूप में एकीकृत किया है और हमेशा एन्क्रिप्शन के लिए अपनी एन्ट्रापी को बढ़ाने पर काम किया है, लेकिन इसके कर्नेल के विभिन्न आंतरिक संचालन सहित ओएस के कई हिस्सों को रैंडम बनाने के लिए भी काम किया है। 2011 के आसपास, दो रैंडम उपकरणों को हटा दिया गया और एक ही स्रोत से जोड़ दिया गया क्योंकि यह एक औसत सिस्टम पर प्रति सेकंड सैकड़ों मेगाबाइट उच्च गुणवत्ता वाले रैंडम डेटा का उत्पादन कर सकता था।{{clarify|date=September 2022}} इससे ओपनबीएसडी पर उपयोगकर्तालैंड कार्यक्रमों द्वारा रैंडम डेटा की कमी असंभव हो गई, जब शुरू में पर्याप्त एन्ट्रापी एकत्र हो गई थी। | ||
== [[हर्ड]] कर्नेल == | == [[हर्ड]] कर्नेल == | ||
हर्ड कर्नेल के लिए लिनक्स कर्नेल से पोर्ट किया गया ड्राइवर उपलब्ध कराया गया है।<ref>[http://ibofobi.dk/stuff/hurd-entropy/ /dev/{,u}random driver for GNU/Hurd] {{Webarchive|url=https://web.archive.org/web/20070918135155/http://ibofobi.dk/stuff/hurd-entropy/ |date=2007-09-18 }} (ibofobi.dk)</ref> | हर्ड कर्नेल के लिए लिनक्स कर्नेल से पोर्ट किया गया ड्राइवर उपलब्ध कराया गया है।<ref>[http://ibofobi.dk/stuff/hurd-entropy/ /dev/{,u}random driver for GNU/Hurd] {{Webarchive|url=https://web.archive.org/web/20070918135155/http://ibofobi.dk/stuff/hurd-entropy/ |date=2007-09-18 }} (ibofobi.dk)</ref> | ||
== सोलारिस == | == सोलारिस == | ||
/dev/random और /dev/urandom सोलारिस 2.6 के बाद से [[सोलारिस (ऑपरेटिंग सिस्टम)]] के लिए सन पैकेज या पैच के रूप में उपलब्ध हैं।<ref name="Solaris_devrandom">{{Cite web|url=http://www.cosy.sbg.ac.at/%7Eandi/SUNrand/|title=अनुकरण के माध्यम से सोलारिस /डेव/रैंडम|access-date=2007-10-15|archive-date=2007-11-04|archive-url=https://web.archive.org/web/20071104145929/http://www.cosy.sbg.ac.at/~andi/SUNrand/|url-status=live}}</ref> और सोलारिस 9 के बाद से यह एक मानक सुविधा रही है। रेफरी>{{Cite web |url=http://docs.sun.com/app/docs/doc/816-5177/random-7d?a=view |title=सोलारिस /देव/यादृच्छिक|access-date=2007-10-17 |archive-url=https://web.archive.org/web/20080511121018/http://docs.sun.com/app/docs/doc/816-5177/random-7d?a=view |archive-date=2008-05-11 |url-status=dead }}</ref> सोलारिस 10 के अनुसार, प्रशासक मौजूदा एन्ट्रापी स्रोतों को हटा सकते हैं या कर्नेल-स्तरीय क्रिप्टोग्राफ़िक ढांचे के माध्यम से नए स्रोतों को परिभाषित कर सकते हैं। | /dev/random और /dev/urandom सोलारिस 2.6 के बाद से [[सोलारिस (ऑपरेटिंग सिस्टम)]] के लिए सन पैकेज या पैच के रूप में उपलब्ध हैं।<ref name="Solaris_devrandom">{{Cite web|url=http://www.cosy.sbg.ac.at/%7Eandi/SUNrand/|title=अनुकरण के माध्यम से सोलारिस /डेव/रैंडम|access-date=2007-10-15|archive-date=2007-11-04|archive-url=https://web.archive.org/web/20071104145929/http://www.cosy.sbg.ac.at/~andi/SUNrand/|url-status=live}}</ref> और सोलारिस 9 के बाद से यह एक मानक सुविधा रही है। रेफरी>{{Cite web |url=http://docs.sun.com/app/docs/doc/816-5177/random-7d?a=view |title=सोलारिस /देव/यादृच्छिक|access-date=2007-10-17 |archive-url=https://web.archive.org/web/20080511121018/http://docs.sun.com/app/docs/doc/816-5177/random-7d?a=view |archive-date=2008-05-11 |url-status=dead }}</ref> सोलारिस 10 के अनुसार, प्रशासक मौजूदा एन्ट्रापी स्रोतों को हटा सकते हैं या कर्नेल-स्तरीय क्रिप्टोग्राफ़िक ढांचे के माध्यम से नए स्रोतों को परिभाषित कर सकते हैं। | ||
सोलारिस 2.4 से पहले के रिलीज के लिए /dev/random को लागू करने वाला एक तृतीय-पक्ष कर्नेल मॉड्यूल भी उपलब्ध है।<ref name="Solaris_devrandom"/> | सोलारिस 2.4 से पहले के रिलीज के लिए /dev/random को लागू करने वाला एक तृतीय-पक्ष कर्नेल मॉड्यूल भी उपलब्ध है।<ref name="Solaris_devrandom"/> | ||
== ओएस/2 == | == ओएस/2 == | ||
OS/2 के लिए एक सॉफ़्टवेयर पैकेज है जो सॉफ़्टवेयर प्रक्रियाओं को | OS/2 के लिए एक सॉफ़्टवेयर पैकेज है जो सॉफ़्टवेयर प्रक्रियाओं को रैंडम डेटा पुनर्प्राप्त करने की अनुमति देता है।<ref>{{Cite web|url=http://r6.ca/RexxEGD/|title=Rexx Entropy Gathering Daemon for OS/2|website=r6.ca|access-date=2007-10-15|archive-date=2007-10-31|archive-url=https://web.archive.org/web/20071031220059/http://r6.ca/RexxEGD/|url-status=live}}</ref> | ||
== खिड़कियाँ == | == खिड़कियाँ == | ||
[[ माइक्रोसॉफ़्ट विंडोज़ ]]़ विंडोज़ 95 की तुलना में नई रिलीज़ करता है जो लिनक्स कर्नेल के /dev/random के समान एन्ट्रापी इकट्ठा करने के लिए [[माइक्रोसॉफ्ट क्रिप्टोएपीआई]] का उपयोग करता है।<ref>{{Cite web|url=https://lists.gnupg.org/pipermail/gnupg-users/2001-November/010831.html|title=विंडोज़ के लिए जीपीएल कमांड-लाइन श्रेड विकल्प|first=Ryan|last=Malayter|date=November 9, 2001|access-date=May 23, 2023|archive-date=October 27, 2021|archive-url=https://web.archive.org/web/20211027215112/https://lists.gnupg.org/pipermail/gnupg-users/2001-November/010831.html|url-status=live}}</ref> | [[ माइक्रोसॉफ़्ट विंडोज़ ]]़ विंडोज़ 95 की तुलना में नई रिलीज़ करता है जो लिनक्स कर्नेल के /dev/random के समान एन्ट्रापी इकट्ठा करने के लिए [[माइक्रोसॉफ्ट क्रिप्टोएपीआई]] का उपयोग करता है।<ref>{{Cite web|url=https://lists.gnupg.org/pipermail/gnupg-users/2001-November/010831.html|title=विंडोज़ के लिए जीपीएल कमांड-लाइन श्रेड विकल्प|first=Ryan|last=Malayter|date=November 9, 2001|access-date=May 23, 2023|archive-date=October 27, 2021|archive-url=https://web.archive.org/web/20211027215112/https://lists.gnupg.org/pipermail/gnupg-users/2001-November/010831.html|url-status=live}}</ref> | ||
विंडोज़ का क्रिप्टोएपीआई अपने सभी एन्ट्रापी स्रोतों से एक बीजित मूल्य को संग्रहीत करने के लिए बाइनरी [[विंडोज़ रजिस्ट्री]] कुंजी HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography\RNG\Seed का उपयोग करता है।<ref>{{Cite web|url=https://www.mail-archive.com/openssl-dev@openssl.org/msg21829.html|title=क्रिप्टोएपीआई स्थापित के साथ विंडोज प्लेटफॉर्म पर एन्ट्रापी के लिए स्रोत|website=www.mail-archive.com|access-date=2023-05-23|archive-date=2018-10-02|archive-url=https://web.archive.org/web/20181002020158/https://www.mail-archive.com/openssl-dev@openssl.org/msg21829.html|url-status=live}}</ref> | विंडोज़ का क्रिप्टोएपीआई अपने सभी एन्ट्रापी स्रोतों से एक बीजित मूल्य को संग्रहीत करने के लिए बाइनरी [[विंडोज़ रजिस्ट्री]] कुंजी HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography\RNG\Seed का उपयोग करता है।<ref>{{Cite web|url=https://www.mail-archive.com/openssl-dev@openssl.org/msg21829.html|title=क्रिप्टोएपीआई स्थापित के साथ विंडोज प्लेटफॉर्म पर एन्ट्रापी के लिए स्रोत|website=www.mail-archive.com|access-date=2023-05-23|archive-date=2018-10-02|archive-url=https://web.archive.org/web/20181002020158/https://www.mail-archive.com/openssl-dev@openssl.org/msg21829.html|url-status=live}}</ref> | ||
क्योंकि क्रिप्टोएपीआई बंद-स्रोत है, विंडोज़ प्लेटफ़ॉर्म पर चलने वाले कुछ मुफ़्त और खुले स्रोत सॉफ़्टवेयर एप्लिकेशन | क्योंकि क्रिप्टोएपीआई बंद-स्रोत है, विंडोज़ प्लेटफ़ॉर्म पर चलने वाले कुछ मुफ़्त और खुले स्रोत सॉफ़्टवेयर एप्लिकेशन रैंडमनैस प्राप्त करने के लिए अन्य उपायों का उपयोग करते हैं। उदाहरण के लिए, जीएनयूपीजी, संस्करण 1.06 के अनुसार, विभिन्न स्रोतों का उपयोग करता है जैसे कि मेमोरी में मुफ्त बाइट्स की संख्या जो एक रैंडम बीज के साथ मिलकर वांछित रैंडमनैस उत्पन्न करती है जिसकी उसे आवश्यकता होती है।<ref>{{Cite web|url=https://lists.gnupg.org/pipermail/gnupg-users/2002-February/011909.html|title=How does Windows GnuPG generate random numbers on keygen?|first=Ryan|last=Malayter|date=February 15, 2002|access-date=May 23, 2023|archive-date=December 1, 2021|archive-url=https://web.archive.org/web/20211201124427/https://lists.gnupg.org/pipermail/gnupg-users/2002-February/011909.html|url-status=live}}</ref> | ||
CAPI का उपयोग करने वाले प्रोग्रामर इसे ठीक से आरंभ करने के बाद CAPI के [[CryptGenRandom]]() को कॉल करके एन्ट्रापी प्राप्त कर सकते हैं।<ref>{{Cite web|url=https://archives.seul.org/or/cvs/Mar-2004/msg00078.html|title=[or-cvs] Get entropy in windows.|website=archives.seul.org|access-date=2023-05-23|archive-date=2013-05-07|archive-url=https://web.archive.org/web/20130507182643/http://archives.seul.org/or/cvs/Mar-2004/msg00078.html|url-status=live}}</ref> | CAPI का उपयोग करने वाले प्रोग्रामर इसे ठीक से आरंभ करने के बाद CAPI के [[CryptGenRandom]]() को कॉल करके एन्ट्रापी प्राप्त कर सकते हैं।<ref>{{Cite web|url=https://archives.seul.org/or/cvs/Mar-2004/msg00078.html|title=[or-cvs] Get entropy in windows.|website=archives.seul.org|access-date=2023-05-23|archive-date=2013-05-07|archive-url=https://web.archive.org/web/20130507182643/http://archives.seul.org/or/cvs/Mar-2004/msg00078.html|url-status=live}}</ref> | ||
क्रिप्टोएपीआई को [[विंडोज विस्टा]] और उच्चतर से हटा दिया गया था। नई एपीआई को क्रिप्टोग्राफी एपीआई: नेक्स्ट जेनरेशन (सीएनजी) कहा जाता है।<ref>{{cite web | url=https://msdn.microsoft.com/en-us/library/windows/desktop/aa375276(v=vs.85).aspx | title=About CNG - Win32 apps | access-date=2018-05-17 | archive-date=2018-05-17 | archive-url=https://web.archive.org/web/20180517152950/https://msdn.microsoft.com/en-us/library/windows/desktop/aa375276(v=vs.85).aspx | url-status=live }}</ref> विंडोज़ का सीएनजी बीजित मूल्य को संग्रहीत करने के लिए बाइनरी विंडोज़ रजिस्ट्री कुंजी HKEY_LOCAL_MACHINE\SYSTEM\RNG\Seed का उपयोग करता है। | क्रिप्टोएपीआई को [[विंडोज विस्टा]] और उच्चतर से हटा दिया गया था। नई एपीआई को क्रिप्टोग्राफी एपीआई: नेक्स्ट जेनरेशन (सीएनजी) कहा जाता है।<ref>{{cite web | url=https://msdn.microsoft.com/en-us/library/windows/desktop/aa375276(v=vs.85).aspx | title=About CNG - Win32 apps | access-date=2018-05-17 | archive-date=2018-05-17 | archive-url=https://web.archive.org/web/20180517152950/https://msdn.microsoft.com/en-us/library/windows/desktop/aa375276(v=vs.85).aspx | url-status=live }}</ref> विंडोज़ का सीएनजी बीजित मूल्य को संग्रहीत करने के लिए बाइनरी विंडोज़ रजिस्ट्री कुंजी HKEY_LOCAL_MACHINE\SYSTEM\RNG\Seed का उपयोग करता है। | ||
Line 43: | Line 35: | ||
* व्यवधान का समय | * व्यवधान का समय | ||
* कीबोर्ड टाइमिंग और माउस मूवमेंट<ref>{{Cite web|url=https://docs.microsoft.com/en-us/windows/win32/api/wincrypt/nf-wincrypt-cryptgenrandom|title=CryptGenRandom function (Wincrypt.h) - Win32 apps|access-date=2020-08-31|archive-date=2020-08-12|archive-url=https://web.archive.org/web/20200812010334/https://docs.microsoft.com/en-us/windows/win32/api/wincrypt/nf-wincrypt-cryptgenrandom|url-status=live}}</ref> | * कीबोर्ड टाइमिंग और माउस मूवमेंट<ref>{{Cite web|url=https://docs.microsoft.com/en-us/windows/win32/api/wincrypt/nf-wincrypt-cryptgenrandom|title=CryptGenRandom function (Wincrypt.h) - Win32 apps|access-date=2020-08-31|archive-date=2020-08-12|archive-url=https://web.archive.org/web/20200812010334/https://docs.microsoft.com/en-us/windows/win32/api/wincrypt/nf-wincrypt-cryptgenrandom|url-status=live}}</ref> | ||
== एंबेडेड सिस्टम == | == एंबेडेड सिस्टम == | ||
[[अंतः स्थापित प्रणाली]] को पर्याप्त एन्ट्रापी इकट्ठा करने में कठिनाई होती है क्योंकि वे अक्सर कम बूट समय के साथ बहुत ही सरल उपकरण होते हैं, और कुंजी पीढ़ी के संचालन के लिए पर्याप्त एन्ट्रापी की आवश्यकता होती है जो अक्सर सिस्टम द्वारा की जाने वाली पहली चीजों में से एक होती है। सामान्य एन्ट्रापी स्रोत इन उपकरणों पर मौजूद नहीं हो सकते हैं, या बूट के दौरान पर्याप्त एन्ट्रापी मौजूद होने को सुनिश्चित करने के लिए पर्याप्त समय तक सक्रिय नहीं रहेंगे। एंबेडेड उपकरणों में अक्सर घूमने वाली डिस्क ड्राइव, मानव इंटरफ़ेस डिवाइस और यहां तक कि प्रशंसकों की कमी होती है, और नेटवर्क इंटरफ़ेस, यदि कोई हो, तो अधिक एन्ट्रॉपी प्रदान करने के लिए पर्याप्त समय तक सक्रिय नहीं होगा। एन्ट्रॉपी तक आसान पहुंच के अभाव में, कुछ डिवाइस रैंडम जेनरेटर को सीड करने के लिए हार्ड-कोडेड कुंजियों का उपयोग कर सकते हैं, या डिवाइस के मैक पते जैसे आसानी से अनुमानित अद्वितीय पहचानकर्ताओं से रैंडम जेनरेटर को सीड कर सकते हैं। एक साधारण अध्ययन{{which|date=January 2016}} समान कुंजियों का उपयोग करने वाले राउटर जैसे कई एम्बेडेड सिस्टम ढूंढकर कमजोर कुंजियों के व्यापक उपयोग का परफॉरमेंस किया। यह सोचा गया था कि यदि सरल और अक्सर हमलावर निर्धारित करने योग्य एक बार के विशिष्ट पहचानकर्ताओं को इनमें से कुछ प्रणालियों की एन्ट्रापी में शामिल नहीं किया गया होता, तो पाई गई कमजोर कुंजियों की संख्या कहीं अधिक होती।<ref>{{Cite news|url=https://www.networkworld.com/article/3009139/millions-of-embedded-devices-use-the-same-hard-coded-ssh-and-tls-private-keys.html|title=लाखों एम्बेडेड डिवाइस समान हार्ड-कोडेड एसएसएच और टीएलएस निजी कुंजी का उपयोग करते हैं|last=Constantin|first=Lucian|work=Network World|access-date=2018-11-05|language=en|archive-date=2018-11-05|archive-url=https://web.archive.org/web/20181105202614/https://www.networkworld.com/article/3009139/millions-of-embedded-devices-use-the-same-hard-coded-ssh-and-tls-private-keys.html|url-status=live}}</ref> | |||
[[अंतः स्थापित प्रणाली]] को पर्याप्त एन्ट्रापी इकट्ठा करने में कठिनाई होती है क्योंकि वे अक्सर कम बूट समय के साथ बहुत ही सरल उपकरण होते हैं, और कुंजी पीढ़ी के संचालन के लिए पर्याप्त एन्ट्रापी की आवश्यकता होती है जो अक्सर सिस्टम द्वारा की जाने वाली पहली चीजों में से एक होती है। सामान्य एन्ट्रापी स्रोत इन उपकरणों पर मौजूद नहीं हो सकते हैं, या बूट के दौरान पर्याप्त एन्ट्रापी मौजूद होने को सुनिश्चित करने के लिए पर्याप्त समय तक सक्रिय नहीं रहेंगे। एंबेडेड उपकरणों में अक्सर घूमने वाली डिस्क ड्राइव, मानव इंटरफ़ेस डिवाइस और यहां तक कि प्रशंसकों की कमी होती है, और नेटवर्क इंटरफ़ेस, यदि कोई हो, तो अधिक एन्ट्रॉपी प्रदान करने के लिए पर्याप्त समय तक सक्रिय नहीं होगा। एन्ट्रॉपी तक आसान पहुंच के अभाव में, कुछ डिवाइस रैंडम जेनरेटर को सीड करने के लिए हार्ड-कोडेड कुंजियों का उपयोग कर सकते हैं, या डिवाइस के मैक पते जैसे आसानी से अनुमानित अद्वितीय पहचानकर्ताओं से रैंडम जेनरेटर को सीड कर सकते हैं। एक साधारण अध्ययन{{which|date=January 2016}} समान कुंजियों का उपयोग करने वाले राउटर जैसे कई एम्बेडेड सिस्टम ढूंढकर कमजोर कुंजियों के व्यापक उपयोग का | |||
==(डी)केंद्रीकृत सिस्टम == | ==(डी)केंद्रीकृत सिस्टम == | ||
एक सच्चा | एक सच्चा रैंडम संख्या जनरेटर (टीआरएनजी) एक (डी) केंद्रीय सेवा हो सकता है। एक केंद्रीकृत प्रणाली का एक उदाहरण जहां एक रैंडम संख्या प्राप्त की जा सकती है वह राष्ट्रीय मानक और प्रौद्योगिकी संस्थान की रैंडमनैस बीकन सेवा है। कार्डानो प्लेटफ़ॉर्म रैंडम संख्याएँ उत्पन्न करने के लिए अपने विकेन्द्रीकृत [[-का-प्रमाण हिस्सेदारी]] प्रोटोकॉल के प्रतिभागियों का उपयोग करता है।<ref name="trg">{{cite web |title=स्केलेबल यादृच्छिकता के लिए एक समाधान|url=https://iohk.io/en/blog/posts/2017/06/06/a-solution-for-scalable-randomness/ |website=iohk.io |date=June 6, 2017 |accessdate=September 14, 2020 |quote=""|archive-date=April 17, 2021 |archive-url=https://web.archive.org/web/20210417212225/https://iohk.io/en/blog/posts/2017/06/06/a-solution-for-scalable-randomness/ |url-status=live }}</ref> | ||
== अन्य प्रणालियाँ == | == अन्य प्रणालियाँ == | ||
ऐसे कुछ सॉफ्टवेयर पैकेज हैं जो किसी को | ऐसे कुछ सॉफ्टवेयर पैकेज हैं जो किसी को रैंडम वर्णों को इकट्ठा करने के लिए यूजरस्पेस प्रक्रिया का उपयोग करने की अनुमति देते हैं, बिल्कुल वही जो /dev/random करता है, जैसे कि ईजीडी, एन्ट्रॉपी गैदरिंग डेमॉन।<ref>{{Cite web|url=https://dwheeler.com/secure-programs/Secure-Programs-HOWTO/random-numbers.html|title=यादृच्छिक संख्याएँ|website=dwheeler.com|access-date=2023-05-23|archive-date=2022-12-30|archive-url=https://web.archive.org/web/20221230212607/https://dwheeler.com/secure-programs/Secure-Programs-HOWTO/random-numbers.html|url-status=live}}</ref> | ||
== हार्डवेयर-उत्पन्न एन्ट्रापी == | == हार्डवेयर-उत्पन्न एन्ट्रापी == | ||
आधुनिक [[ CPU ]] और हार्डवेयर में अक्सर एकीकृत जनरेटर की सुविधा होती है जो ऑपरेटिंग सिस्टम को उच्च गुणवत्ता और उच्च गति एन्ट्रॉपी प्रदान कर सकते हैं। लिनक्स कर्नेल पर आधारित सिस्टम पर, कोई ऐसे डिवाइस से उत्पन्न एन्ट्रॉपी को /dev/hw_random के माध्यम से पढ़ सकता है।<ref>{{Cite web|url=https://marc.info/?l=kroupware&m=116377029100152&w=2|title='Re: SSL/TLS entropy problem,' - MARC|website=marc.info|access-date=2023-05-23|archive-date=2018-11-15|archive-url=https://web.archive.org/web/20181115224312/https://marc.info/?l=kroupware&m=116377029100152&w=2|url-status=live}}</ref> हालाँकि, कभी-कभी /dev/hw_random धीमा हो सकता है;<ref>{{Cite web|url=http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00770.html|title=Re: /dev/hw_random|access-date=2007-10-15|archive-date=2007-10-31|archive-url=https://web.archive.org/web/20071031091748/http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00770.html|url-status=dead}}</ref><ref>{{Cite web|url=http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00786.html|title=Re: /dev/hw_random|access-date=2007-10-15|archive-date=2007-11-12|archive-url=https://web.archive.org/web/20071112175917/http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00786.html|url-status=dead}}</ref> | आधुनिक [[ CPU |CPU]] और हार्डवेयर में अक्सर एकीकृत जनरेटर की सुविधा होती है जो ऑपरेटिंग सिस्टम को उच्च गुणवत्ता और उच्च गति एन्ट्रॉपी प्रदान कर सकते हैं। लिनक्स कर्नेल पर आधारित सिस्टम पर, कोई ऐसे डिवाइस से उत्पन्न एन्ट्रॉपी को /dev/hw_random के माध्यम से पढ़ सकता है।<ref>{{Cite web|url=https://marc.info/?l=kroupware&m=116377029100152&w=2|title='Re: SSL/TLS entropy problem,' - MARC|website=marc.info|access-date=2023-05-23|archive-date=2018-11-15|archive-url=https://web.archive.org/web/20181115224312/https://marc.info/?l=kroupware&m=116377029100152&w=2|url-status=live}}</ref> हालाँकि, कभी-कभी /dev/hw_random धीमा हो सकता है;<ref>{{Cite web|url=http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00770.html|title=Re: /dev/hw_random|access-date=2007-10-15|archive-date=2007-10-31|archive-url=https://web.archive.org/web/20071031091748/http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00770.html|url-status=dead}}</ref><ref>{{Cite web|url=http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00786.html|title=Re: /dev/hw_random|access-date=2007-10-15|archive-date=2007-11-12|archive-url=https://web.archive.org/web/20071112175917/http://www.redhat.com/archives/rhl-devel-list/2004-August/msg00786.html|url-status=dead}}</ref> | ||
कुछ कंपनियां एन्ट्रॉपी जेनरेशन डिवाइस बनाती हैं, और उनमें से कुछ को लिनक्स के लिए ड्राइवरों के साथ भेजा जाता है।<ref>{{Cite web |url=http://www.std.com/~reinhold/truenoise.html |title=यादृच्छिक शोर स्रोत|access-date=2007-10-15 |archive-date=2007-11-21 |archive-url=https://web.archive.org/web/20071121080813/http://www.std.com/~reinhold/truenoise.html |url-status=live }}</ref><ref>http://random.com.hr/products/random/hg324.html {{Webarchive|url=https://web.archive.org/web/20080513052740/http://random.com.hr/products/random/hg324.html |date=2008-05-13 }}</ref> | कुछ कंपनियां एन्ट्रॉपी जेनरेशन डिवाइस बनाती हैं, और उनमें से कुछ को लिनक्स के लिए ड्राइवरों के साथ भेजा जाता है।<ref>{{Cite web |url=http://www.std.com/~reinhold/truenoise.html |title=यादृच्छिक शोर स्रोत|access-date=2007-10-15 |archive-date=2007-11-21 |archive-url=https://web.archive.org/web/20071121080813/http://www.std.com/~reinhold/truenoise.html |url-status=live }}</ref><ref>http://random.com.hr/products/random/hg324.html {{Webarchive|url=https://web.archive.org/web/20080513052740/http://random.com.hr/products/random/hg324.html |date=2008-05-13 }}</ref> | ||
लिनक्स सिस्टम पर, कोई आरएनजी-टूल्स पैकेज इंस्टॉल कर सकता है<ref>{{Cite web |url=http://packages.debian.org/unstable/utils/आरएनजी-उपकरण|title=आरएनजी-उपकरण|access-date=2007-10-16 |archive-date=2007-10-21 |archive-url=https://web.archive.org/web/20071021031120/http://packages.debian.org/unstable/utils/आरएनजी-उपकरण|url-status=live }}</ref> जो RDRAND निर्देश, विश्वसनीय प्लेटफ़ॉर्म मॉड्यूल और कुछ [[Intel]], [[AMD]], या [[VIA Technologies]] [[चिपसेट]] का समर्थन करने वाले CPU में पाए जाने वाले वास्तविक | लिनक्स सिस्टम पर, कोई आरएनजी-टूल्स पैकेज इंस्टॉल कर सकता है<ref>{{Cite web |url=http://packages.debian.org/unstable/utils/आरएनजी-उपकरण|title=आरएनजी-उपकरण|access-date=2007-10-16 |archive-date=2007-10-21 |archive-url=https://web.archive.org/web/20071021031120/http://packages.debian.org/unstable/utils/आरएनजी-उपकरण|url-status=live }}</ref> जो RDRAND निर्देश, विश्वसनीय प्लेटफ़ॉर्म मॉड्यूल और कुछ [[Intel]], [[AMD]], या [[VIA Technologies]] [[चिपसेट]] का समर्थन करने वाले CPU में पाए जाने वाले वास्तविक रैंडम संख्या जनरेटर (TRNG) का समर्थन करता है,<ref>https://www.kernel.org/doc/Documentation/hw_random.txt {{Webarchive|url=https://web.archive.org/web/20130731115715/https://www.kernel.org/doc/Documentation/hw_random.txt |date=2013-07-31 }} {{Bare URL plain text|date=March 2022}}</ref> /dev/random में एकत्रित एन्ट्रॉपी को प्रभावी ढंग से बढ़ाना और संभावित रूप से क्रिप्टोग्राफ़िक क्षमता में सुधार करना। यह विशेष रूप से [[ नेतृत्वहीन व्यवस्था |नेतृत्वहीन व्यवस्था]] पर उपयोगी है जिसमें एन्ट्रापी का कोई अन्य स्रोत नहीं है। | ||
==व्यावहारिक निहितार्थ== | ==व्यावहारिक निहितार्थ== | ||
Line 70: | Line 52: | ||
कम या शून्य एन्ट्रापी वाले सिस्टम के लिए जिम्मेदार प्रशासकों को /dev/random के विकल्प के रूप में /dev/urandom का उपयोग करने का प्रयास नहीं करना चाहिए क्योंकि इससे SSL/TLS कनेक्शन में निम्न-श्रेणी का एन्क्रिप्शन हो सकता है।<ref>{{Cite web|url=https://marc.info/?l=kroupware&m=116375188915536&w=2|title='SSL/TLS entropy problem, aka pops timeouts (was: sasl ldap problem)' - MARC|website=marc.info|access-date=2023-05-23|archive-date=2018-11-15|archive-url=https://web.archive.org/web/20181115232141/https://marc.info/?l=kroupware&m=116375188915536&w=2|url-status=live}}</ref> | कम या शून्य एन्ट्रापी वाले सिस्टम के लिए जिम्मेदार प्रशासकों को /dev/random के विकल्प के रूप में /dev/urandom का उपयोग करने का प्रयास नहीं करना चाहिए क्योंकि इससे SSL/TLS कनेक्शन में निम्न-श्रेणी का एन्क्रिप्शन हो सकता है।<ref>{{Cite web|url=https://marc.info/?l=kroupware&m=116375188915536&w=2|title='SSL/TLS entropy problem, aka pops timeouts (was: sasl ldap problem)' - MARC|website=marc.info|access-date=2023-05-23|archive-date=2018-11-15|archive-url=https://web.archive.org/web/20181115232141/https://marc.info/?l=kroupware&m=116375188915536&w=2|url-status=live}}</ref> | ||
कुछ सॉफ़्टवेयर सिस्टम अक्सर अपनी [[ Diffie-Hellman ]] कुंजियाँ बदलते हैं, और यह कुछ मामलों में सर्वर को एन्ट्रापी बाधा के साथ भी सामान्य रूप से कार्य करना जारी रखने में मदद कर सकता है।<ref>Josefsson, Simon; [http://www1.ietf.org/mail-archive/web/tls/current/msg01660.html [TLS] Re: Short Ephermal Diffie-Hellman keys] {{Webarchive|url=https://web.archive.org/web/20071111095952/http://www1.ietf.org/mail-archive/web/tls/current/msg01660.html |date=2007-11-11 }} (ietf.org mailing list)</ref> | कुछ सॉफ़्टवेयर सिस्टम अक्सर अपनी [[ Diffie-Hellman |Diffie-Hellman]] कुंजियाँ बदलते हैं, और यह कुछ मामलों में सर्वर को एन्ट्रापी बाधा के साथ भी सामान्य रूप से कार्य करना जारी रखने में मदद कर सकता है।<ref>Josefsson, Simon; [http://www1.ietf.org/mail-archive/web/tls/current/msg01660.html [TLS] Re: Short Ephermal Diffie-Hellman keys] {{Webarchive|url=https://web.archive.org/web/20071111095952/http://www1.ietf.org/mail-archive/web/tls/current/msg01660.html |date=2007-11-11 }} (ietf.org mailing list)</ref> | ||
कम एन्ट्रापी वाले सर्वर पर, एक प्रक्रिया रुकी हुई दिखाई दे सकती है जब वह /dev/random (लिनक्स-आधारित सिस्टम पर) में | कम एन्ट्रापी वाले सर्वर पर, एक प्रक्रिया रुकी हुई दिखाई दे सकती है जब वह /dev/random (लिनक्स-आधारित सिस्टम पर) में रैंडम वर्णों के प्रकट होने की प्रतीक्षा कर रही हो। उदाहरण के लिए, [[डेबियन]] में एक ज्ञात समस्या थी जिसके कारण कुछ मामलों में [[exim4]] लटक गया था।<ref>{{cite web |url=http://lists.gnupg.org/pipermail/gnutls-dev/2004-December/000800.html |archive-url=https://web.archive.org/web/20070117213440/http://lists.gnupg.org/pipermail/gnutls-dev/2004-December/000800.html |archive-date=2007-01-17 |title=[gnutls-dev] gnutls_rsa_params_init hangs. Is regenerating rsa-params once a day too frequent? |website=lists.gnupg.org}}</ref> | ||
=== सिक्योरिटी === | |||
=== | |||
कीबोर्ड टाइमिंग हमलों के लिए एन्ट्रॉपी स्रोतों का उपयोग किया जा सकता है।<ref>Zalewski, Michal; [http://archive.cert.uni-stuttgart.de/bugtraq/2003/08/msg00213.html Unix entropy source can be used for keystroke timing attacks] {{Webarchive|url=https://web.archive.org/web/20110719111151/http://archive.cert.uni-stuttgart.de/bugtraq/2003/08/msg00213.html |date=2011-07-19 }}, 2003</ref> | कीबोर्ड टाइमिंग हमलों के लिए एन्ट्रॉपी स्रोतों का उपयोग किया जा सकता है।<ref>Zalewski, Michal; [http://archive.cert.uni-stuttgart.de/bugtraq/2003/08/msg00213.html Unix entropy source can be used for keystroke timing attacks] {{Webarchive|url=https://web.archive.org/web/20110719111151/http://archive.cert.uni-stuttgart.de/bugtraq/2003/08/msg00213.html |date=2011-07-19 }}, 2003</ref> | ||
एन्ट्रॉपी सर्वर (कंप्यूटिंग) की [[क्रिप्टोग्राफी]] (टीएलएस/एसएसएल) को प्रभावित कर सकती है: यदि कोई सर्वर | एन्ट्रॉपी सर्वर (कंप्यूटिंग) की [[क्रिप्टोग्राफी]] (टीएलएस/एसएसएल) को प्रभावित कर सकती है: यदि कोई सर्वर रैंडमनैस के उचित स्रोत का उपयोग करने में विफल रहता है, तो सर्वर द्वारा उत्पन्न कुंजियाँ असुरक्षित होंगी। | ||
कुछ मामलों में एक [[हैकर (कंप्यूटर सुरक्षा)]] (दुर्भावनापूर्ण हमलावर) [[छद्म यादृच्छिक संख्या जनरेटर]] (पीआरएनजी) के आउटपुट से एन्ट्रॉपी के कुछ [[ अंश ]]्स का अनुमान लगा सकता है, और ऐसा तब होता है जब पीआरएनजी में पर्याप्त एन्ट्रॉपी पेश नहीं की जाती है।<ref>[http://osdir.com/ml/encryption.general/2005-01/msg00074.html Re: entropy depletion (was: SSL/TLS passive sniffing)] {{Webarchive|url=https://web.archive.org/web/20110517025619/http://osdir.com/ml/encryption.general/2005-01/msg00074.html |date=2011-05-17 }}, 2005</ref> | कुछ मामलों में एक [[हैकर (कंप्यूटर सुरक्षा)|हैकर (कंप्यूटर सिक्योरिटी)]] (दुर्भावनापूर्ण हमलावर) [[छद्म यादृच्छिक संख्या जनरेटर|छद्म रैंडम संख्या जनरेटर]] (पीआरएनजी) के आउटपुट से एन्ट्रॉपी के कुछ [[ अंश |अंश]] ्स का अनुमान लगा सकता है, और ऐसा तब होता है जब पीआरएनजी में पर्याप्त एन्ट्रॉपी पेश नहीं की जाती है।<ref>[http://osdir.com/ml/encryption.general/2005-01/msg00074.html Re: entropy depletion (was: SSL/TLS passive sniffing)] {{Webarchive|url=https://web.archive.org/web/20110517025619/http://osdir.com/ml/encryption.general/2005-01/msg00074.html |date=2011-05-17 }}, 2005</ref> | ||
==संभावित स्रोत== | ==संभावित स्रोत== | ||
आम तौर पर उपयोग किए जाने वाले एन्ट्रापी स्रोतों में माउस, कीबोर्ड और आईडीई टाइमिंग शामिल हैं, लेकिन अन्य संभावित स्रोत भी हैं। उदाहरण के लिए, कोई कंप्यूटर के [[माइक्रोफ़ोन]] से एन्ट्रापी एकत्र कर सकता है, या [[डिस्क ड्राइव]] के अंदर [[अशांति]] को मापने के लिए एक सेंसर का निर्माण कर सकता है।<ref>{{Cite web|url=http://www.codeproject.com/internet/YourOwnSecureProtocol.asp?df=100&forumid=316484&exp=0&select=1846294|title=Build your own cryptographically safe server/client protocol - 4.8.3. Collecting entropy|access-date=2020-01-08|archive-date=2012-07-23|archive-url=https://archive.today/20120723103648/http://www.codeproject.com/internet/YourOwnSecureProtocol.asp?df=100&forumid=316484&exp=0&select=1846294|url-status=bot: unknown}}</ref> | आम तौर पर उपयोग किए जाने वाले एन्ट्रापी स्रोतों में माउस, कीबोर्ड और आईडीई टाइमिंग शामिल हैं, लेकिन अन्य संभावित स्रोत भी हैं। उदाहरण के लिए, कोई कंप्यूटर के [[माइक्रोफ़ोन]] से एन्ट्रापी एकत्र कर सकता है, या [[डिस्क ड्राइव]] के अंदर [[अशांति]] को मापने के लिए एक सेंसर का निर्माण कर सकता है।<ref>{{Cite web|url=http://www.codeproject.com/internet/YourOwnSecureProtocol.asp?df=100&forumid=316484&exp=0&select=1846294|title=Build your own cryptographically safe server/client protocol - 4.8.3. Collecting entropy|access-date=2020-01-08|archive-date=2012-07-23|archive-url=https://archive.today/20120723103648/http://www.codeproject.com/internet/YourOwnSecureProtocol.asp?df=100&forumid=316484&exp=0&select=1846294|url-status=bot: unknown}}</ref> | ||
यूनिक्स/बीएसडी डेरिवेटिव के लिए एक यूएसबी आधारित समाधान मौजूद है जो सिस्टम में दो एन्ट्रापी जेनरेटर स्रोतों द्वारा उत्पन्न बिट स्ट्रीम को फ़िल्टर करने/सुरक्षित करने के लिए एआरएम कॉर्टेक्स सीपीयू का उपयोग करता है।<ref>{{Cite web|url=http://www.entropykey.co.uk/|archiveurl=https://web.archive.org/web/20100722164508/http://www.entropykey.co.uk/|url-status=dead|title=Simtec Electronics Entropy Key: USB True Random Number Generator|archivedate=July 22, 2010|website=www.entropykey.co.uk}}</ref> | यूनिक्स/बीएसडी डेरिवेटिव के लिए एक यूएसबी आधारित समाधान मौजूद है जो सिस्टम में दो एन्ट्रापी जेनरेटर स्रोतों द्वारा उत्पन्न बिट स्ट्रीम को फ़िल्टर करने/सुरक्षित करने के लिए एआरएम कॉर्टेक्स सीपीयू का उपयोग करता है।<ref>{{Cite web|url=http://www.entropykey.co.uk/|archiveurl=https://web.archive.org/web/20100722164508/http://www.entropykey.co.uk/|url-status=dead|title=Simtec Electronics Entropy Key: USB True Random Number Generator|archivedate=July 22, 2010|website=www.entropykey.co.uk}}</ref> | ||
[[ बादल भड़कना ]] एन्ट्रापी के अतिरिक्त स्रोत के रूप में 80 [[लावा लैंप]] के रैक से एक छवि फ़ीड का उपयोग करता है।<ref>{{Cite web|url=http://blog.cloudflare.com/randomness-101-lavarand-in-production/|title=Randomness 101: LavaRand in Production|date=November 6, 2017|website=The Cloudflare Blog|access-date=May 23, 2023|archive-date=May 1, 2023|archive-url=https://web.archive.org/web/20230501132603/https://blog.cloudflare.com/randomness-101-lavarand-in-production/|url-status=live}}</ref> | [[ बादल भड़कना | बादल भड़कना]] एन्ट्रापी के अतिरिक्त स्रोत के रूप में 80 [[लावा लैंप]] के रैक से एक छवि फ़ीड का उपयोग करता है।<ref>{{Cite web|url=http://blog.cloudflare.com/randomness-101-lavarand-in-production/|title=Randomness 101: LavaRand in Production|date=November 6, 2017|website=The Cloudflare Blog|access-date=May 23, 2023|archive-date=May 1, 2023|archive-url=https://web.archive.org/web/20230501132603/https://blog.cloudflare.com/randomness-101-lavarand-in-production/|url-status=live}}</ref> | ||
== यह भी देखें == | == यह भी देखें == | ||
* [[एन्ट्रॉपी (सूचना सिद्धांत)]] | * [[एन्ट्रॉपी (सूचना सिद्धांत)]] | ||
*[[एन्ट्रापी]] | *[[एन्ट्रापी]] | ||
* | * रैंडमनैस | ||
== संदर्भ == | == संदर्भ == |
Revision as of 21:04, 16 August 2023
कम्प्यूटिंग में, एन्ट्रापी एक ऑपरेटिंग सिस्टम या एप्लिकेशन द्वारा क्रिप्टोग्राफी या अन्य उपयोगों में उपयोग के लिए रैंडमनैस एकत्र की गई है जिसके लिए रैंडम डेटा की आवश्यकता होती है। यह रैंडमनैस अक्सर हार्डवेयर स्रोतों (पंखे के शोर या एचडीडी में भिन्नता) से एकत्र की जाती है, या तो पहले से मौजूद स्रोतों जैसे कि माउस मूवमेंट या विशेष रूप से प्रदान किए गए रैंडमनैस जनरेटर से भी एकत्र कर सकते है, एन्ट्रापी की कमी परफॉरमेंस और सिक्योरिटी पर नेगेटिव प्रभाव डाल सकती है।
लिनक्स कर्नेल
लिनक्स कर्नेल कीबोर्ड (कंप्यूटिंग) टाइमिंग, माउस (कंप्यूटिंग) मूवमेंट और इंटीग्रेटेड ड्राइव इलेक्ट्रॉनिक्स (आईडीई) टाइमिंग से एन्ट्रापी उत्पन्न करता है और विशेष फ़ाइलों /dev/random और /dev/ के माध्यम से अन्य ऑपरेटिंग सिस्टम प्रक्रियाओं के लिए रैंडम वर्ण डेटा उपलब्ध कराता है। urandom. यह क्षमता लिनक्स संस्करण 1.3.30 में पेश की गई थी।[1] कुछ लिनक्स कर्नेल पैच हैं जो किसी को अधिक एन्ट्रापी स्रोतों का उपयोग करने की अनुमति देते हैं।[2] Audio_entropyd परियोजना,[3] जो कुछ ऑपरेटिंग सिस्टम जैसे कि फेडोरा (ऑपरेटिंग सिस्टम) में शामिल है, ऑडियो डेटा को एन्ट्रापी स्रोत के रूप में उपयोग करने की अनुमति देता है।[4] video_entropyd भी उपलब्ध हैं,[5] जो एक वीडियो-स्रोत और एन्ट्रॉपीब्रोकर से रैंडम डेटा की गणना करता है,[6] जिसमें ये तीनों शामिल हैं और इनका उपयोग एन्ट्रापी डेटा को उन प्रणालियों में वितरित करने के लिए किया जा सकता है जो इनमें से किसी को भी चलाने में सक्षम नहीं हैं (जैसे आभाषी दुनिया)। इसके अलावा, कोई हेज्ड टू पूल एन्ट्रॉपी के माध्यम से HAVEGE एल्गोरिदम का उपयोग कर सकता है।[7] कुछ प्रणालियों में, नेटवर्क इंटरप्ट का उपयोग एन्ट्रापी स्रोत के रूप में भी किया जा सकता है।[8]
ओपनबीएसडी कर्नेल
ओपनबीएसडी ने क्रिप्टोग्राफी को अपने मुख्य लक्ष्यों में से एक के रूप में एकीकृत किया है और हमेशा एन्क्रिप्शन के लिए अपनी एन्ट्रापी को बढ़ाने पर काम किया है, लेकिन इसके कर्नेल के विभिन्न आंतरिक संचालन सहित ओएस के कई हिस्सों को रैंडम बनाने के लिए भी काम किया है। 2011 के आसपास, दो रैंडम उपकरणों को हटा दिया गया और एक ही स्रोत से जोड़ दिया गया क्योंकि यह एक औसत सिस्टम पर प्रति सेकंड सैकड़ों मेगाबाइट उच्च गुणवत्ता वाले रैंडम डेटा का उत्पादन कर सकता था।[clarification needed] इससे ओपनबीएसडी पर उपयोगकर्तालैंड कार्यक्रमों द्वारा रैंडम डेटा की कमी असंभव हो गई, जब शुरू में पर्याप्त एन्ट्रापी एकत्र हो गई थी।
हर्ड कर्नेल
हर्ड कर्नेल के लिए लिनक्स कर्नेल से पोर्ट किया गया ड्राइवर उपलब्ध कराया गया है।[9]
सोलारिस
/dev/random और /dev/urandom सोलारिस 2.6 के बाद से सोलारिस (ऑपरेटिंग सिस्टम) के लिए सन पैकेज या पैच के रूप में उपलब्ध हैं।[10] और सोलारिस 9 के बाद से यह एक मानक सुविधा रही है। रेफरी>"सोलारिस /देव/यादृच्छिक". Archived from the original on 2008-05-11. Retrieved 2007-10-17.</ref> सोलारिस 10 के अनुसार, प्रशासक मौजूदा एन्ट्रापी स्रोतों को हटा सकते हैं या कर्नेल-स्तरीय क्रिप्टोग्राफ़िक ढांचे के माध्यम से नए स्रोतों को परिभाषित कर सकते हैं।
सोलारिस 2.4 से पहले के रिलीज के लिए /dev/random को लागू करने वाला एक तृतीय-पक्ष कर्नेल मॉड्यूल भी उपलब्ध है।[10]
ओएस/2
OS/2 के लिए एक सॉफ़्टवेयर पैकेज है जो सॉफ़्टवेयर प्रक्रियाओं को रैंडम डेटा पुनर्प्राप्त करने की अनुमति देता है।[11]
खिड़कियाँ
माइक्रोसॉफ़्ट विंडोज़ ़ विंडोज़ 95 की तुलना में नई रिलीज़ करता है जो लिनक्स कर्नेल के /dev/random के समान एन्ट्रापी इकट्ठा करने के लिए माइक्रोसॉफ्ट क्रिप्टोएपीआई का उपयोग करता है।[12] विंडोज़ का क्रिप्टोएपीआई अपने सभी एन्ट्रापी स्रोतों से एक बीजित मूल्य को संग्रहीत करने के लिए बाइनरी विंडोज़ रजिस्ट्री कुंजी HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryptography\RNG\Seed का उपयोग करता है।[13] क्योंकि क्रिप्टोएपीआई बंद-स्रोत है, विंडोज़ प्लेटफ़ॉर्म पर चलने वाले कुछ मुफ़्त और खुले स्रोत सॉफ़्टवेयर एप्लिकेशन रैंडमनैस प्राप्त करने के लिए अन्य उपायों का उपयोग करते हैं। उदाहरण के लिए, जीएनयूपीजी, संस्करण 1.06 के अनुसार, विभिन्न स्रोतों का उपयोग करता है जैसे कि मेमोरी में मुफ्त बाइट्स की संख्या जो एक रैंडम बीज के साथ मिलकर वांछित रैंडमनैस उत्पन्न करती है जिसकी उसे आवश्यकता होती है।[14] CAPI का उपयोग करने वाले प्रोग्रामर इसे ठीक से आरंभ करने के बाद CAPI के CryptGenRandom() को कॉल करके एन्ट्रापी प्राप्त कर सकते हैं।[15] क्रिप्टोएपीआई को विंडोज विस्टा और उच्चतर से हटा दिया गया था। नई एपीआई को क्रिप्टोग्राफी एपीआई: नेक्स्ट जेनरेशन (सीएनजी) कहा जाता है।[16] विंडोज़ का सीएनजी बीजित मूल्य को संग्रहीत करने के लिए बाइनरी विंडोज़ रजिस्ट्री कुंजी HKEY_LOCAL_MACHINE\SYSTEM\RNG\Seed का उपयोग करता है।
विंडोज़ का नया संस्करण विभिन्न प्रकार के एन्ट्रापी स्रोतों का उपयोग करने में सक्षम है:
- विश्वसनीय प्लेटफ़ॉर्म मॉड्यूल यदि उपलब्ध हो और मदरबोर्ड पर सक्षम हो
- यूईएफआई इंटरफ़ेस से एन्ट्रॉपी (यदि यूईएफआई से बूट किया गया है)[17]
- RDRAND सीपीयू अनुदेश यदि उपलब्ध हो
- हार्डवेयर सिस्टम घड़ी (वास्तविक समय घड़ी)
- OEM0 ACPI तालिका सामग्री
- व्यवधान का समय
- कीबोर्ड टाइमिंग और माउस मूवमेंट[18]
एंबेडेड सिस्टम
अंतः स्थापित प्रणाली को पर्याप्त एन्ट्रापी इकट्ठा करने में कठिनाई होती है क्योंकि वे अक्सर कम बूट समय के साथ बहुत ही सरल उपकरण होते हैं, और कुंजी पीढ़ी के संचालन के लिए पर्याप्त एन्ट्रापी की आवश्यकता होती है जो अक्सर सिस्टम द्वारा की जाने वाली पहली चीजों में से एक होती है। सामान्य एन्ट्रापी स्रोत इन उपकरणों पर मौजूद नहीं हो सकते हैं, या बूट के दौरान पर्याप्त एन्ट्रापी मौजूद होने को सुनिश्चित करने के लिए पर्याप्त समय तक सक्रिय नहीं रहेंगे। एंबेडेड उपकरणों में अक्सर घूमने वाली डिस्क ड्राइव, मानव इंटरफ़ेस डिवाइस और यहां तक कि प्रशंसकों की कमी होती है, और नेटवर्क इंटरफ़ेस, यदि कोई हो, तो अधिक एन्ट्रॉपी प्रदान करने के लिए पर्याप्त समय तक सक्रिय नहीं होगा। एन्ट्रॉपी तक आसान पहुंच के अभाव में, कुछ डिवाइस रैंडम जेनरेटर को सीड करने के लिए हार्ड-कोडेड कुंजियों का उपयोग कर सकते हैं, या डिवाइस के मैक पते जैसे आसानी से अनुमानित अद्वितीय पहचानकर्ताओं से रैंडम जेनरेटर को सीड कर सकते हैं। एक साधारण अध्ययन[which?] समान कुंजियों का उपयोग करने वाले राउटर जैसे कई एम्बेडेड सिस्टम ढूंढकर कमजोर कुंजियों के व्यापक उपयोग का परफॉरमेंस किया। यह सोचा गया था कि यदि सरल और अक्सर हमलावर निर्धारित करने योग्य एक बार के विशिष्ट पहचानकर्ताओं को इनमें से कुछ प्रणालियों की एन्ट्रापी में शामिल नहीं किया गया होता, तो पाई गई कमजोर कुंजियों की संख्या कहीं अधिक होती।[19]
(डी)केंद्रीकृत सिस्टम
एक सच्चा रैंडम संख्या जनरेटर (टीआरएनजी) एक (डी) केंद्रीय सेवा हो सकता है। एक केंद्रीकृत प्रणाली का एक उदाहरण जहां एक रैंडम संख्या प्राप्त की जा सकती है वह राष्ट्रीय मानक और प्रौद्योगिकी संस्थान की रैंडमनैस बीकन सेवा है। कार्डानो प्लेटफ़ॉर्म रैंडम संख्याएँ उत्पन्न करने के लिए अपने विकेन्द्रीकृत -का-प्रमाण हिस्सेदारी प्रोटोकॉल के प्रतिभागियों का उपयोग करता है।[20]
अन्य प्रणालियाँ
ऐसे कुछ सॉफ्टवेयर पैकेज हैं जो किसी को रैंडम वर्णों को इकट्ठा करने के लिए यूजरस्पेस प्रक्रिया का उपयोग करने की अनुमति देते हैं, बिल्कुल वही जो /dev/random करता है, जैसे कि ईजीडी, एन्ट्रॉपी गैदरिंग डेमॉन।[21]
हार्डवेयर-उत्पन्न एन्ट्रापी
आधुनिक CPU और हार्डवेयर में अक्सर एकीकृत जनरेटर की सुविधा होती है जो ऑपरेटिंग सिस्टम को उच्च गुणवत्ता और उच्च गति एन्ट्रॉपी प्रदान कर सकते हैं। लिनक्स कर्नेल पर आधारित सिस्टम पर, कोई ऐसे डिवाइस से उत्पन्न एन्ट्रॉपी को /dev/hw_random के माध्यम से पढ़ सकता है।[22] हालाँकि, कभी-कभी /dev/hw_random धीमा हो सकता है;[23][24] कुछ कंपनियां एन्ट्रॉपी जेनरेशन डिवाइस बनाती हैं, और उनमें से कुछ को लिनक्स के लिए ड्राइवरों के साथ भेजा जाता है।[25][26] लिनक्स सिस्टम पर, कोई आरएनजी-टूल्स पैकेज इंस्टॉल कर सकता है[27] जो RDRAND निर्देश, विश्वसनीय प्लेटफ़ॉर्म मॉड्यूल और कुछ Intel, AMD, या VIA Technologies चिपसेट का समर्थन करने वाले CPU में पाए जाने वाले वास्तविक रैंडम संख्या जनरेटर (TRNG) का समर्थन करता है,[28] /dev/random में एकत्रित एन्ट्रॉपी को प्रभावी ढंग से बढ़ाना और संभावित रूप से क्रिप्टोग्राफ़िक क्षमता में सुधार करना। यह विशेष रूप से नेतृत्वहीन व्यवस्था पर उपयोगी है जिसमें एन्ट्रापी का कोई अन्य स्रोत नहीं है।
व्यावहारिक निहितार्थ
सिस्टम प्रशासकों, विशेष रूप से इंटरनेट सर्वरों की देखरेख करने वालों को यह सुनिश्चित करना होगा कि एन्ट्रापी की कमी के कारण सर्वर प्रक्रियाएँ नहीं रुकेंगी। लिनक्स कर्नेल, या किसी अन्य कर्नेल या यूजरस्पेस प्रक्रिया का उपयोग करने वाले सर्वर (कंप्यूटिंग) पर एन्ट्रॉपी जो कंसोल और स्टोरेज सबसिस्टम से एन्ट्रॉपी उत्पन्न करती है, अक्सर माउस और कीबोर्ड की कमी के कारण आदर्श से कम होती है, इस प्रकार सर्वर को उत्पन्न करना पड़ता है आईडीई टाइमिंग जैसे संसाधनों के सीमित सेट से उनकी एन्ट्रॉपी।
लिनक्स में एन्ट्रॉपी पूल का आकार फ़ाइल /proc/sys/kernel/random/entropy_avail के माध्यम से देखा जा सकता है और आम तौर पर कम से कम 2000 बिट्स (अधिकतम 4096 में से) होना चाहिए।[29][30] एन्ट्रापी बार-बार बदलती रहती है।
कम या शून्य एन्ट्रापी वाले सिस्टम के लिए जिम्मेदार प्रशासकों को /dev/random के विकल्प के रूप में /dev/urandom का उपयोग करने का प्रयास नहीं करना चाहिए क्योंकि इससे SSL/TLS कनेक्शन में निम्न-श्रेणी का एन्क्रिप्शन हो सकता है।[31] कुछ सॉफ़्टवेयर सिस्टम अक्सर अपनी Diffie-Hellman कुंजियाँ बदलते हैं, और यह कुछ मामलों में सर्वर को एन्ट्रापी बाधा के साथ भी सामान्य रूप से कार्य करना जारी रखने में मदद कर सकता है।[32] कम एन्ट्रापी वाले सर्वर पर, एक प्रक्रिया रुकी हुई दिखाई दे सकती है जब वह /dev/random (लिनक्स-आधारित सिस्टम पर) में रैंडम वर्णों के प्रकट होने की प्रतीक्षा कर रही हो। उदाहरण के लिए, डेबियन में एक ज्ञात समस्या थी जिसके कारण कुछ मामलों में exim4 लटक गया था।[33]
सिक्योरिटी
कीबोर्ड टाइमिंग हमलों के लिए एन्ट्रॉपी स्रोतों का उपयोग किया जा सकता है।[34] एन्ट्रॉपी सर्वर (कंप्यूटिंग) की क्रिप्टोग्राफी (टीएलएस/एसएसएल) को प्रभावित कर सकती है: यदि कोई सर्वर रैंडमनैस के उचित स्रोत का उपयोग करने में विफल रहता है, तो सर्वर द्वारा उत्पन्न कुंजियाँ असुरक्षित होंगी। कुछ मामलों में एक हैकर (कंप्यूटर सिक्योरिटी) (दुर्भावनापूर्ण हमलावर) छद्म रैंडम संख्या जनरेटर (पीआरएनजी) के आउटपुट से एन्ट्रॉपी के कुछ अंश ्स का अनुमान लगा सकता है, और ऐसा तब होता है जब पीआरएनजी में पर्याप्त एन्ट्रॉपी पेश नहीं की जाती है।[35]
संभावित स्रोत
आम तौर पर उपयोग किए जाने वाले एन्ट्रापी स्रोतों में माउस, कीबोर्ड और आईडीई टाइमिंग शामिल हैं, लेकिन अन्य संभावित स्रोत भी हैं। उदाहरण के लिए, कोई कंप्यूटर के माइक्रोफ़ोन से एन्ट्रापी एकत्र कर सकता है, या डिस्क ड्राइव के अंदर अशांति को मापने के लिए एक सेंसर का निर्माण कर सकता है।[36] यूनिक्स/बीएसडी डेरिवेटिव के लिए एक यूएसबी आधारित समाधान मौजूद है जो सिस्टम में दो एन्ट्रापी जेनरेटर स्रोतों द्वारा उत्पन्न बिट स्ट्रीम को फ़िल्टर करने/सुरक्षित करने के लिए एआरएम कॉर्टेक्स सीपीयू का उपयोग करता है।[37] बादल भड़कना एन्ट्रापी के अतिरिक्त स्रोत के रूप में 80 लावा लैंप के रैक से एक छवि फ़ीड का उपयोग करता है।[38]
यह भी देखें
- एन्ट्रॉपी (सूचना सिद्धांत)
- एन्ट्रापी
- रैंडमनैस
संदर्भ
- ↑ random(4) - Linux man page Archived 2007-10-11 at the Wayback Machine (die.net)
- ↑ "Robotic Tendencies » Missing entropy". Archived from the original on 2022-12-06. Retrieved 2023-05-23.
- ↑ "ऑडियो एन्ट्रॉपी डेमॉन". March 23, 2021. Archived from the original on 2021-03-23.
- ↑ "Fedora Package Database – audio-entropyd".[permanent dead link]
- ↑ "video_entropyd". March 23, 2021. Archived from the original on 2021-03-23.
- ↑ "एन्ट्रॉपी ब्रोकर". May 29, 2020. Archived from the original on 2020-05-29.
- ↑ "haveged – A simple entropy daemon". Archived from the original on 27 October 2012. Retrieved 3 April 2011.
- ↑ "Entropy and Random Devices | LinuxLink by TimeSys – Your Embedded Linux Resource". Archived from the original on 2016-04-02. Retrieved 2007-10-15.
- ↑ /dev/{,u}random driver for GNU/Hurd Archived 2007-09-18 at the Wayback Machine (ibofobi.dk)
- ↑ 10.0 10.1 "अनुकरण के माध्यम से सोलारिस /डेव/रैंडम". Archived from the original on 2007-11-04. Retrieved 2007-10-15.
- ↑ "Rexx Entropy Gathering Daemon for OS/2". r6.ca. Archived from the original on 2007-10-31. Retrieved 2007-10-15.
- ↑ Malayter, Ryan (November 9, 2001). "विंडोज़ के लिए जीपीएल कमांड-लाइन श्रेड विकल्प". Archived from the original on October 27, 2021. Retrieved May 23, 2023.
- ↑ "क्रिप्टोएपीआई स्थापित के साथ विंडोज प्लेटफॉर्म पर एन्ट्रापी के लिए स्रोत". www.mail-archive.com. Archived from the original on 2018-10-02. Retrieved 2023-05-23.
- ↑ Malayter, Ryan (February 15, 2002). "How does Windows GnuPG generate random numbers on keygen?". Archived from the original on December 1, 2021. Retrieved May 23, 2023.
- ↑ "[or-cvs] Get entropy in windows". archives.seul.org. Archived from the original on 2013-05-07. Retrieved 2023-05-23.
- ↑ "About CNG - Win32 apps". Archived from the original on 2018-05-17. Retrieved 2018-05-17.
- ↑ "यूईएफआई एन्ट्रापी संग्रहण प्रोटोकॉल - विंडोज़ ड्राइवर". Archived from the original on 2018-05-17. Retrieved 2018-05-17.
- ↑ "CryptGenRandom function (Wincrypt.h) - Win32 apps". Archived from the original on 2020-08-12. Retrieved 2020-08-31.
- ↑ Constantin, Lucian. "लाखों एम्बेडेड डिवाइस समान हार्ड-कोडेड एसएसएच और टीएलएस निजी कुंजी का उपयोग करते हैं". Network World (in English). Archived from the original on 2018-11-05. Retrieved 2018-11-05.
- ↑ "स्केलेबल यादृच्छिकता के लिए एक समाधान". iohk.io. June 6, 2017. Archived from the original on April 17, 2021. Retrieved September 14, 2020.
- ↑ "यादृच्छिक संख्याएँ". dwheeler.com. Archived from the original on 2022-12-30. Retrieved 2023-05-23.
- ↑ "'Re: SSL/TLS entropy problem,' - MARC". marc.info. Archived from the original on 2018-11-15. Retrieved 2023-05-23.
- ↑ "Re: /dev/hw_random". Archived from the original on 2007-10-31. Retrieved 2007-10-15.
- ↑ "Re: /dev/hw_random". Archived from the original on 2007-11-12. Retrieved 2007-10-15.
- ↑ "यादृच्छिक शोर स्रोत". Archived from the original on 2007-11-21. Retrieved 2007-10-15.
- ↑ http://random.com.hr/products/random/hg324.html Archived 2008-05-13 at the Wayback Machine
- ↑ "आरएनजी-उपकरण". Archived from the original on 2007-10-21. Retrieved 2007-10-16.
- ↑ https://www.kernel.org/doc/Documentation/hw_random.txt Archived 2013-07-31 at the Wayback Machine[bare URL plain text file]
- ↑ "Re: [exim] no reply to STARTTLS". lists.exim.org. Archived from the original on 2012-07-22. Retrieved 2023-05-23.
- ↑ random(4) Linux man page Archived 2007-10-11 at the Wayback Machine, die.net
- ↑ "'SSL/TLS entropy problem, aka pops timeouts (was: sasl ldap problem)' - MARC". marc.info. Archived from the original on 2018-11-15. Retrieved 2023-05-23.
- ↑ Josefsson, Simon; [TLS Re: Short Ephermal Diffie-Hellman keys] Archived 2007-11-11 at the Wayback Machine (ietf.org mailing list)
- ↑ "[gnutls-dev] gnutls_rsa_params_init hangs. Is regenerating rsa-params once a day too frequent?". lists.gnupg.org. Archived from the original on 2007-01-17.
- ↑ Zalewski, Michal; Unix entropy source can be used for keystroke timing attacks Archived 2011-07-19 at the Wayback Machine, 2003
- ↑ Re: entropy depletion (was: SSL/TLS passive sniffing) Archived 2011-05-17 at the Wayback Machine, 2005
- ↑ "Build your own cryptographically safe server/client protocol - 4.8.3. Collecting entropy". Archived from the original on 2012-07-23. Retrieved 2020-01-08.
{{cite web}}
: CS1 maint: bot: original URL status unknown (link) - ↑ "Simtec Electronics Entropy Key: USB True Random Number Generator". www.entropykey.co.uk. Archived from the original on July 22, 2010.
- ↑ "Randomness 101: LavaRand in Production". The Cloudflare Blog. November 6, 2017. Archived from the original on May 1, 2023. Retrieved May 23, 2023.