gpt4 book ai didi

database - mongodb 没有名为 restore 的角色

转载 作者:可可西里 更新时间:2023-11-01 10:38:40 24 4
gpt4 key购买 nike

我正在尝试创建一个具有恢复权限的用户,以便我可以在本地恢复我使用 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com