Administrar usuarios y roles es una parte crucial de la administración de cualquier base de datos, y MongoDB no es una excepción. Este capítulo de nuestro curso cubrirá cómo crear, administrar y asignar roles a usuarios en MongoDB.
En MongoDB, la autenticación y la autorización son las dos formas principales de gestionar la seguridad. La autenticación verifica la identidad de un usuario, mientras que la autorización determina qué acciones puede realizar un usuario. En otras palabras, la autenticación es el proceso de verificar quién es usted, mientras que la autorización es el proceso de verificar lo que tiene permitido hacer.
Para administrar usuarios y roles en MongoDB, debe comprender cómo MongoDB maneja la seguridad. MongoDB utiliza un modelo de seguridad basado en roles, lo que significa que puede asignar roles específicos a usuarios específicos. Cada rol tiene un conjunto específico de privilegios que determinan lo que el usuario puede hacer.
Para crear un nuevo usuario en MongoDB, puede utilizar el comando db.createUser()
. Este comando crea un nuevo usuario y le asigna un rol. Por ejemplo, el siguiente comando crea un nuevo usuario llamado "myUser" con la contraseña "myPassword" y el rol "readWrite":
db.createUser( { usuario: "miUsuario", pwd: "miContraseña", roles: [ "leerEscribir" ] } )
Este comando crea un nuevo usuario que tiene permiso para leer y escribir datos. Sin embargo, este usuario no tiene permiso para realizar tareas administrativas como crear nuevas bases de datos o administrar usuarios.
Si desea cambiar la función de un usuario, puede utilizar el comando db.updateUser()
. Este comando actualiza la función de un usuario existente. Por ejemplo, el siguiente comando actualiza la función de usuario "myUser" a "dbAdmin":
db.updateUser( "miUsuario", { roles: ["dbAdmin"] } )
Este comando actualiza la función del usuario "myUser" a "dbAdmin", lo que significa que este usuario ahora tiene permiso para realizar tareas administrativas.
Además, MongoDB también le permite crear sus propias funciones personalizadas. Para crear una nueva función, puede utilizar el comando db.createRole()
. Por ejemplo, el siguiente comando crea una nueva función llamada "readWriteAndAdmin":
db.createRole( { rol: "readWriteAndAdmin", privilegios: [ { recurso: { db: "mydb", colección: "" }, acciones: [ "buscar", "actualizar", "insertar", "eliminar", "createCollection", "dropCollection", "createIndex", "dropIndex", "viewOn", "collStats", "dbStats", "dbHash" , "adminbd" ] } ], roles: [] } )
Este comando crea una nueva función que tiene permisos para leer, escribir y administrar la base de datos "mydb".
En resumen, administrar usuarios y roles en MongoDB es una tarea importante que ayuda a garantizar la seguridad de su base de datos. Al comprender cómo crear, administrar y asignar roles a los usuarios, puede asegurarse de que cada usuario tenga los privilegios adecuados para realizar sus tareas.
En el próximo capítulo, cubriremos cómo monitorear el rendimiento de su base de datos MongoDB y cómo optimizarla para obtener el mejor rendimiento posible. ¡Estén atentos!