database - mongodb 没有名为 restore 的角色

标签 database mongodb backup

我正在尝试创建一个具有恢复权限的用户,以便我可以在本地恢复我使用 mongodump 在远程服务器上备份的数据库(注意,数据库需要身份验证,但我的问题只是为任何新数据库创建一个用户) .

我在本地使用mongo3.6.6。

在本地计算机上,我尝试使用以下方法创建具有恢复角色的用户。注意我正在创建一个新的本地数据库和新数据库的新用户。

mongo -u Admin -p authenticationDatabase admin

#create a new database that will extract backup to
use backup_data_db

db.createUser[{
  user: "local_user",T
  pwd: "123",
  roles: [
    {role: "read", db: "backup_data_db"},
    {role: "restore", db: "backup_data_db"}]
})

于是我收到以下错误:

Error: couldn't add user: No role named restore@backup_data_db

我已尝试创建具有多个角色组合的用户 - dbAdmin、readWrite、read、dbOwner、backup、restore。在这些角色中,对于“备份”和“恢复”角色,我总是得到“没有名为 xxxx@backup_data_db 的角色”。创建这些角色似乎与其他角色不同,但我找不到任何关于如何创建这些角色的文档,除了我相信我正在关注的 Mongo 文档。

请注意,我还尝试从管理数据库开始,即:

use admin

并重复上面相同的 db.createUser 代码。并得到了同样的错误。

有什么用 - 创建一个有 root 权限的用户:

use admin

db.createUser( {
user: "rootuser",
pwd: "passwd",
roles: ["root", "userAdminAnyDatabase", "dbAdminAnyDatabase", 
"readWriteAnyDatabase"] } )

root角色具有备份和恢复权限,创建此角色时没有来自 mongodb 的投诉。

然后我可以运行以下命令并恢复数据库 OK

mongorestore -u rootuser -p passwd --authenticationDatabase admin -d backup_data_db path_to_backup_dir

文档表明无需 root 访问权限即可恢复,我做错了什么?

最佳答案

错误可能是因为 restore 角色只能从 admin 数据库中使用。

“MongoDB 在每个数据库上提供内置的数据库用户和数据库管理角色。MongoDB 仅在管理数据库上提供所有其他内置角色。”

restore 角色在Backup and Restoration Roles 中。

3.6 文档 are here .

例如(未测试):

db.createUser[{
  user: "local_user",
  pwd: "123",
  roles: [
    {role: "read", db: "backup_data_db"},
    {role: "restore", db: "admin"}]
})

关于database - mongodb 没有名为 restore 的角色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51452733/

相关文章:

emacs - 如何删除 Emacs 在关闭时创建的以 '#' 开头和结尾的临时文件?

sql - T-SQL 获取最后一个日期时间记录

MySQL 多行

php - 适用于 iOS 的简单 PHP/MySQL Web 服务

php - 如何在 Windows 7 上安装 PHP 7 的 MongoDB 驱动程序?

windows-10 - 如何在Windows 10中将分区完全备份到Microsoft OneDrive?

database - CouchDB 备份和克隆数据库

c# - 从 SqlDataReader 创建 JSON 字符串

mongodb - Mongoose 在数据库中的模型名称后添加一个 "s"?

具有客户端访问控制的 Mongodb docker 容器