MongoDB
MongoDB software | |
---|---|
Genere | Database management system |
Sviluppatore | MongoDB Inc. |
Data prima versione | 2009 |
Ultima versione | 7.0.5 (5 gennaio 2024) |
Sistema operativo | Multipiattaforma |
Linguaggio | Python C JavaScript C++ Go |
Licenza | SSPL (Server Side Public License) (licenza non libera) |
Sito web | www.mongodb.com/ |
MongoDB(da "humongous ", enorme) è unDBMSnon relazionale,orientato ai documenti.
Classificato come un database di tipoNoSQL,MongoDB si allontana dalla struttura tradizionale basata su tabelle deidatabase relazionaliin favore di documenti in stileJSONcon schema dinamico (MongoDB chiama il formatoBSON), rendendo l'integrazione di dati di alcuni tipi di applicazioni più facile e veloce.
Sviluppato inizialmente dalla società di software 10gen (ora diventata MongoDB Inc.) nell'ottobre 2007 come un componente di un prodotto diplatform as a service,l'azienda si è spostata verso un modello di sviluppoopen sourcenel 2009, con 10gen in grado di offrire un supporto commerciale e altri servizi.[1]Da allora, MongoDB è stato adottato come backend da un alto numero di grandi siti web e società di servizi comeCraigslist,eBay,Foursquare,SourceForgee ilThe New York Times,tra gli altri. MongoDB è il più popolare database NoSQL.[2]
Storia
[modifica|modifica wikitesto]Lo sviluppo di MongoDB è iniziato nel 2007, quando l'azienda (allora chiamata 10gen) stava sviluppando unplatform as a servicesimile aWindows AzureoGoogle App Engine.[3]Nel 2009, MongoDB è stato reso open source come prodotto indipendente con una licenzaGNU AGPL.
Dalla versione 1.4 (marzo 2010), MongoDB è stato considerato production ready.[4]La versione stabile 3.0 è stata pubblicata il 3 febbraio 2015[5].
Licenza e supporto
[modifica|modifica wikitesto]MongoDB è disponibile gratuitamente sotto laServer Side Public License.Le librerie per i vari linguaggi sono disponibili sotto laApache License.In aggiunta, MongoDB Inc. offre licenze commerciali per MongoDB.[6]
Caratteristiche principali
[modifica|modifica wikitesto]Alcune delle caratteristiche principali sono:
Query ad hoc[7]
- MongoDB supporta ricerche per campi, intervalli eregular expression.Le query possono restituire campi specifici del documento e anche includere funzioni definite dall'utente in JavaScript.
Indicizzazione[8]
- Qualunque campo in MongoDB può essere indicizzato (gli indici in MongoDB sono concettualmente similari a quelli dei tradizionali database relazionali). Sono disponibili anche indici secondari, indici unici, indici sparsi, indici geospaziali e indici full text.
Alta Disponibilità[9]
- MongoDB fornisce alta disponibilità e aumento del carico gestito attraverso i replica set. Un replica set consiste in due o più copie dei dati. Ogni replica può avere il ruolo di copia primaria o secondaria in qualunque momento. La replica primaria effettua tutte le scritture e le letture. Le repliche secondarie mantengono una copia dei dati della replica primaria attraverso un meccanismo di replicazione incluso nel prodotto. Quando una replica primaria fallisce, il replica set inizia automaticamente un processo di elezione per determinare quale replica secondaria deve diventare primaria. Le copie secondarie possono anche effettuare letture, con dati eventualmente consistenti di default.
Sharding e bilanciamento dei dati[10]
- MongoDB scala orizzontalmente usando lo sharding. L'utente deve scegliere una chiave di sharding, che determina come i dati di una collection saranno distribuiti tra i vari nodi. I dati sono divisi in intervalli (basati sulla chiave di shard) e distribuiti su molteplici shard (uno shard è un replica set, quindi con una replica primaria e due o più repliche secondarie).
- MongoDB include un meccanismo di bilanciamento dei dati, spostando gli intervalli di dati da uno shard troppo carico a uno shard meno carico, in modo da bilanciare la distribuzione dei dati all'interno del cluster.
File Storage[11]
- MongoDB può essere usato anche come unfile system,traendo vantaggio dalla caratteristiche di replicazione e di bilanciamento su più server per memorizzare file, anche di grandi dimensioni.
- Questa funzione, chiamata GridFS, è inclusa nei driver di MongoDB e disponibile facilmente per tantissimi linguaggi di sviluppo. MongoDB espone delle funzioni per la manipolazione dei file. GridFS è usato, ad esempio, nei plugin di NGINX e lighttpd. Invece di memorizzare il file in un singolo documento, GridFS divide il file in tante parti più piccole, chiamate chunks, e memorizza ognuno di questi chunk in un documento separato.
- Ai file possono essere associati deimetadati,su cui è possibile anche creare degli indici full-text.
Aggregazione[12]
- MongoDB supporta due modalità di aggregazione dei dati: il MapReduce e l'Aggregration Framework. Quest'ultimo lavora come unapipelinee permette di ottenere risultati molto più rapidamente del MapReduce grazie all'implementazione in C++.
Capped Collection[13]
- MongoDB supporta collection a dimensioni fisse chiamate capped collection. Questo tipo di collection mantiene l'ordine di inserimento e una volta raggiunta la dimensione definita, si comporta come una coda circolare.
Supporto ai linguaggi di programmazione
[modifica|modifica wikitesto]MongoDB ha reso disponibiliSDKufficiali per i più popolari linguaggi di programmazione e ambienti di sviluppo. Esistono anche moltissimi progetti non ufficiali, sviluppati e supportati dalla comunità, per fornire supporto ad alcuni linguaggi meno diffusi.
Gestione e amministrazione del database
[modifica|modifica wikitesto]MongoDB Inc. mette a disposizione il servizio di monitoraggio e di backup, chiamatoMMS.Tramite l'installazione di un agent locale che invia dati al server MMS nel cloud, questo permette di monitorare le istanze di MongoDB senza dover installare software. L'utilizzo del servizio è ovviamente subordinato all'acquisto di una licenza commerciale.
Oltre a MMS ci sono alcuni tools già presenti nell'installazione di MongoDB:
mongo[14]
- MongoDB offre una shell interattiva chiamatamongo,la quale permette agli sviluppatori di:
- vedere, inserire, rimuovere e aggiornare i dati nei loro database;
- ottenere informazioni sulla replicazione, sulla configurazione dello sharding;
- spegnere i server;
- eseguire del codice JavaScript;
- molto altro.
- È possibile accedere alle informazioni amministrative anche attraverso un'interfaccia webche fornisce informazioni sullo stato corrente del server. La porta predefinita per l'interfaccia web è di 1000 superiore a quella predefinita del database (quindi 28017).
mongostat[15]
- mongostatè uno strumento a riga di comando che visualizza una lista riassuntiva delle statistiche di un'istanza di MongoDB in esecuzione: quante e che tipo di query sono eseguite così come la percentuale di tempo in cui il database è rimastolockato[non chiaro]e quanta memoria sta usando. Questo tool è simile al comandovmstatdi UNIX/Linux.
- mongotopè uno strumento a linea di comando che fornisce un metodo per tracciare la quantità di tempo usata da un'istanza di MongoDB a leggere e a scrivere dati. Fornisce statistiche a livello di collection. Di default, mongotop ritorna valori al secondo. Questo tool è simile al comandotopdi UNIX/Linux.
- mongosniffè un tool command-line che fornisce uno sniffing a basso livello dell'attività del database monitorando il traffico di rete in entrata e in uscita. Richiede la libreria di reteLibpcaped è disponibile solo per i sistemi UNIX-like. Un'alternativa cross-platform open source èWireshark,un analizzatore di pacchetti che ha il pieno supporto del protocollo di MongoDB.
mongoimport,mongoexport
- mongoimportè un'utility command-line per importare il contenuto da un file JSON, CSV o TSV creato da mongoexport o da qualunque export di terze parti che ne rispettano il formato.
mongodump, mongorestore
- mongodump è un'utility command-line per creare un export binario del contenuto di un database MongoDB. Mongorestore può essere usato per ricaricare un dump fatto con mongodump.
Popolarità
[modifica|modifica wikitesto]Secondo db-engines.com, a giugno 2018 MongoDB è al 5º posto della classifica dei database più diffuso al mondo e al 1º posto dei database NoSQL.[2]
Al 9 agosto 2022, MongoDB Inc. conta circa 31.000 clienti attivi che utilizzano il loro database per salvare i propri dati.[16]
Implementazioni popolari
[modifica|modifica wikitesto]Alcuni degli utilizzatori più significativi di MongoDB sono:
- MetLifeusa MongoDB per "The Wall", un'applicazione di servizio al cliente che fornisce una vista a 360 gradi dei clienti di MetLife.[17]
- Craigslistmemorizza oltre 2 miliardi di documenti in MongoDB.[senza fonte]
- SAPusa MongoDB in SAP platform-as-a-service.[senza fonte]
- Forbesmemorizza articoli e dati societari in MongoDB.[18]
- The New York Timesusa MongoDB nella sua applicazione di caricamento di fotografie.[19]
- Sourceforgeusa MongoDB come storage delle pagine.[senza fonte]
- Codecademyusa MongoDB come datastore per il suo sistema di learning online.[senza fonte]
- Shutteflyusa MongoDB per la sua piattaforma di fotografie. Nel 2013 la piattaforma aveva oltre 18 miliardi di foto caricate da oltre 7 milioni di utenti.[senza fonte]
- CERNusa MongoDB come back-end del Data Aggregation System nelLarge Hadron Collider.[senza fonte]
- Foursquareimplementa MongoDB suAmazon AWSper memorizzare località e le registrazioni degli utenti nelle località.[20]
- eBayusa MongoDB per i suggerimenti della ricerca e per State Hub, il Cloud Manager interno.[21]
- OwlStatutilizza MongoDB per il salvataggio delle statistiche.[senza fonte]
Note
[modifica|modifica wikitesto]- ^10gen diventa MongoDB,sugigaom.com.URL consultato il 3 maggio 2019(archiviato dall'url originaleil 16 novembre 2018).
- ^ab(EN)DB-Engines Ranking,suDB-Engines.URL consultato il 9 agosto 2022.
- ^Il papà di MongoDB: la mia creatura è meglio di Google Big Tables
- ^MongoDB 1.4 è pronto per la produzioneArchiviatol'8 luglio 2014 inInternet Archive.
- ^Announcing MongoDB 3.0 | MongoDB
- ^(EN)MongoDB Atlas Database | Multi-Cloud Database Service,suMongoDB.URL consultato il 9 agosto 2022.
- ^(EN)MongoDB CRUD Operations — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Indexes — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Replication — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Sharding — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)GridFS — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Aggregation Operations — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Capped Collections — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)mongo Shell Quick Reference — MongoDB Manual,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)mongostat — MongoDB Database Tools,suwww.mongodb.com.URL consultato il 9 agosto 2022.
- ^(EN)Our Customers,suMongoDB.URL consultato il 14 giugno 2021.
- ^(EN)MetLife's "Wall" Powered by MongoDB,suDATAVERSITY,22 novembre 2013.URL consultato il 14 giugno 2021.
- ^(EN)Forbes Embraces MongoDB On Google Cloud As Part Of Digital-first Strategy,suaster.cloud,14 novembre 2020.URL consultato il 14 giugno 2021.
- ^(EN)Case Study: The New York Times Runs MongoDB,suMongoDB.URL consultato il 14 giugno 2021(archiviato dall'url originaleil 14 giugno 2021).
- ^(EN)OSCON: How foursquare uses MongoDB to manage its data,suDell Technologies.URL consultato il 17 giugno 2021.
- ^How eBay Solves the Database Scaling Problem with MongoDB - Hybrid Cloud Management and Automation | Morpheus,sumorpheusdata.com.URL consultato il 17 giugno 2021.
Voci correlate
[modifica|modifica wikitesto]Altri progetti
[modifica|modifica wikitesto]- Wikimedia Commonscontiene immagini o altri file suMongoDB
Collegamenti esterni
[modifica|modifica wikitesto]- (EN)Sito ufficiale,sumongodb.com.
- MongoDB,supackages.debian.org.
- Repository sorgenti di MongoDB,sugithub.com.
- (EN)MongoDB,suFree Software Directory.
- Sito della 10gen,su10gen.com.
- MongoDB Italian linkedIn group,sulinkedin.com.
- (EN)Admin UIs[collegamento interrotto],sumongodb.com.Elenco delle principali interfacce di amministrazione sul sito di MongoDB.
Controllo di autorità | VIAF(EN)174499323·LCCN(EN)no2011130709·GND(DE)7724020-0·BNF(FR)cb16963009m(data)·J9U(EN,HE)987007384178205171 |
---|