Diferencia entre revisiones de «MongoDB»
m Correcciones en acentuación y uso del lenguaje. |
Evitar anglicismos Etiquetas: Edición visual Edición desde móvil Edición vía web móvil |
||
(No se muestran 203 ediciones intermedias de más de 100 usuarios) | |||
Línea 1: | Línea 1: | ||
{{formato de cita|t=20141216085952}} |
|||
{{Desactualizado|t=20231206185826}} |
|||
{{Ficha de software |
{{Ficha de software |
||
| |
|nombre = MongoDB |
||
| |
|logo = |
||
| |
|desplegable = |
||
| |
|captura = |
||
|pie = |
|||
| fecha_última_versión = {{fecha de lanzamiento|20|03|2012}} |
|||
|desarrollador = MongoDB Inc. |
|||
| sistema_operativo = [[Multiplataforma]] |
|||
| |
|autor = |
||
| |
|modelo_desarrollo = [[Software libre]] |
||
| |
|lanzamiento = 2009 <!-- {{fecha|DD|MM|AAAA}} --> |
||
| |
|web_lanzamiento = |
||
|última_versión = <!-- wikidata --> |
|||
|modelo_desarrollo = [[Codigo abierto]] |
|||
|género = [[Base de datos]], [[NoSQL]] |
|||
| lenguaje_programación = [[C++]] |
|||
|lenguaje_programación = [[C++]] |
|||
|sistema_operativo = [[Multiplataforma]] |
|||
|plataforma = |
|||
|licencia = <!-- wikidata --> |
|||
|estado = |
|||
|idiomas = |
|||
|español = <!-- Sí / No --> |
|||
|sitio_web = http://www.mongodb.org/ |
|||
|soporte = |
|||
|versiones = |
|||
}} |
}} |
||
'''MongoDB''' (de la palabra en ingles “hu'''mongo'''us” que significa enorme) es un sistema de [[base de datos]] [[NoSQL]] orientado a documentos, desarrollado bajo el concepto de [[código abierto]]. |
|||
'''MongoDB''' (del inglés ''hu'''mongo'''us'', "enorme"{{Citation needed|reason=de dónde proviene esta información? No puedo encontrar esta referencia en mongodb.org|date=October 2022}}) es un sistema de [[base de datos]] [[NoSQL]], [[Base de datos documental|orientado a documentos]] y de [[código abierto]]. |
|||
MongoDB forma parte de la nueva familia de sistemas de base de datos NoSQL. En vez de guardar los datos en tablas como se hace en las base de datos relacionales, MongoDB guarda estructuras de datos en documentos tipo [[JSON]] con un esquema dinámico (MongoDB llama ese formato [[BSON]]), haciendo que la integración de los datos en ciertas aplicaciones sea mas fácil y rápida. |
|||
En lugar de guardar los datos en tablas, tal y como se hace en las [[Base de datos relacional|bases de datos relacionales]], MongoDB guarda estructuras de datos [[BSON]] (una especificación similar a [[JSON]]) con un esquema dinámico, haciendo que la integración de los datos en ciertas aplicaciones sea más fácil y rápida. |
|||
El desarrollo de MongoDB empezó en octubre de 2007 por la compañía de software [http://www.10gen.com/ 10gen]. Ahora MongoDB es una base de datos lista para la producción de uso y con muchas características (feature). Esta base de datos es altamente utilizada en las industrias y MTV Network<ref>http://blog.mongodb.org/post/5360007734/mongodb-powering-mtvs-web-properties</ref>, Craiglist<ref>http://blog.mongodb.org/post/5545198613/mongodb-live-at-craigslist</ref> y Foursquare<ref>http://blip.tv/mongodb/mongodb-at-foursquare-3723202</ref> son algunas de las empresas que utilizan esta base de datos. |
|||
MongoDB es una base de datos adecuada para su uso en producción y con múltiples funcionalidades. Esta base de datos se utiliza mucho en la industria,<ref>{{Cita web|url=https://db-engines.com/en/ranking|título=DB-Engines Ranking|fechaacceso=9 de agosto de 2019|sitioweb=DB-Engines|idioma=en}}</ref> contando con implementaciones en empresas como MTV Network,<ref>{{Cita web|url=https://www.mongodb.com/blog/post/mongodb-powering-mtvs-web-properties|título=MongoDB Powering MTV's Web Properties {{!}} MongoDB Blog|fechaacceso=9 de agosto de 2019|sitioweb=MongoDB|idioma=en-us}}</ref> Craigslist,<ref>{{Cita web|url=https://www.mongodb.com/blog/post/mongodb-live-at-craigslist|título=MongoDB live at Craigslist {{!}} MongoDB Blog|fechaacceso=9 de agosto de 2019|sitioweb=MongoDB|idioma=en-us}}</ref> Foursquare.<ref>{{cita web|url=http://blip.tv/mongodb/mongodb-at-foursquare-3723202|título=http://blip.tv/mongodb/mongodb-at-foursquare-3723202|urlarchivo=https://web.archive.org/web/20120608101623/http://blip.tv/mongodb/mongodb-at-foursquare-3723202|fechaarchivo=8 de junio de 2012}}</ref> |
|||
El [[código binario]] está disponible para los sistemas operativos [[Windows]], [[Linux]], [[OS X]] y [http://es.wikipedia.org/wiki/Solaris_%28sistema_operativo%29 Solaris]. |
|||
El [[código fuente]] está disponible para los sistemas operativos [[Windows]], [[GNU/Linux]], [[OS X]] y [[Solaris_(sistema_operativo)|Solaris]]. |
|||
== Historia == |
== Historia == |
||
El desarrollo de MongoDB |
El desarrollo de MongoDB comenzó en 2007 de la mano de 10gen Inc. (ahora llamada MongoDB Inc.)<ref name=":0">{{Cita web|url=https://www.mongodb.com/press/10gen-announces-company-name-change-mongodb-inc|título=10gen Announces Company Name Change to MongoDB, Inc.|fechaacceso=6 de mayo de 2016|sitioweb=MongoDB}}</ref> cuando desarrollaban una [[plataforma como servicio]] (PaaS) similar al conocido Google App Engine.<ref>{{cita web|url=http://www.theregister.co.uk/2011/05/25/the_once_and_future_mongodb/|título=MongoDB daddy: My baby beats Google BigTable|fechaacceso=27 octubre 2022|autor=Cade Metz|fecha=25 de mayo de 2011|idioma=en}}</ref> En 2009 MongoDB fue lanzado como un producto independiente y publicado bajo la licencia de código abierto [[AGPL]].<ref name="blog.mongodb_1">{{cita web |url=http://blog.mongodb.org/post/103832439/the-agpl|título=http://blog.mongodb.org/post/103832439/the-agpl}}</ref> |
||
En marzo de 2011, se lanzó la versión 1.4 y se consideró ya como una base de datos lista para su uso en producción.<ref>http://blog.mongodb.org/post/472835820/mongodb-1-4-ready-for-production</ref> |
En marzo de 2011, se lanzó la versión 1.4 y se consideró ya como una base de datos lista para su uso en producción.<ref>{{cita web|url=http://blog.mongodb.org/post/472835820/mongodb-1-4-ready-for-production|título=http://blog.mongodb.org/post/472835820/mongodb-1-4-ready-for-production|urlarchivo=https://web.archive.org/web/20140708154101/http://blog.mongodb.org/post/472835820/mongodb-1-4-ready-for-production|fechaarchivo=8 de julio de 2014}}</ref> |
||
En julio de 2022 se lanzó la versión 6.0 y el 15 de agosto de 2023 la versión 7.0. |
|||
== Concesión de licencias y soporte == |
== Concesión de licencias y soporte == |
||
MongoDB se puede obtener de |
MongoDB se puede obtener de forma gratuita bajo la licencia pública general de Affero ([[AGPL]]) de [[GNU]].<ref name="blog.mongodb_1"/> Los [[drivers]] para los [[lenguajes de programación]] están bajo la [[Licencia Apache|licencia de Apache]]. Además de estas licencias, MongoDB Inc. ofrece una licencia comercial que incluye características avanzadas (como integración con [[SASL]], [[LDAP]], [[Kerberos]],<ref>{{Cita web|url=https://docs.mongodb.com/manual/core/authentication-mechanisms-enterprise/|título=Enterprise Authentication Mechanisms — MongoDB Manual 3.2|fechaacceso=6 de mayo de 2016|sitioweb=docs.mongodb.com}}</ref> [[Simple Network Management Protocol]]<ref>{{Cita web|url=https://docs.mongodb.com/manual/tutorial/monitor-with-snmp/|título=Monitor MongoDB With SNMP on Linux — MongoDB Manual 3.2|fechaacceso=6 de mayo de 2016|sitioweb=docs.mongodb.com}}</ref> y búsqueda de texto de [[Rosette Linguistics Platform de Basis Technology]]<ref>{{Cita web|url=https://docs.mongodb.com/manual/tutorial/text-search-with-rlp/|título=Text Search with Basis Technology Rosette Linguistics Platform — MongoDB Manual 3.2|fechaacceso=6 de mayo de 2016|sitioweb=docs.mongodb.com}}</ref>), herramientas de gestión, monitorización y backup, así como soporte.<ref>{{cita web |url=https://www.mongodb.com/lp/contact/enterprise|título=https://www.mongodb.com/lp/contact/enterprise}}</ref> |
||
== Características principales == |
== Características principales == |
||
=== Consultas ad hoc === |
|||
Lo siguiente es una breve descripción de las características principales de MongoDB: |
|||
MongoDB soporta la búsqueda por campos, consultas de rangos y expresiones regulares. Las consultas pueden devolver un campo específico del documento pero también puede ser una función definida por el usuario para su mejor ocupación. |
|||
=== Consultas Ad hoc === |
|||
MongoDB soporta la búsqueda por campos, consultas de rangos y expresiones regulares. Las consultas pueden devolver un campo específico del documento pero también puede ser una función [[JavaScript]] definida por el usuario. |
|||
=== Indexación === |
=== Indexación === |
||
Cualquier campo en un documento de MongoDB puede ser indexado, al igual que es posible hacer índices secundarios. El concepto de índices en MongoDB es similar |
Cualquier campo en un documento de MongoDB puede ser indexado, al igual que es posible hacer índices secundarios. El concepto de índices en MongoDB es similar al empleado en [[Base de datos relacional|base de datos relacionales]]. |
||
=== Replicación === |
=== Replicación === |
||
MongoDB soporta el tipo de replicación |
MongoDB soporta el tipo de replicación primario-secundario. Cada grupo de primario y sus secundarios se denomina replica set.<ref>{{cita web |url=https://docs.mongodb.org/manual/replication/|título=https://docs.mongodb.org/manual/replication/}}</ref> El primario puede ejecutar comandos de lectura y escritura. Los secundarios replican los datos del primario y sólo se pueden usar para lectura o para copia de seguridad, pero no se pueden realizar escrituras. Los secundarios tienen la habilidad de poder elegir un nuevo primario en caso de que el primario actual deje de responder. |
||
=== Balanceo de carga === |
=== Balanceo de carga === |
||
MongoDB |
MongoDB puede escalar de forma horizontal usando el concepto de ''[[Shard_(arquitectura_de_base_de_datos)|shard]] ''.<ref>{{cita web |url=http://www.mongodb.org/display/DOCS/Sharding|título=http://www.mongodb.org/display/DOCS/Sharding}}</ref> El desarrollador elige una clave de sharding, la cual determina cómo serán distribuidos los datos de una colección. Los datos son divididos en rangos (basado en la clave de sharding) y distribuidos a través de múltiples shard. Cada shard puede ser una réplica set. |
||
MongoDB tiene la capacidad de ejecutarse en múltiple servidores, balanceando la carga y/o |
MongoDB tiene la capacidad de ejecutarse en múltiple servidores, balanceando la carga y/o replicando los datos para poder mantener el sistema funcionando en caso de que exista un fallo de hardware. La configuración automática es fácil de implementar bajo [https://tekslate.com/sort-document-mongodb/ MongoDB] y se pueden agregar nuevas servidores a MongoDB con el sistema de base de datos funcionando. |
||
=== Almacenamiento de archivos === |
=== Almacenamiento de archivos === |
||
MongoDB puede ser utilizado como un [[sistema de archivos]], aprovechando la capacidad de MongoDB para el balanceo de carga y la replicación de datos en múltiples servidores. Esta funcionalidad, llamada GridFS<ref>{{cita web |url=http://www.mongodb.org/display/DOCS/GridFS|título=http://www.mongodb.org/display/DOCS/GridFS}}</ref> e incluida en la distribución oficial, implementa sobre los drivers, no sobre el servidor,<ref>{{Cita web|url=https://github.com/mongodb/specifications/blob/master/source/gridfs/gridfs-spec.rst|título=mongodb/specifications|fechaacceso=12 de abril de 2016|sitioweb=GitHub}}</ref> una serie de funciones y métodos para manipular archivos y contenido. En un sistema con múltiple servidores, los archivos pueden ser distribuidos y replicados entre los mismos de forma transparente, creando así un sistema eficiente tolerante de fallos y con balanceo de carga. |
|||
MongoDB puede ser utilizado con un [[sistema de archivos]], tomando la ventaja de la capacidad que tiene MongoDB para el balanceo de carga y la replicación de datos utilizando múltiples servidores para el almacenamiento de archivos. |
|||
Esta función (que es llamada GridFS<ref>http://www.mongodb.org/display/DOCS/GridFS</ref>) está incluida en los drivers de MongoDB y disponible para los lenguajes de programación que soporta MongoDB. Esta base de datos expone funciones para la manipulación de archivos y contenido a los desarrolladores. |
|||
En un sistema con multiple servidores, los archivos pueden ser distribuidos y copiados entre los mismos varias veces y de una forma transparente, de esta forma se crea un sistema eficiente que maneja fallos y balanceo de carga. |
|||
=== Agregación === |
=== Agregación === |
||
MongoDB proporciona un framework de agregación que permite realizar operaciones similares al "GROUP BY" de SQL. El framework de agregación está construido como un pipeline en el que los datos van pasando a través de diferentes etapas en los cuales estos datos son modificados, agregados, filtrados y formateados hasta obtener el resultado deseado. Todo este procesado es capaz de utilizar índices si existieran y se produce en memoria. |
|||
La función MapReduce puede ser utilizada para el procesamiento por lotes de datos y operaciones de agregación. Esta función permite que los usuarios puedan obtener el tipo de resultado que se obtiene cuando se utiliza el comando SQL “group-by”. |
|||
Asimismo, MongoDB proporciona una función MapReduce que puede ser utilizada para el procesamiento por lotes de datos y operaciones de agregación. |
|||
=== Ejecución de JavaScript del lado del servidor === |
=== Ejecución de JavaScript del lado del servidor === |
||
MongoDB tiene la capacidad de realizar consultas utilizando JavaScript, haciendo que estas sean enviadas directamente a la base de datos para ser ejecutadas. |
MongoDB tiene la capacidad de realizar consultas utilizando JavaScript, haciendo que estas sean enviadas directamente a la base de datos para ser ejecutadas. |
||
== Fragmentación (''sharding'') == |
|||
Si estás desarrollando un servicio que se va haciendo popular o los niveles de acceso a base de datos son cada vez más altos, empezarás a notar que tu base de datos está siendo atacada por un tráfico creciente y tu servidor esté sufriendo por los altos niveles de estrés y te podrías ver en la necesidad de actualizar tu infraestructura para soportar la demanda. |
|||
Aquí entra en juego el sharding, es el modo en el que hacemos nuestra base de datos escalable. En lugar de tener una colección en una base de datos, la pondríamos en varias bases de datos distribuidas, de modo que a la hora de consultar los datos de dicha colección, los recuperemos como si de una única base de datos se tratase. Mongo se encargará de averiguar de manera transparente en qué base de datos se encuentran los datos. |
|||
Los fragmentos estarán formados por replica set, de modo que si creamos tres fragmentos, cada uno de los cuales tiene una replica set con tres servidores, estaríamos hablando de un total de nueve servidores. |
|||
Las consultas se realizan de manera distribuida a través de un módulo enrutador, “MongoS”, que mantiene un pool de conexiones a los distintos hosts. Para distribuir los datos de una colección ordenada, se trocea la colección en rangos a los que se les asigna un identificador (''shard key''), que puede ser una parte del propio documento, y se distribuye entre los ''replica sets''. |
|||
== Principales limitaciones == |
|||
=== Implementación de propiedades ACID multidocumento === |
|||
MongoDB solo garantizaba ACID dentro del mismo documento. El no implementar las propiedades [[ACID]] generaba que la base de datos no aseguraran la durabilidad, la integridad, la consistencia y el aislamiento requeridos obligatoriamente en las transacciones. El soporte para transacciones [[ACID]] de múltiples documentos se agregó a MongoDB en la versión 4.0 de junio de 2018. |
|||
Sobre la base de este punto se detallan los cuatro siguientes: |
|||
* '''Problemas de consistencia''' |
|||
En versiones anteriores de la base de datos las lecturas estrictamente consistentes ven versiones obsoletas de documentos, también pueden devolver datos incorrectos de lecturas que nunca deberían haber ocurrido.<ref>{{cita web |url=https://aphyr.com/posts/322-call-me-maybe-mongodb-stale-reads|título=Call me maybe: MongoDB stale reads}}</ref> |
|||
Este problema se considera solucionado a partir de la versión 3.4: https://jepsen.io/analyses/mongodb-3-4-0-rc3 |
|||
* '''Bloqueo a nivel de documento''' |
|||
MongoDB bloquea la base de datos a nivel de documento ante cada operación de escritura. Sólo se podrán hacer operaciones de escritura concurrentes entre distintos documentos. |
|||
* '''Las escrituras no son durables ni verificables''' |
|||
MongoDB retorna cuando todavía no se ha escrito la información en el espacio de almacenamiento permanente, lo que puede ocasionar pérdidas de información. En MongoDB 2.2 se cambia el valor por defecto para escribir en al menos una réplica, pero esto sigue sin satisfacer la durabilidad ni la verificabilidad.<ref>{{cita web |url=http://hackingdistributed.com/2013/01/29/mongo-ft/|título=Broken by Design: MongoDB Fault Tolerance :: Hacking, Distributed}}</ref> |
|||
* '''Problemas de escalabilidad''' |
|||
Tiene problemas de rendimiento cuando el volumen de datos supera los 100GB.<ref>{{cita web |url=http://jaxenter.com/mongodb-mocked-after-posting-100gb-scaling-checklist-48377.html|título=MongoDB mocked after posting “100GB Scaling Checklist”}}</ref> |
|||
== Casos de uso == |
== Casos de uso == |
||
La base de datos MongoDB es adecuada para los siguientes usos:<ref>http://www.mongodb.org/display/DOCS/Use+Cases</ref> |
La base de datos MongoDB es adecuada para los siguientes usos:<ref>{{cita web |url=http://www.mongodb.org/display/DOCS/Use+Cases|título=http://www.mongodb.org/display/DOCS/Use+Cases}}</ref> |
||
* Almacenamiento y registro de eventos |
* Almacenamiento y registro de eventos |
||
* |
* Sistemas de manejo de documentos y contenido |
||
* [[Comercio electrónico |
* [[Comercio electrónico]] |
||
* Juegos |
* Juegos |
||
* |
* Sistemas con alto volumen de lecturas |
||
* Aplicaciones móviles |
* Aplicaciones móviles |
||
* Almacén de datos operacional de |
* Almacén de datos operacional de sitios web |
||
**Almacenamiento de comentarios |
|||
* Manejo de contenido |
|||
**Votaciones |
|||
* Almacenamiento de comentarios |
|||
**Registro de usuarios |
|||
:* Votaciones |
|||
**Perfiles de usuarios |
|||
**Sesiones de datos |
|||
*Proyectos que utilizan metodologías de desarrollo iterativo o ágiles |
|||
:* Sesiones de datos |
|||
*Manejo de estadísticas en tiempo real |
|||
:* etc. |
|||
* Proyectos que utilizan metodologías de desarrollo iterativo o ágiles |
|||
MongoDB es utilizado para uno o varios de estos casos por varias empresas.<ref>{{cita web|url=http://www.mongodb.org/display/DOCS/Production+Deployments|título=http://www.mongodb.org/display/DOCS/Production+Deployments|urlarchivo=https://web.archive.org/web/20120510084455/http://www.mongodb.org/display/DOCS/Production+Deployments|fechaarchivo=10 de mayo de 2012}}</ref> |
|||
* Manejo de estadísticas en tiempo real |
|||
MongoDB es utilizado para uno o varios de estos casos por varias empresas.<ref>http://www.mongodb.org/display/DOCS/Production+Deployments</ref> |
|||
== Manipulación de datos: colecciones y documentos == |
== Manipulación de datos: colecciones y documentos == |
||
MongoDB guarda la estructura de los datos en documentos |
MongoDB guarda la estructura de los datos en documentos BSON con un esquema dinámico, lo que implica que no existe un esquema predefinido. Los elementos de los datos se denominan documentos y se guardan en colecciones. Una colección puede tener un número indeterminado de documentos. Comparando con una base de datos relacional, se puede decir que las colecciones son como tablas y los documentos son registros en la tabla. La diferencia es que en una base de datos relacional cada registro en una tabla tiene la misma cantidad de campos, mientras que en MongoDB cada documento en una colección puede tener diferentes campos. |
||
En un documento, se pueden agregar, eliminar, modificar o renombrar nuevos campos en cualquier momento,<ref>{{cita web|url=http://www.mongodbspain.com/wp-content/uploads/2014/03/MongoDBSpain-CheetSheet.pdf|título=http://www.mongodbspain.com/wp-content/uploads/2014/03/MongoDBSpain-CheetSheet.pdf|fechaacceso=27 de marzo de 2014|urlarchivo=https://web.archive.org/web/20140328041650/http://www.mongodbspain.com/wp-content/uploads/2014/03/MongoDBSpain-CheetSheet.pdf|fechaarchivo=28 de marzo de 2014}}</ref> ya que no hay un esquema predefinido. La estructura de un documento es simple y compuesta por pares llave/valor, parecido a las matrices asociativas en un lenguaje de programación, esto se debe a que MongoDB sigue el formato de JSON. En MongoDB la clave es el nombre del campo y el valor es su contenido, los cuales se separan mediante el uso de “:”, tal y como se puede ver en el siguiente ejemplo. |
|||
Los elementos de los datos son llamados documentos y se guardan en colecciones. Una colección puede tener un número indeterminado de documentos. |
|||
Como valor se pueden usar números, cadenas o datos binarios como imágenes o cualquier otro. |
|||
Comparando con una base de datos relacional, se puede decir que las colecciones son como tablas y los documentos son archivos. La diferencia es que en una base de datos relacional cada archivo en una tabla tiene la misma cantidad de campos, mientras que en MongoDB cada documento en una colección puede tener diferentes campos. |
|||
<syntaxhighlight lang="javascript"> |
|||
En un documento, se pueden agregar, eliminar, modificar o renombrar nuevos campos en cualquier momento, ya que no hay un esquema predefinido. La estructura de un documento es simple y compuesta por “key-value pairs” parecido a las matrices asociativas en un lenguaje de programación, esto es debido a que MongoDB sigue el formato de JSON. En MongoDB la clave es el nombre del campo y el valor es su contenido, los cuales se separan mediante el uso de “:”, tal y como se puede ver en el siguiente ejemplo. |
|||
Como valor se pueden usar números, cadenas o datos binarios como imágenes o cualquier otro “key-value pairs”. |
|||
<source lang="javascript"> |
|||
{ |
{ |
||
"_id": ObjectId("4efa8d2b7d284dad101e4bc7"), |
"_id": ObjectId("4efa8d2b7d284dad101e4bc7"), |
||
Línea 92: | Línea 133: | ||
} |
} |
||
} |
} |
||
</syntaxhighlight> |
|||
</source> |
|||
En este ejemplo se puede ver que en el campo “Address” se contiene otro documento que tiene los campos de “Street” y “City”. |
En este ejemplo se puede ver que en el campo “Address” se contiene otro documento que tiene los campos de “Street” y “City”. |
||
== Lenguaje de programación soportado == |
|||
== Lenguajes de programación soportados == |
|||
MongoDB tiene drivers oficiales para los siguientes lenguajes de programación: |
|||
Según la documentación oficial de MongoDB, este sistema tiene controladores oficiales para los siguientes lenguajes de programación: |
|||
* C |
|||
* [[C (lenguaje de programación)|C]] |
|||
* [[C++]] |
* [[C++]] |
||
* [[C#]] / [[.NET]] |
* [[C Sharp|C#]] / [[.NET]] |
||
* [[Erlang]] |
|||
* [[Haskell]] |
|||
* [[Java (lenguaje de programación)|Java]] |
* [[Java (lenguaje de programación)|Java]] |
||
* [[JavaScript]] |
* [[JavaScript]] |
||
* [[ |
* [[Node.js]] |
||
* node.JS |
|||
* [[Perl]] |
* [[Perl]] |
||
* [[PHP]] |
* [[PHP]] |
||
* [[Python]] |
* [[Python]] |
||
* [[Ruby]] |
* [[Ruby]] |
||
* [[Scala]] |
* [[Scala (lenguaje de programación)|Scala]] |
||
* [[Embarcadero_Delphi|Delphi]] |
|||
*C++ Builder |
|||
== Instrumentos de MongoDB == |
== Instrumentos de MongoDB == |
||
Los siguientes comandos pueden ser instalados para el manejo y la administración del sistema de base de datos: |
Los siguientes comandos pueden ser instalados para el manejo y la administración del sistema de base de datos: |
||
; mongo<ref>{{Cita web|url=https://docs.mongodb.com/manual/mongo|título=The mongo Shell — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/mongo.txt|idioma=en}}</ref> :Shell interactivo que permite a los desarrolladores y administradores ver, insertar, eliminar y actualizar datos en su base de datos. Este también permite entre otras funciones la replicación de datos, configuración de sharding, apagar los servidores, ejecutar JavaScript y todos los comandos que se puedan realizar. |
|||
; mongostat<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongostat|título=mongostat — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongostat.txt|idioma=en}}</ref> :Instrumento de línea de comandos que muestra en resumen una lista de estadísticas de una instancia de MongoDB en ejecución. Esto te permite visualizar cuantas inserciones, actualizaciones, eliminaciones, consultas y comandos se han ejecutado, pero también cuanta memoria está utilizando y cuanto tiempo ha estado cerrada la base de datos. |
|||
; mongotop<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongotop|título=mongotop — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongotop.txt|idioma=en}}</ref> :Instrumento de línea de comandos que provee un método para dar seguimiento a la cantidad de tiempo que dura una lectura o escritura de datos en una instancia. También provee estadísticas en el nivel de cada colección. |
|||
; mongosniff<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongosniff|título=mongosniff — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongosniff.txt|idioma=en}}</ref> :Instrumento de línea de comandos que provee un sniffing en la base de datos haciendo un sniffing en el tráfico de la red que va desde y hacia MongoDB. |
|||
; mongoimport<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongoimport|título=mongoimport — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongoimport.txt|idioma=en}}</ref>/mongoexport<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongoexport|título=mongoexport — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongoexport.txt|idioma=en}}</ref> :Instrumento de línea de comandos que facilita la importación exportación de contenido desde JSON, CSV o TSV. También tiene el potencial de importar o exportar hacia otros formatos. |
|||
; mongodump<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongodump|título=mongodump — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongodump.txt|idioma=en}}</ref>/mongorestore<ref>{{Cita web|url=https://docs.mongodb.com/manual/reference/program/mongorestore|título=mongorestore — MongoDB Manual|fechaacceso=9 de agosto de 2019|sitioweb=https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongorestore.txt|idioma=en}}</ref> :Instrumento de línea de comandos para la creación de una imagen binaria del contenido de la base de datos. Estos comandos son utilizados para la estrategia de copias de seguridad en MongoDB. |
|||
== Referencias == |
== Referencias == |
||
{{listaref}} |
{{listaref}} |
||
== Bibliografía == |
== Bibliografía == |
||
*{{citation |
* {{citation |
||
| first1 = Kyle |
| first1 = Kyle |
||
| last1 = Banker |
| last1 = Banker |
||
| date = |
| date = 28 de marzo de 2011 |
||
| title = MongoDB in Action |
| title = MongoDB in Action |
||
| edition = 1st |
| edition = 1st |
||
Línea 133: | Línea 175: | ||
| isbn = 9781935182870 |
| isbn = 9781935182870 |
||
}} |
}} |
||
*{{citation |
* {{citation |
||
| first1 = Kristina |
| first1 = Kristina |
||
| last1 = Chodorow |
| last1 = Chodorow |
||
| first2 = Michael |
| first2 = Michael |
||
| last2 = Dirolf |
| last2 = Dirolf |
||
| date = |
| date = 23 de septiembre de 2010 |
||
| title = MongoDB: The Definitive Guide |
| title = MongoDB: The Definitive Guide |
||
| edition = 1st |
| edition = 1st |
||
Línea 145: | Línea 187: | ||
| isbn = 9781449381561 |
| isbn = 9781449381561 |
||
}} |
}} |
||
*{{citation |
* {{citation |
||
| first1 = Mitch |
| first1 = Mitch |
||
| last1 = Pirtle |
| last1 = Pirtle |
||
| date = |
| date = 3 de marzo de 2011 |
||
| title = MongoDB for Web Development |
| title = MongoDB for Web Development |
||
| edition = 1st |
| edition = 1st |
||
Línea 155: | Línea 197: | ||
| isbn = 9780321705334 |
| isbn = 9780321705334 |
||
}} |
}} |
||
*{{citation |
* {{citation |
||
| first1 = Tim |
| first1 = Tim |
||
| last1 = Hawkins |
| last1 = Hawkins |
||
Línea 162: | Línea 204: | ||
| first3 = Peter |
| first3 = Peter |
||
| last3 = Membrey |
| last3 = Membrey |
||
| date = |
| date = 26 de septiembre de 2010 |
||
| title = The Definitive Guide to MongoDB: The NoSQL Database for Cloud and Desktop Computing |
| title = The Definitive Guide to MongoDB: The NoSQL Database for Cloud and Desktop Computing |
||
| edition = 1st |
| edition = 1st |
||
Línea 169: | Línea 211: | ||
| isbn = 9781430230519 |
| isbn = 9781430230519 |
||
}} |
}} |
||
== Enlaces externos == |
== Enlaces externos == |
||
[http://www.mongodb.org/ |
* [http://www.mongodb.org/ Página oficial] |
||
[http://zanphp.com/wiki/Clase_MongoDB MongoDB con ZanPHP] |
* [https://web.archive.org/web/20120424231346/http://zanphp.com/wiki/Clase_MongoDB MongoDB con ZanPHP] |
||
* [https://web.archive.org/web/20140904152816/http://www.mongodbspain.com/es/ MongoDB Spain - Comunidad Española sobre MongoDB] |
|||
* [http://universo-digital.net/como-instalar-mongodb-en-ubuntu-16-04/ Cómo instalar MongoDB en Ubuntu] |
|||
{{Control de autoridades}} |
|||
[[Categoría:Bases de datos]] |
|||
[[Categoría:Código abierto]] |
|||
[[Categoría:NoSQL]] |
|||
[[Categoría:Software de 2009]] |
Revisión actual - 20:41 7 oct 2024
MongoDB | ||
---|---|---|
Información general | ||
Tipo de programa | Base de datos, NoSQL | |
Desarrollador | MongoDB Inc. | |
Modelo de desarrollo | Software libre | |
Lanzamiento inicial | 2009 | |
Información técnica | ||
Programado en | C++ | |
Versiones | ||
Última versión estable | 8.0.49 de diciembre de 2024 | |
Última versión en pruebas | 4.3.03 de junio de 2019 | |
Enlaces | ||
MongoDB (del inglés humongous, "enorme"[cita requerida]) es un sistema de base de datos NoSQL, orientado a documentos y de código abierto.
En lugar de guardar los datos en tablas, tal y como se hace en las bases de datos relacionales, MongoDB guarda estructuras de datos BSON (una especificación similar a JSON) con un esquema dinámico, haciendo que la integración de los datos en ciertas aplicaciones sea más fácil y rápida.
MongoDB es una base de datos adecuada para su uso en producción y con múltiples funcionalidades. Esta base de datos se utiliza mucho en la industria,[1] contando con implementaciones en empresas como MTV Network,[2] Craigslist,[3] Foursquare.[4]
El código fuente está disponible para los sistemas operativos Windows, GNU/Linux, OS X y Solaris.
Historia
[editar]El desarrollo de MongoDB comenzó en 2007 de la mano de 10gen Inc. (ahora llamada MongoDB Inc.)[5] cuando desarrollaban una plataforma como servicio (PaaS) similar al conocido Google App Engine.[6] En 2009 MongoDB fue lanzado como un producto independiente y publicado bajo la licencia de código abierto AGPL.[7]
En marzo de 2011, se lanzó la versión 1.4 y se consideró ya como una base de datos lista para su uso en producción.[8]
En julio de 2022 se lanzó la versión 6.0 y el 15 de agosto de 2023 la versión 7.0.
Concesión de licencias y soporte
[editar]MongoDB se puede obtener de forma gratuita bajo la licencia pública general de Affero (AGPL) de GNU.[7] Los drivers para los lenguajes de programación están bajo la licencia de Apache. Además de estas licencias, MongoDB Inc. ofrece una licencia comercial que incluye características avanzadas (como integración con SASL, LDAP, Kerberos,[9] Simple Network Management Protocol[10] y búsqueda de texto de Rosette Linguistics Platform de Basis Technology[11]), herramientas de gestión, monitorización y backup, así como soporte.[12]
Características principales
[editar]Consultas ad hoc
[editar]MongoDB soporta la búsqueda por campos, consultas de rangos y expresiones regulares. Las consultas pueden devolver un campo específico del documento pero también puede ser una función definida por el usuario para su mejor ocupación.
Indexación
[editar]Cualquier campo en un documento de MongoDB puede ser indexado, al igual que es posible hacer índices secundarios. El concepto de índices en MongoDB es similar al empleado en base de datos relacionales.
Replicación
[editar]MongoDB soporta el tipo de replicación primario-secundario. Cada grupo de primario y sus secundarios se denomina replica set.[13] El primario puede ejecutar comandos de lectura y escritura. Los secundarios replican los datos del primario y sólo se pueden usar para lectura o para copia de seguridad, pero no se pueden realizar escrituras. Los secundarios tienen la habilidad de poder elegir un nuevo primario en caso de que el primario actual deje de responder.
Balanceo de carga
[editar]MongoDB puede escalar de forma horizontal usando el concepto de shard .[14] El desarrollador elige una clave de sharding, la cual determina cómo serán distribuidos los datos de una colección. Los datos son divididos en rangos (basado en la clave de sharding) y distribuidos a través de múltiples shard. Cada shard puede ser una réplica set. MongoDB tiene la capacidad de ejecutarse en múltiple servidores, balanceando la carga y/o replicando los datos para poder mantener el sistema funcionando en caso de que exista un fallo de hardware. La configuración automática es fácil de implementar bajo MongoDB y se pueden agregar nuevas servidores a MongoDB con el sistema de base de datos funcionando.
Almacenamiento de archivos
[editar]MongoDB puede ser utilizado como un sistema de archivos, aprovechando la capacidad de MongoDB para el balanceo de carga y la replicación de datos en múltiples servidores. Esta funcionalidad, llamada GridFS[15] e incluida en la distribución oficial, implementa sobre los drivers, no sobre el servidor,[16] una serie de funciones y métodos para manipular archivos y contenido. En un sistema con múltiple servidores, los archivos pueden ser distribuidos y replicados entre los mismos de forma transparente, creando así un sistema eficiente tolerante de fallos y con balanceo de carga.
Agregación
[editar]MongoDB proporciona un framework de agregación que permite realizar operaciones similares al "GROUP BY" de SQL. El framework de agregación está construido como un pipeline en el que los datos van pasando a través de diferentes etapas en los cuales estos datos son modificados, agregados, filtrados y formateados hasta obtener el resultado deseado. Todo este procesado es capaz de utilizar índices si existieran y se produce en memoria. Asimismo, MongoDB proporciona una función MapReduce que puede ser utilizada para el procesamiento por lotes de datos y operaciones de agregación.
Ejecución de JavaScript del lado del servidor
[editar]MongoDB tiene la capacidad de realizar consultas utilizando JavaScript, haciendo que estas sean enviadas directamente a la base de datos para ser ejecutadas.
Fragmentación (sharding)
[editar]Si estás desarrollando un servicio que se va haciendo popular o los niveles de acceso a base de datos son cada vez más altos, empezarás a notar que tu base de datos está siendo atacada por un tráfico creciente y tu servidor esté sufriendo por los altos niveles de estrés y te podrías ver en la necesidad de actualizar tu infraestructura para soportar la demanda.
Aquí entra en juego el sharding, es el modo en el que hacemos nuestra base de datos escalable. En lugar de tener una colección en una base de datos, la pondríamos en varias bases de datos distribuidas, de modo que a la hora de consultar los datos de dicha colección, los recuperemos como si de una única base de datos se tratase. Mongo se encargará de averiguar de manera transparente en qué base de datos se encuentran los datos.
Los fragmentos estarán formados por replica set, de modo que si creamos tres fragmentos, cada uno de los cuales tiene una replica set con tres servidores, estaríamos hablando de un total de nueve servidores.
Las consultas se realizan de manera distribuida a través de un módulo enrutador, “MongoS”, que mantiene un pool de conexiones a los distintos hosts. Para distribuir los datos de una colección ordenada, se trocea la colección en rangos a los que se les asigna un identificador (shard key), que puede ser una parte del propio documento, y se distribuye entre los replica sets.
Principales limitaciones
[editar]Implementación de propiedades ACID multidocumento
[editar]MongoDB solo garantizaba ACID dentro del mismo documento. El no implementar las propiedades ACID generaba que la base de datos no aseguraran la durabilidad, la integridad, la consistencia y el aislamiento requeridos obligatoriamente en las transacciones. El soporte para transacciones ACID de múltiples documentos se agregó a MongoDB en la versión 4.0 de junio de 2018.
Sobre la base de este punto se detallan los cuatro siguientes:
- Problemas de consistencia
En versiones anteriores de la base de datos las lecturas estrictamente consistentes ven versiones obsoletas de documentos, también pueden devolver datos incorrectos de lecturas que nunca deberían haber ocurrido.[17]
Este problema se considera solucionado a partir de la versión 3.4: https://jepsen.io/analyses/mongodb-3-4-0-rc3
- Bloqueo a nivel de documento
MongoDB bloquea la base de datos a nivel de documento ante cada operación de escritura. Sólo se podrán hacer operaciones de escritura concurrentes entre distintos documentos.
- Las escrituras no son durables ni verificables
MongoDB retorna cuando todavía no se ha escrito la información en el espacio de almacenamiento permanente, lo que puede ocasionar pérdidas de información. En MongoDB 2.2 se cambia el valor por defecto para escribir en al menos una réplica, pero esto sigue sin satisfacer la durabilidad ni la verificabilidad.[18]
- Problemas de escalabilidad
Tiene problemas de rendimiento cuando el volumen de datos supera los 100GB.[19]
Casos de uso
[editar]La base de datos MongoDB es adecuada para los siguientes usos:[20]
- Almacenamiento y registro de eventos
- Sistemas de manejo de documentos y contenido
- Comercio electrónico
- Juegos
- Sistemas con alto volumen de lecturas
- Aplicaciones móviles
- Almacén de datos operacional de sitios web
- Almacenamiento de comentarios
- Votaciones
- Registro de usuarios
- Perfiles de usuarios
- Sesiones de datos
- Proyectos que utilizan metodologías de desarrollo iterativo o ágiles
- Manejo de estadísticas en tiempo real
MongoDB es utilizado para uno o varios de estos casos por varias empresas.[21]
Manipulación de datos: colecciones y documentos
[editar]MongoDB guarda la estructura de los datos en documentos BSON con un esquema dinámico, lo que implica que no existe un esquema predefinido. Los elementos de los datos se denominan documentos y se guardan en colecciones. Una colección puede tener un número indeterminado de documentos. Comparando con una base de datos relacional, se puede decir que las colecciones son como tablas y los documentos son registros en la tabla. La diferencia es que en una base de datos relacional cada registro en una tabla tiene la misma cantidad de campos, mientras que en MongoDB cada documento en una colección puede tener diferentes campos. En un documento, se pueden agregar, eliminar, modificar o renombrar nuevos campos en cualquier momento,[22] ya que no hay un esquema predefinido. La estructura de un documento es simple y compuesta por pares llave/valor, parecido a las matrices asociativas en un lenguaje de programación, esto se debe a que MongoDB sigue el formato de JSON. En MongoDB la clave es el nombre del campo y el valor es su contenido, los cuales se separan mediante el uso de “:”, tal y como se puede ver en el siguiente ejemplo. Como valor se pueden usar números, cadenas o datos binarios como imágenes o cualquier otro.
{
"_id": ObjectId("4efa8d2b7d284dad101e4bc7"),
"Last Name": "PELLERIN",
"First Name": "Franck",
"Age": 29,
"Address": {
"Street": "1 chemin des Loges",
"City": "VERSAILLES"
}
}
En este ejemplo se puede ver que en el campo “Address” se contiene otro documento que tiene los campos de “Street” y “City”.
Lenguajes de programación soportados
[editar]Según la documentación oficial de MongoDB, este sistema tiene controladores oficiales para los siguientes lenguajes de programación:
Instrumentos de MongoDB
[editar]Los siguientes comandos pueden ser instalados para el manejo y la administración del sistema de base de datos:
- mongo[23]
- Shell interactivo que permite a los desarrolladores y administradores ver, insertar, eliminar y actualizar datos en su base de datos. Este también permite entre otras funciones la replicación de datos, configuración de sharding, apagar los servidores, ejecutar JavaScript y todos los comandos que se puedan realizar.
- mongostat[24]
- Instrumento de línea de comandos que muestra en resumen una lista de estadísticas de una instancia de MongoDB en ejecución. Esto te permite visualizar cuantas inserciones, actualizaciones, eliminaciones, consultas y comandos se han ejecutado, pero también cuanta memoria está utilizando y cuanto tiempo ha estado cerrada la base de datos.
- mongotop[25]
- Instrumento de línea de comandos que provee un método para dar seguimiento a la cantidad de tiempo que dura una lectura o escritura de datos en una instancia. También provee estadísticas en el nivel de cada colección.
- mongosniff[26]
- Instrumento de línea de comandos que provee un sniffing en la base de datos haciendo un sniffing en el tráfico de la red que va desde y hacia MongoDB.
- mongoimport[27]/mongoexport[28]
- Instrumento de línea de comandos que facilita la importación exportación de contenido desde JSON, CSV o TSV. También tiene el potencial de importar o exportar hacia otros formatos.
- mongodump[29]/mongorestore[30]
- Instrumento de línea de comandos para la creación de una imagen binaria del contenido de la base de datos. Estos comandos son utilizados para la estrategia de copias de seguridad en MongoDB.
Referencias
[editar]- ↑ «DB-Engines Ranking». DB-Engines (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «MongoDB Powering MTV's Web Properties | MongoDB Blog». MongoDB (en inglés estadounidense). Consultado el 9 de agosto de 2019.
- ↑ «MongoDB live at Craigslist | MongoDB Blog». MongoDB (en inglés estadounidense). Consultado el 9 de agosto de 2019.
- ↑ «http://blip.tv/mongodb/mongodb-at-foursquare-3723202». Archivado desde el original el 8 de junio de 2012.
- ↑ «10gen Announces Company Name Change to MongoDB, Inc.». MongoDB. Consultado el 6 de mayo de 2016.
- ↑ Cade Metz (25 de mayo de 2011). «MongoDB daddy: My baby beats Google BigTable» (en inglés). Consultado el 27 de octubre de 2022.
- ↑ a b «http://blog.mongodb.org/post/103832439/the-agpl».
- ↑ «http://blog.mongodb.org/post/472835820/mongodb-1-4-ready-for-production». Archivado desde el original el 8 de julio de 2014.
- ↑ «Enterprise Authentication Mechanisms — MongoDB Manual 3.2». docs.mongodb.com. Consultado el 6 de mayo de 2016.
- ↑ «Monitor MongoDB With SNMP on Linux — MongoDB Manual 3.2». docs.mongodb.com. Consultado el 6 de mayo de 2016.
- ↑ «Text Search with Basis Technology Rosette Linguistics Platform — MongoDB Manual 3.2». docs.mongodb.com. Consultado el 6 de mayo de 2016.
- ↑ «https://www.mongodb.com/lp/contact/enterprise».
- ↑ «https://docs.mongodb.org/manual/replication/».
- ↑ «http://www.mongodb.org/display/DOCS/Sharding».
- ↑ «http://www.mongodb.org/display/DOCS/GridFS».
- ↑ «mongodb/specifications». GitHub. Consultado el 12 de abril de 2016.
- ↑ «Call me maybe: MongoDB stale reads».
- ↑ «Broken by Design: MongoDB Fault Tolerance :: Hacking, Distributed».
- ↑ «MongoDB mocked after posting “100GB Scaling Checklist”».
- ↑ «http://www.mongodb.org/display/DOCS/Use+Cases».
- ↑ «http://www.mongodb.org/display/DOCS/Production+Deployments». Archivado desde el original el 10 de mayo de 2012.
- ↑ «http://www.mongodbspain.com/wp-content/uploads/2014/03/MongoDBSpain-CheetSheet.pdf». Archivado desde el original el 28 de marzo de 2014. Consultado el 27 de marzo de 2014.
- ↑ «The mongo Shell — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/mongo.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongostat — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongostat.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongotop — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongotop.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongosniff — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongosniff.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongoimport — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongoimport.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongoexport — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongoexport.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongodump — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongodump.txt (en inglés). Consultado el 9 de agosto de 2019.
- ↑ «mongorestore — MongoDB Manual». https://github.com/mongodb/docs/blob/v4.0/source/reference/program/mongorestore.txt (en inglés). Consultado el 9 de agosto de 2019.
Bibliografía
[editar]- Banker, Kyle (28 de marzo de 2011), MongoDB in Action (1st edición), Manning, p. 375, ISBN 9781935182870.
- Chodorow, Kristina; Dirolf, Michael (23 de septiembre de 2010), MongoDB: The Definitive Guide (1st edición), O'Reilly Media, p. 216, ISBN 9781449381561.
- Pirtle, Mitch (3 de marzo de 2011), MongoDB for Web Development (1st edición), Addison-Wesley Professional, p. 360, ISBN 9780321705334.
- Hawkins, Tim; Plugge, Eelco; Membrey, Peter (26 de septiembre de 2010), The Definitive Guide to MongoDB: The NoSQL Database for Cloud and Desktop Computing (1st edición), Apress, p. 350, ISBN 9781430230519.