El autor seleccionó COVID-19 Relief Fund para que reciba una donación como parte del programa Write for DOnations.
MongoDB es uno de los motores de base de datos más populares de NoSQL. Es famoso por ser escalable, sólido, confiable y fácil de usar. En este artículo, respaldará, restaurará y migrará una base de datos de MongoDB de muestra.
Importar y exportar una base de datos implica gestionar los datos en un formato legible por el ser humano y compatible con otros productos de software. Por el contrario, las operaciones de copia de seguridad y restauración de MongoDB crean o utilizan datos binarios específicos de MongoDB, que preservan no solo la uniformidad y la integridad de sus datos, sino también sus atributos específicos de MongoDB. Por lo tanto, para migrar, generalmente es preferible usar la copia de seguridad y la restauración siempre que los sistemas de origen y destino sean compatibles.
Antes de seguir este tutorial, asegúrese de completar los siguientes requisitos previos:
Salvo que se indique lo contrario, todos los comandos que requieren privilegios root en este tutorial deben ejecutarse como usuario no root con privilegios sudo.
Antes de continuar con este artículo, es necesario tener algunos conocimientos básicos sobre la materia. Si tiene experiencia con otros sistemas de base de datos NoSQL como Redis, es posible que encuentre algunas similitudes cuando trabaje con MongoDB.
MongoDB utiliza los formatos JSON y BSON (JSON binario) para almacenar su información. JSON es el formato legible por el ser humano perfecto para exportar y, finalmente, importar sus datos. Además, puede administrar los datos exportados con cualquier herramienta que sea compatible con JSON, incluyendo un editor de texto simple.
Un ejemplo de documento JSON tiene el siguiente aspecto:
{"address":[
{"building":"1007", "street":"Park Ave"},
{"building":"1008", "street":"New Ave"},
]}
Es conveniente trabajar con JSON, pero no es compatible con todos los tipos de datos disponibles en BSON. Eso significa que habrá la llamada “pérdida de fidelidad” de la información si utiliza JSON. Para respaldar y restaurar, es mejor usar el BSON binario.
En segundo lugar, no tiene que preocuparse por crear explícitamente una base de datos de MongoDB. Si la base de datos que especifica para la importación no existe todavía, se creará automáticamente. Aún mejor es el caso de la estructura de las colecciones (tablas de base de datos). A diferencia de otros motores de bases de datos, en MongoDB, la estructura se crea de nuevo automáticamente al insertar el primer documento (fila de la base de datos).
En tercer lugar, en MongoDB, leer o insertar grandes cantidades de datos, como las tareas de este artículo, puede requerir de muchos recursos y utilizar gran parte de su CPU, memoria y espacio de disco. Eso es crucial teniendo en cuenta que MongoDB se suele utilizar para las grandes bases de datos y los macrodatos. La solución más sencilla a este problema es ejecutar las exportaciones y las copias de seguridad durante la noche o en horas no pico.
En cuarto lugar, la consistencia de la información podría ser un problema si tiene un servidor MongoDB ocupado en el que la información cambia durante el proceso de exportación o respaldo de la base de datos. Una posible solución para este problema es la replicación, que puede considerar cuando avance en el tema de MongoDB.
Aunque puede usar las funciones de importación y exportación para respaldar y restaurar los datos, hay mejores formas de garantizar la integridad total de sus bases de datos de MongoDB. Para respaldar sus datos, debe usar el comando mongodump
. Para restaurar, utilice mongorestore
. Veamos cómo funcionan.
mongodump
para respaldar una base de datos de MongoDBPrimero, vamos a respaldar su base de datos de MongoDB.
Un argumento esencial para mongodump
es --db
, que especifica el nombre de la base de datos que desea respaldar. Si no se especifica el nombre de la base de datos, mongodump
hace una copia de seguridad de todas las bases de datos. El segundo argumento importante es --out
, que define el directorio en el que se verterán los datos. Por ejemplo, vamos a respaldar la base de datos newdb
y vamos a almacenarla en el directorio /var/backups/mongobackups
. Lo ideal es que tengamos cada una de nuestras copias de seguridad en un directorio con la fecha actual como /var/backup/mongobackups/10-29-20
.
Primero, cree el directorio /var/backup/mongobackups
:
- sudo mkdir /var/backups/mongobackups
Luego, ejecute mongodump
:
- sudo mongodump --db newdb --out /var/backups/mongobackups/`date +"%m-%d-%y"`
Verá un resultado similar a este:
Output2020-10-29T19:22:36.886+0000 writing newdb.restaurants to
2020-10-29T19:22:36.969+0000 done dumping newdb.restaurants (25359 documents)
Tenga en cuenta que en la ruta del directorio anterior, hemos usado date +"%m-%d-%y"
, que obtiene automáticamente la fecha actual. Eso nos permitirá tener copias de seguridad dentro del directorio, como /var/backup/10-29-20/
. Esto es especialmente conveniente cuando automatizamos las copias de seguridad.
En este punto, tenemos una copia de seguridad competa de la base de datos newdb
en el directorio /var/backup/mongobackups/10-29-20/newdb/
. Esta copia de seguridad tiene todo lo necesario para restaurar el newdb
de forma adecuada y preservar la llamada “fidelidad”.
Como regla general, debe realizar copias de seguridad con regularidad y preferiblemente cuando el servidor está menos cargado. Por lo tanto, puede configurar el comando mongodump
como tarea de cron para que se ejecute regularmente, por ejemplo, cada día a la 03:03 a.m.
Para ello, abra crontab, el editor de Cron:
- sudo crontab -e
Tenga en cuenta que cuando ejecute sudo crontab
, editará las tareas de cron para el usuario root. Esto se recomienda porque si establece los crones de su usuario, podrían no ejecutarse correctamente, especialmente si su perfil sudo requiere verificación de contraseña.
Dentro de la línea de comandos de crontab, inserte el siguiente comando mongodump
:
3 3 * * * mongodump --out /var/backups/mongobackups/`date +"%m-%d-%y"`
En el comando anterior, omitimos el argumento --db
a propósito porque normalmente querrá tener todas las bases de datos respaldadas.
Dependiendo del tamaño de su base de datos de MongoDB, es posible que pronto se quede sin espacio en el disco con demasiadas copias de seguridad. Es por eso que también se recomienda limpiar las copias de seguridad antiguas con regularidad o comprimirlas.
Por ejemplo, para eliminar todas las copias de seguridad de más de siete días, puede usar el siguiente comando bash:
- find /var/backups/mongobackups/ -mtime +7 -exec rm -rf {} \;
De forma similar al comando mongodump
anterior, también puede añadirlo como tarea de cron. Debe ejecutarse justo antes de iniciar la siguiente copia de seguridad, por ejemplo, a las 03:01 a.m. Para ello, abra crontab de nuevo:
- sudo crontab -e
Después de eso, inserte la siguiente línea:
1 3 * * * find /var/backups/mongobackups/ -mtime +7 -exec rm -rf {} \;
Guarde y cierre el archivo.
Completar todas las tareas en este paso garantizará una solución de respaldo adecuada para sus bases de datos de MongoDB.
mongorestore
para restaurar y migrar una base de datos de MongoDBCuando restaura su base de datos de MongoDB desde una copia de seguridad anterior, tiene la copia exacta de su información de MongoDB en un momento determinado, incluyendo todos los índices y los tipos de datos. Esto es especialmente útil cuando desea migrar sus bases de datos de MongoDB. Para restaurar MongoDB, usaremos el comando mongorestore
, que funciona con las copias de seguridad binarias que produce mongodump
.
Continuemos nuestros ejemplos con la base de datos newdb
y veremos cómo podemos restaurarla desde la copia de seguridad tomada anterior. Primero, especificaremos el nombre de la base de datos con el argumento --nsInclude
Usaremos newdb*
para restaurar todas las colecciones. Para restaurar una colección única como los restaurantes
, utilice newdb.restaurants
en su lugar.
Luego, con --drop
, nos aseguraremos de que la base de datos de destino se elimine primero para que la copia de seguridad se restaure en una base de datos limpia. Como argumento final, especificaremos el directorio de la última copia de seguridad, que tendrá un aspecto similar a este: /var/backup/mongobackups/10-29-20/newdb/
.
Una vez que tenga una copia de seguridad con marca de tiempo, puede restaurarla usando este comando:
- sudo mongorestore --db newdb --drop /var/backups/mongobackups/10-29-20/newdb/
Verá un resultado similar a este:
Output2020-10-29T19:25:45.825+0000 the --db and --collection args should only be used when restoring from a BSON file. Other uses are deprecated and will not exist in the future; use --nsInclude instead
2020-10-29T19:25:45.826+0000 building a list of collections to restore from /var/backups/mongobackups/10-29-20/newdb dir
2020-10-29T19:25:45.829+0000 reading metadata for newdb.restaurants from /var/backups/mongobackups/10-29-20/newdb/restaurants.metadata.json
2020-10-29T19:25:45.834+0000 restoring newdb.restaurants from /var/backups/mongobackups/10-29-20/newdb/restaurants.bson
2020-10-29T19:25:46.130+0000 no indexes to restore
2020-10-29T19:25:46.130+0000 finished restoring newdb.restaurants (25359 documents)
2020-10-29T19:25:46.130+0000 done
En el caso anterior, estamos restaurando los datos en el mismo servidor donde creamos la copia de seguridad. Si desea migrar los datos a otro servidor y usar la misma técnica, deberá copiar el directorio de la copia de seguridad, que es /var/backups/mongobackups/10-29-20/newdb/
en nuestro caso, al otro servidor.
Ahora, ha realizado algunas tareas esenciales relacionadas con el respaldo, la restauración y la migración de sus bases de datos de MongoDB. Ningún servidor MongoDB de producción debería funcionar sin una estrategia de respaldo fiable, como la que se describe aquí.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!