മോംഗോഡിബി
വികസിപ്പിച്ചത് | MongoDB Inc. |
---|---|
ആദ്യപതിപ്പ് | ഫെബ്രുവരി 11, 2009[1] |
Stable release | 7.0.5[2]
/ 5 ജനുവരി 2024,10 മാസങ്ങൾക്ക് മുമ്പ് |
റെപോസിറ്ററി | |
ഭാഷ | 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 |
ക്രോസ്-പ്ലാറ്റ്ഫോം ഡോക്യുമെന്റ് ഓറിയന്റഡ് ഡാറ്റാബേസ് പ്രോഗ്രാം ആണ് മോംഗോഡിബി. ഒരു നോഎസ്ക്യൂഎൽ(NoSQL) ഡാറ്റാബേസ് പ്രോഗ്രാം എന്ന് തരംതിരിച്ചിട്ടുള്ള മോംഗോഡിബി സ്കീമയോടുകൂടിയ ജെസൺ(JSON)പോലുള്ള പ്രമാണങ്ങൾ ഉപയോഗിക്കുന്നു. മോംഗോഡിബി വികസിപ്പിച്ചെടുത്തത് മോംഗോഡിബി ഇങ്ക് ആണ്, സെർവർ സൈഡ് പബ്ലിക് ലൈസൻസിന് (എസ്എസ്പിഎൽ) കീഴിൽ ലൈസൻസുള്ളതാണ്.
ചരിത്രം
[തിരുത്തുക]ഒരു സേവന ഉൽപ്പന്നമെന്ന നിലയിൽ ആസൂത്രിതമായ ഒരു പ്ലാറ്റ്ഫോമിന്റെ ഘടകമായി ടെൻജെൻ(10gen) സോഫ്റ്റ്വേർ കമ്പനി 2007 ൽ മോംഗോഡിബി വികസിപ്പിക്കാൻ തുടങ്ങി. 2009 ൽ കമ്പനി ഒരു ഓപ്പൺ സോഴ്സ് ഡെവലപ്മെന്റ് മോഡലിലേക്ക് മാറി, വാണിജ്യ പിന്തുണയും മറ്റ് സേവനങ്ങളും കമ്പനി വാഗ്ദാനം ചെയ്തു. 2013 ൽ ടെൻജെൻ അതിന്റെ പേര് മോംഗോഡിബി ഇങ്ക് എന്ന് മാറ്റി.[5]
ഒക്ടോബർ 20, 2017 ന്, മോംഗോഡിബി ഒരു പൊതു വ്യാപാരം നടത്തുന്ന കമ്പനിയായി മാറി, നാസ്ഡാക്കിൽ എംഡിബിയായി ലിസ്റ്റുചെയ്തിട്ടുണ്ട്, ഓരോ ഷെയറിനും 24 ഡോളർ ഐപിഒ വിലയുണ്ട്. [6]
2019 ഒക്ടോബർ 30 ന് മോംഗോഡിബി അലിബാബ ക്ലൗഡുമായി ചേർന്നു, ഉപയോക്താക്കൾക്ക് മോംഗോഡിബി-ആസ്-എ-സർവ്വീസ് സൊലൂഷൻ വാഗ്ദാനം ചെയ്യും. ഉപയോക്താക്കൾക്ക് ബാബയുടെ(BABA) ആഗോള ഡാറ്റാ സെന്ററുകളിൽ നിന്ന് നിയന്ത്രിത ഓഫർ ഉപയോഗിക്കാൻ കഴിയും.[7]
പതിപ്പ് | റിലീസ് തീയതി | ഫീച്ചേഴ്സ് നോട്ട്സ് | റെഫ് | |
---|---|---|---|---|
1.0 | ഫെബ്രുവരി 2009 | |||
1.2 | ഡിസംബർ 2009 |
|
[8] | |
1.4 | മാർച്ച് 2010 | [9] | ||
1.6 | ഓഗസ്റ്റ് 2010 |
|
[10] | |
1.8 | മാർച്ച് 2011 | [11] | ||
2.0 | സെപ്റ്റംബർ 2011 | [12] | ||
2.2 | ഓഗസ്റ്റ് 2012 | [13] | ||
2.4 | മാർച്ച് 2013 |
|
[14] | |
2.6 | ഏപ്രിൽ 8, 2014 |
|
[15] | |
3.0 | മാർച്ച് 3, 2015 |
|
[16] | |
3.2 | ഡിസംബർ 8, 2015 |
|
[17] | |
3.4 | നവംബർ 29, 2016 |
|
[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 ഓപ്പറേറ്ററും സ്റ്റാൻഡേർഡ് ഡീവിയേഷൻ പോലുള്ള സ്റ്റാറ്റിസ്റ്റിക്കൽ ഓപ്പറേറ്റർമാരും അഗ്രഗേഷൻ ഫ്രെയിംവർക്കിൽ ഉൾപ്പെടുന്നു.
അവലംബം
[തിരുത്തുക]- ↑ "State of MongoDB March, 2010". DB-Engines (in അമേരിക്കൻ ഇംഗ്ലീഷ്). Archived from the original on September 18, 2017. Retrieved July 5, 2017.
- ↑ "Release Notes for MongoDB 7.0.5".
- ↑ "How to Set Up a MongoDB NoSQL Cluster Using Oracle Solaris Zones". Oracle. Archived from the original on August 12, 2017. Retrieved July 5, 2017.
- ↑ "How-To: MongoDB on FreeBSD 10.x". FreeBSD News. Archived from the original on December 28, 2017. Retrieved July 5, 2017.
- ↑ "10gen embraces what it created, becomes MongoDB Inc". Gigaom. Archived from the original on March 5, 2016. Retrieved January 29, 2016.
- ↑ Witkowski, Wallace (October 21, 2017). "MongoDB shares rally 34% in first day of trading above elevated IPO price". MarketWatch. Dow Jones. Archived from the original on February 26, 2018. Retrieved February 26, 2018.
- ↑ Betz, Brandy (2019-10-30). "MongoDB teams with Alibaba Cloud". Seeking Alpha. Retrieved 2019-10-31.
- ↑ "Release Notes for MongoDB 1.2.x". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 1.4". mongodb.com. Archived from the original on 2021-06-21. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 1.6". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 1.8". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 2.0". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 2.2". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 2.4". mongodb.com. Archived from the original on 2021-06-21. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 2.6". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 3.0". mongodb.com. Archived from the original on 2021-06-21. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 3.2". mongodb.com. Archived from the original on 2021-07-05. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 3.4". mongodb.com. Archived from the original on 2021-06-20. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 3.6". mongodb.com. Archived from the original on 2021-06-12. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 4.0". mongodb.com. Archived from the original on 2018-09-08. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 4.2". mongodb.com. Archived from the original on 2019-10-03. Retrieved 2019-10-23.
- ↑ "Release Notes for MongoDB 4.4". mongodb.com. Archived from the original on 2020-08-12. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 4.4". mongodb.com. Archived from the original on 2020-08-12. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 4.4". mongodb.com. Archived from the original on 2020-08-12. Retrieved 2021-06-23.
- ↑ "Release Notes for MongoDB 4.4". mongodb.com. Archived from the original on 2020-08-12. Retrieved 2021-06-23.
- ↑ Davis Kerby. "Why MongoDB is the way to go". DZone. Archived from the original on June 12, 2018. Retrieved July 6, 2017.
- ↑ "Ridiculously fast MongoDB replica recovery Part 1 of 2". ClusterHQ. Archived from the original on October 30, 2017.
- ↑ "Turning MongoDB Replica Set to a Sharded Cluster". Severalnines. Archived from the original on November 25, 2016.
- ↑ "GridFS & MongoDB: Pros & Cons". Compose. Archived from the original on September 10, 2017.
- ↑ "NGINX plugin for MongoDB source code". GitHub. Archived from the original on April 11, 2016. Retrieved September 10, 2016.
- ↑ "lighttpd plugin for MongoDB source code". Bitbucket. Archived from the original on August 7, 2011. Retrieved June 28, 2010.
- ↑ Malick Md. "MongoDB overview". Expertstown. Archived from the original on March 5, 2014. Retrieved February 27, 2014.
- ↑ "Aggregation — MongoDB Manual". docs.mongodb.com (in ഇംഗ്ലീഷ്). Archived from the original on November 29, 2018. Retrieved August 14, 2018.
- ↑ "Map-Reduce — MongoDB Manual". docs.mongodb.com (in ഇംഗ്ലീഷ്). Archived from the original on August 14, 2018. Retrieved August 14, 2018.