മോംഗോഡിബി

വിക്കിപീഡിയ, ഒരു സ്വതന്ത്ര വിജ്ഞാനകോശം.
മോംഗോഡിബി
വികസിപ്പിച്ചത്MongoDB Inc.
ആദ്യപതിപ്പ്ഫെബ്രുവരി 11, 2009; 14 വർഷങ്ങൾക്ക് മുമ്പ് (2009-02-11)[1]
Stable release
6.0.7[2] Edit this on Wikidata / 28 ജൂൺ 2023,2 മാസങ്ങൾക്ക് മുമ്പ്
Repository വിക്കിഡാറ്റയിൽ തിരുത്തുക
ഭാഷC++, JavaScript, Python
ഓപ്പറേറ്റിങ് സിസ്റ്റംWindows Vista and later, Linux, OS X 10.7 and later, Solaris,[3] FreeBSD[4]
ലഭ്യമായ ഭാഷകൾEnglish
തരംDocument-oriented database
അനുമതിപത്രംServer Side Public License
വെബ്‌സൈറ്റ്www.mongodb.com

ക്രോസ്-പ്ലാറ്റ്ഫോം ഡോക്യുമെന്റ് ഓറിയന്റഡ് ഡാറ്റാബേസ് പ്രോഗ്രാം ആണ് മോംഗോഡിബി. ഒരു നോഎസ്ക്യൂഎൽ(NoSQL) ഡാറ്റാബേസ് പ്രോഗ്രാം എന്ന് തരംതിരിച്ചിട്ടുള്ള മോംഗോഡിബി സ്കീമയോടുകൂടിയ ജെസൺ(JSON)പോലുള്ള പ്രമാണങ്ങൾ ഉപയോഗിക്കുന്നു. മോംഗോഡിബി വികസിപ്പിച്ചെടുത്തത് മോംഗോഡിബി ഇങ്ക് ആണ്, സെർവർ സൈഡ് പബ്ലിക് ലൈസൻസിന് (എസ്എസ്പിഎൽ) കീഴിൽ ലൈസൻസുള്ളതാണ്.

ചരിത്രം[തിരുത്തുക]

ഒരു സേവന ഉൽ‌പ്പന്നമെന്ന നിലയിൽ ആസൂത്രിതമായ ഒരു പ്ലാറ്റ്ഫോമിന്റെ ഘടകമായി ടെൻജെൻ(10gen) സോഫ്റ്റ്‌വേർ കമ്പനി 2007 ൽ മോംഗോഡിബി വികസിപ്പിക്കാൻ തുടങ്ങി. 2009 ൽ കമ്പനി ഒരു ഓപ്പൺ സോഴ്‌സ് ഡെവലപ്‌മെന്റ് മോഡലിലേക്ക് മാറി, വാണിജ്യ പിന്തുണയും മറ്റ് സേവനങ്ങളും കമ്പനി വാഗ്ദാനം ചെയ്തു. 2013 ൽ ടെൻജെൻ അതിന്റെ പേര് മോംഗോഡിബി ഇങ്ക് എന്ന് മാറ്റി.[5]

ഒക്ടോബർ 20, 2017 ന്, മോംഗോഡിബി ഒരു പൊതു വ്യാപാരം നടത്തുന്ന കമ്പനിയായി മാറി, നാസ്ഡാക്കിൽ എംഡിബിയായി ലിസ്റ്റുചെയ്തിട്ടുണ്ട്, ഓരോ ഷെയറിനും 24 ഡോളർ ഐപിഒ വിലയുണ്ട്. [6]

2019 ഒക്ടോബർ 30 ന് മോംഗോഡിബി അലിബാബ ക്ലൗഡുമായി ചേർന്നു, ഉപയോക്താക്കൾക്ക് മോംഗോഡിബി-ആസ്-എ-സർവ്വീസ് സൊലൂഷൻ വാഗ്ദാനം ചെയ്യും. ഉപയോക്താക്കൾക്ക് ബാബയുടെ(BABA) ആഗോള ഡാറ്റാ സെന്ററുകളിൽ നിന്ന് നിയന്ത്രിത ഓഫർ ഉപയോഗിക്കാൻ കഴിയും.[7]

മോംഗോഡിബി റിലീസ് ചരിത്രം
പതിപ്പ് റിലീസ് തീയതി ഫീച്ചേഴ്സ് നോട്ട്സ് റെഫ്
1.0 ഫെബ്രുവരി 2009
1.2 ഡിസംബർ 2009
  • ഓരോ കളക്ഷനും കൂടുതൽ സൂചികകൾ
  • വേഗത്തിലുള്ള സൂചിക സൃഷ്ടിക്കൽ
  • മാപ്പ്/റെഡ്യൂസ്
  • ജാവാസ്ക്രിപ്റ്റ് ഫംഗ്ഷനുകൾ സ്റ്റോർ ചെയ്തു
  • ക്രമീകരിക്കാവുന്ന fsync സമയം
  • നിരവധി ചെറിയ സവിശേഷതകളും പരിഹാരങ്ങളും
[8]
1.4 മാർച്ച് 2010 [9]
1.6 ഓഗസ്റ്റ് 2010
  • ഉൽ‌പാദനത്തിന് തയ്യാറായ ഷാർഡിംഗ്
  • റെപ്ലിക്കാ സെറ്റുകൾ
  • IPv6- നുള്ള പിന്തുണ
[10]
1.8 മാർച്ച് 2011 [11]
2.0 സെപ്റ്റംബർ 2011 [12]
2.2 ഓഗസ്റ്റ് 2012 [13]
2.4 മാർച്ച് 2013
  • മെച്ചപ്പെടുത്തിയ ജിയോസ്പേഷ്യൽ പിന്തുണ
  • വി 8 ജാവാസ്ക്രിപ്റ്റ് എഞ്ചിനിലേക്ക് മാറുക
  • സുരക്ഷാ മെച്ചപ്പെടുത്തലുകൾ
  • വാചകങ്ങൾ തിരയൽ (ബീറ്റ)
  • ഹാഷ് സൂചിക
[14]
2.6 ഏപ്രിൽ 8, 2014
  • അഗ്രഷൻ മെച്ചപ്പെടുത്തലുകൾ
  • ടെക്സ്റ്റ്-തിരയൽ സംയോജനം
  • ക്വറി-എഞ്ചിൻ മെച്ചപ്പെടുത്തലുകൾ
  • പുതിയ റൈറ്റ്-ഓപ്പറേഷൻ പ്രോട്ടോക്കോൾ
  • സുരക്ഷാ മെച്ചപ്പെടുത്തലുകൾ
[15]
3.0 മാർച്ച് 3, 2015
  • വയർഡ് ടൈഗർ സ്റ്റോറേജ് എഞ്ചിൻ പിന്തുണ
  • പ്ലഗബിൾ സ്റ്റോറേജ് എഞ്ചിൻ എപിഐ(API)
  • SCRAM-SHA-1 പ്രാമാണീകരണം
  • മെച്ചപ്പെടുത്തിയ എക്സപ്ലെയിൻ ഫങ്ഷണാലിറ്റി
  • മോംഗോഡിബി ഓപ്‌സ് മാനേജർ
[16]
3.2 ഡിസംബർ 8, 2015
  • സ്ഥിരമായി ഉപയോഗിക്കുന്ന വയർ‌ടൈഗർ സംഭരണ എഞ്ചിൻ
  • റെപ്ലിക്കേഷൻ തിരഞ്ഞെടുപ്പ് മെച്ചപ്പെടുത്തലുകൾ
  • കോൺഫിഗറേഷൻ സെർവറുകൾ റെപ്ലിക്ക സെറ്റ്സ്
  • റീഡ്കണസേൺ(readConcern)
  • പ്രമാണ മൂല്യനിർണ്ണയങ്ങൾ
  • വി8(V8)-ൽ നിന്ന് സ്‌പൈഡർമങ്കിയിലേക്ക് മാറി
[17]
3.4 നവംബർ 29, 2016
  • ലീനിറൈസിബിൾ റീഡിംഗ് കൺസേൺസ്
  • കാഴ്ചകൾ
  • കോളാഷൻ(collation)
[18]
3.6 നവംബർ 2017 [19]
4.0 ജൂൺ 2018
  • ഇടപാടുകൾ
[20]
4.2 ഓഗസ്റ്റ് 2019 [21]
4.4 ജൂലൈ 2020 [22]
4.4.5 ഏപ്രിൽ 2021 [23] [24]
4.4.6 മെയ് 2021 [25]

പ്രധാന സവിശേഷതകൾ[തിരുത്തുക]

അഡ്ഹോക് ക്വറീസ്[തിരുത്തുക]

ഫീൽഡ്, ശ്രേണി അന്വേഷണം, പതിവ് എക്‌സ്‌പ്രഷൻ തിരയലുകൾ എന്നിവ മോംഗോഡിബി പിന്തുണയ്ക്കുന്നു.[26] ചോദ്യങ്ങൾക്ക് പ്രമാണങ്ങളുടെ നിർ‌ദ്ദിഷ്‌ട ഫീൽ‌ഡുകൾ‌ നൽ‌കാനും ഉപയോക്താവ് നിർ‌വ്വചിച്ച ജാവാസ്ക്രിപ്റ്റ് ഫങ്ഷൻസും ഉൾ‌പ്പെടുത്താനും കഴിയും. ഒരു നിശ്ചിത വലിപ്പത്തിന്റെ ഫലങ്ങളുടെ ക്രമരഹിതമായ സാമ്പിൾ നൽകുന്നതിന് അന്വേഷണങ്ങൾ ക്രമീകരിക്കാനും കഴിയും.

ഇൻഡെക്സിംഗ്[തിരുത്തുക]

ഒരു മോംഗോഡിബി പ്രമാണത്തിലെ ഫീൽഡുകൾ പ്രാഥമിക, ദ്വിതീയ സൂചികകൾ ഉപയോഗിച്ച് ഇൻഡെക്സ് ചെയ്യാം

റെപ്ലിക്കേഷൻ[തിരുത്തുക]

റെപ്ലിക്ക സെറ്റുകളിൽ മോംഗോഡിബി ഉയർന്ന ലഭ്യത നൽകുന്നു.[27] ഒരു റെപ്ലിക്ക സെറ്റിൽ ഡാറ്റയുടെ രണ്ടോ അതിലധികമോ പകർപ്പുകൾ അടങ്ങിയിരിക്കുന്നു. ഓരോ റെപ്ലിക്ക സെറ്റ് അംഗത്തിനും എപ്പോൾ വേണമെങ്കിലും പ്രാഥമിക അല്ലെങ്കിൽ ദ്വിതീയ റെപ്ലിക്കയുടെ റോളിൽ പ്രവർത്തിക്കാം. എല്ലാ റൈറ്റുകളും റീഡുകളും പ്രാഥമിക റെപ്ലിക്കയിൽ സ്ഥിരസ്ഥിതിയായി ചെയ്യുന്നു. ബിൽറ്റ്-ഇൻ റെപ്ലിക്കേഷൻ ഉപയോഗിച്ച് ദ്വിതീയ പകർപ്പുകൾ പ്രാഥമിക ഡാറ്റയുടെ ഒരു പകർപ്പ് നിലനിർത്തുന്നു. ഒരു പ്രൈമറിയുടെ തനിപ്പകർ‌പ്പ് പരാജയപ്പെടുമ്പോൾ, ഏത് ദ്വിതീയമാണ് പ്രാഥമികമാകേണ്ടതെന്ന് നിർണ്ണയിക്കാൻ റെപ്ലിക്ക സെറ്റ് യാന്ത്രികമായി ഒരു തിരഞ്ഞെടുപ്പ് പ്രക്രിയ നടത്തുന്നു. സെക്കൻഡറികൾക്ക് ഓപ്‌ഷണലായി റീഡ് ഓപ്പറേഷനുകൾ നൽകാനാകും, പക്ഷേ ആ ഡാറ്റ സ്ഥിരമായിരിക്കും.

മോംഗോഡിബി വിന്യാസത്തിന് ഒരൊറ്റ ദ്വിതീയ അംഗം മാത്രമേ ഉള്ളൂവെങ്കിൽ, ഒരു ആർബിറ്റർ എന്ന് വിളിക്കുന്ന ഒരു പ്രത്യേക ഡെമൺ സെറ്റിലേക്ക് ചേർക്കേണ്ടതാണ്. ഇതിനൊരു ഉത്തരവാദിത്തമുണ്ട്, അത് പുതിയ പ്രൈമറിയുടെ തിരഞ്ഞെടുപ്പ് പരിഹരിക്കുക എന്നതാണ്. അനന്തരഫലമായി, അനുയോജ്യമായ ഡിസ്ട്രിബ്യൂട്ടട് മോംഗോഡിബി വിന്യാസത്തിന് കുറഞ്ഞത് മൂന്ന് പ്രത്യേക സെർവറുകളെങ്കിലും ആവശ്യമാണ്, ഒരു പ്രൈമറിയും, മറ്റൊന്ന് സെക്കൻട്രിയുടെ കാര്യത്തിലും.

ബാലൻസിംഗ് ലോഡുചെയ്യുക[തിരുത്തുക]

ഷാർഡിംഗ് ഉപയോഗിക്കുന്ന തിരശ്ചീനമായ മോംഗോഡിബി സ്കെയിലുകൾ.[28] ഉപയോക്താവ് ഒരു ഷാർഡ് കീ തിരഞ്ഞെടുക്കുന്നു, ഇത് ഒരു കളക്ഷനിലെ ഡാറ്റ എങ്ങനെ വിതരണം ചെയ്യുമെന്ന് നിർണ്ണയിക്കുന്നു. ഡാറ്റയെ ശ്രേണികളായി വിഭജിച്ചിരിക്കുന്നു (ഷാർഡ് കീ അടിസ്ഥാനമാക്കി) ഒന്നിലധികം ഷാർഡുകളിലായി വിതരണം ചെയ്യുന്നു. (ഒന്നോ അതിലധികമോ റീപ്ലിക്കകൾ ഉള്ള ഒരു മാസ്റ്ററാണ് ഷാർഡ്). പകരമായി, ഒരു ഷാർഡിലേക്ക് മാപ്പ് ചെയ്യുന്നതിന് ഷാർഡ് കീ ഹാഷ് ചെയ്യാൻ കഴിയും - ഒരു ഇരട്ട ഡാറ്റ വിതരണം പ്രാപ്തമാക്കുന്നു. ഹാർഡ്‌വെയർ തകരാറുണ്ടായാൽ സിസ്റ്റം നിലനിർത്തുന്നതിനും പ്രവർത്തിപ്പിക്കുന്നതിനും മോംഗോഡിബിക്ക് ഒന്നിലധികം സെർവറുകളിൽ പ്രവർത്തിക്കാനും ലോഡ് ബാലൻസ് ചെയ്യാനോ ഡാറ്റയുടെ തനിപ്പകർപ്പ് എടുക്കാനോ കഴിയും.

ഫയൽ സ്റ്റോറേജ്[തിരുത്തുക]

ഫയലുകൾ സംഭരിക്കുന്നതിനായി ഒന്നിലധികം മെഷീനുകളിൽ ലോഡ് ബാലൻസിംഗും ഡാറ്റ റെപ്ലിക്കേഷൻ സവിശേഷതകളും ഉപയോഗിച്ച് ഗ്രിഡ്എഫ്എസ്(GridFS)എന്ന് വിളിക്കുന്ന ഒരു ഫയൽ സിസ്റ്റമായി മോംഗോഡിബി ഉപയോഗിക്കാം.[29] ഗ്രിഡ് ഫയൽ സിസ്റ്റം എന്ന് വിളിക്കുന്ന ഈ പ്രവർത്തനം മോംഗോഡിബി ഡ്രൈവറുകളിൽ ഉൾപ്പെടുത്തിയിട്ടുണ്ട്. ഡവലപ്പർമാർക്ക് ഫയൽ മാനുപ്പുലേഷനും, ഉള്ളടക്കത്തിനുമുള്ള പ്രവർത്തനങ്ങൾ മോംഗോഡിബി തുറന്നുകാട്ടുന്നു.[30] മംഗോഫൈൽസ് യൂട്ടിലിറ്റി അല്ലെങ്കിൽ എൻ‌ജിൻ‌എക്സ്, ലൈറ്റ്ടി‌പിഡി എന്നിവയ്ക്കുള്ള പ്ലഗിനുകൾ ഉപയോഗിച്ച് ഗ്രിഡ് എഫ്എസ് ആക്സസ് ചെയ്യാൻ കഴിയും.[31]ഗ്രിഡ്എഫ്എസ് ഒരു ഫയലിനെ ഭാഗങ്ങളായി അല്ലെങ്കിൽ ചങ്കുകളായി(chunks) വിഭജിക്കുകയും ഓരോ ചങ്കുകളും പ്രത്യേക ഡോക്യുമെന്റായി സംഭരിക്കുകയും ചെയ്യുന്നു.[32]

അഗ്രഗേഷൻ[തിരുത്തുക]

അഗ്രഗേഷൻ നടത്തുന്നതിന് മോംഗോഡിബി മൂന്ന് വഴികൾ നൽകുന്നു: അഗ്രഗേഷൻ പൈപ്പ്ലൈൻ, മാപ്പ്-റിഡ്യൂസ് ഫംഗ്ഷൻ, സിംഗിൾ പർപ്പസ് അഗ്രഗേഷൻ മെത്തേഡുകൾ മുതലായവ.[33]

ഡാറ്റയുടെ ബാച്ച് പ്രോസസ്സിംഗിനും അഗ്രഗേഷൻ പ്രവർത്തനങ്ങൾക്കും മാപ്പ്-റിഡ്യൂസ് ഉപയോഗിക്കാം. എന്നാൽ മോംഗോഡിബിയുടെ ഡോക്യുമെന്റേഷൻ അനുസരിച്ച്, അഗ്രഗേഷൻ പൈപ്പ്ലൈൻ മിക്ക അഗ്രഗേഷൻ പ്രവർത്തനങ്ങൾക്കും മികച്ച പ്രകടനം നൽകുന്നു.[34]

എസ്ക്യൂഎൽ ഗ്രൂപ്പ്(SQL GROUP)ബൈ ക്ലോസ് ഉപയോഗിക്കുന്ന തരത്തിലുള്ള റിസൾട്ട് നേടുന്നതിന് അഗ്രഗേഷൻ ഫ്രെയിംവർക്ക് ഉപയോക്താക്കളെ പ്രാപ്തരാക്കുന്നു. അഗ്രഗേഷൻ ഓപ്പറേറ്റഴ്സിനെ ഒരുമിച്ച് കൂട്ടിച്ചേർത്ത് ഒരു പൈപ്പ് ലൈൻ രൂപപ്പെടുത്താം-യുണിക്സ്(Unix)പൈപ്പുകൾക്ക് സമാനമാണ്. ഒന്നിലധികം ശേഖരങ്ങളിൽ നിന്നുള്ള ഡോക്യുമെന്റുകളിൽ ചേരാൻ കഴിയുന്ന $lookup ഓപ്പറേറ്ററും സ്റ്റാൻഡേർഡ് ഡീവിയേഷൻ പോലുള്ള സ്റ്റാറ്റിസ്റ്റിക്കൽ ഓപ്പറേറ്റർമാരും അഗ്രഗേഷൻ ഫ്രെയിംവർക്കിൽ ഉൾപ്പെടുന്നു.

അവലംബം[തിരുത്തുക]

  1. "State of MongoDB March, 2010". DB-Engines (ഭാഷ: അമേരിക്കൻ ഇംഗ്ലീഷ്). മൂലതാളിൽ നിന്നും September 18, 2017-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് July 5, 2017.
  2. "Release Notes for MongoDB 6.0".
  3. "How to Set Up a MongoDB NoSQL Cluster Using Oracle Solaris Zones". Oracle. മൂലതാളിൽ നിന്നും August 12, 2017-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് July 5, 2017.
  4. "How-To: MongoDB on FreeBSD 10.x". FreeBSD News. മൂലതാളിൽ നിന്നും December 28, 2017-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് July 5, 2017.
  5. "10gen embraces what it created, becomes MongoDB Inc". Gigaom. മൂലതാളിൽ നിന്നും March 5, 2016-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് January 29, 2016.
  6. Witkowski, Wallace (October 21, 2017). "MongoDB shares rally 34% in first day of trading above elevated IPO price". MarketWatch. Dow Jones. മൂലതാളിൽ നിന്നും February 26, 2018-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് February 26, 2018.
  7. Betz, Brandy (2019-10-30). "MongoDB teams with Alibaba Cloud". Seeking Alpha. ശേഖരിച്ചത് 2019-10-31.
  8. "Release Notes for MongoDB 1.2.x". mongodb.com.
  9. "Release Notes for MongoDB 1.4". mongodb.com.
  10. "Release Notes for MongoDB 1.6". mongodb.com.
  11. "Release Notes for MongoDB 1.8". mongodb.com.
  12. "Release Notes for MongoDB 2.0". mongodb.com.
  13. "Release Notes for MongoDB 2.2". mongodb.com.
  14. "Release Notes for MongoDB 2.4". mongodb.com.
  15. "Release Notes for MongoDB 2.6". mongodb.com.
  16. "Release Notes for MongoDB 3.0". mongodb.com.
  17. "Release Notes for MongoDB 3.2". mongodb.com.
  18. "Release Notes for MongoDB 3.4". mongodb.com.
  19. "Release Notes for MongoDB 3.6". mongodb.com.
  20. "Release Notes for MongoDB 4.0". mongodb.com.
  21. "Release Notes for MongoDB 4.2". mongodb.com.
  22. "Release Notes for MongoDB 4.4". mongodb.com.
  23. "Release Notes for MongoDB 4.4". mongodb.com.
  24. "Release Notes for MongoDB 4.4". mongodb.com.
  25. "Release Notes for MongoDB 4.4". mongodb.com.
  26. Davis Kerby. "Why MongoDB is the way to go". DZone. മൂലതാളിൽ നിന്നും June 12, 2018-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് July 6, 2017.
  27. "Ridiculously fast MongoDB replica recovery Part 1 of 2". ClusterHQ. മൂലതാളിൽ നിന്നും October 30, 2017-ന് ആർക്കൈവ് ചെയ്തത്.
  28. "Turning MongoDB Replica Set to a Sharded Cluster". Severalnines. മൂലതാളിൽ നിന്നും November 25, 2016-ന് ആർക്കൈവ് ചെയ്തത്.
  29. "GridFS & MongoDB: Pros & Cons". Compose. മൂലതാളിൽ നിന്നും September 10, 2017-ന് ആർക്കൈവ് ചെയ്തത്.
  30. "NGINX plugin for MongoDB source code". GitHub. മൂലതാളിൽ നിന്നും April 11, 2016-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് September 10, 2016.
  31. "lighttpd plugin for MongoDB source code". Bitbucket. മൂലതാളിൽ നിന്നും August 7, 2011-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് June 28, 2010.
  32. Malick Md. "MongoDB overview". Expertstown. മൂലതാളിൽ നിന്നും March 5, 2014-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് February 27, 2014.
  33. "Aggregation — MongoDB Manual". docs.mongodb.com (ഭാഷ: ഇംഗ്ലീഷ്). മൂലതാളിൽ നിന്നും November 29, 2018-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് August 14, 2018.
  34. "Map-Reduce — MongoDB Manual". docs.mongodb.com (ഭാഷ: ഇംഗ്ലീഷ്). മൂലതാളിൽ നിന്നും August 14, 2018-ന് ആർക്കൈവ് ചെയ്തത്. ശേഖരിച്ചത് August 14, 2018.
"https://ml.wikipedia.org/w/index.php?title=മോംഗോഡിബി&oldid=3713845" എന്ന താളിൽനിന്ന് ശേഖരിച്ചത്