Pra*_*nna 3 shell terminal mongodb
管理员用户权限:
db.getUsers()
[
    {
        "_id" : "admin.myself",
        "user" : "myself",
        "db" : "admin",
        "roles" : [
            {
                "role" : "userAdminAnyDatabase",
                "db" : "admin"
            },
            {
                "role" : "dbAdmin",
                "db" : "reports"
            },
            {
                "role" : "dbAdmin",
                "db" : "places"
            }
        ],
        "customData" : {
        }
    }
]
我能够对我的远程 mongo 数据库进行身份验证,例如,
mongo --host <hostname> -u "myself" -p "myself" --authenticationDatabase "admin"
我还可以像这样远程进行转储
mongodump --host <hostname> --port 27017 --username "myslef" --password "myself" --out home/myself/mongodb-backup
但是,当我修改数据库上的某些集合并尝试像下面的代码一样恢复它时,它不起作用并引发身份验证错误。
mongorestore --host <hostname> -u "myself" -p "myself" home/myself/mongodb-backup/
错误:
Failed: error getting auth version of server: not authorized on admin to execute command { getParameter: 1, authSchemaVersion: 1 }
您应该像这样向管理员添加 root 角色
db.grantRolesToUser( "myAdmin", [ "root" ])
只有在那之后你才能从备份中恢复
| 归档时间: | 
 | 
| 查看次数: | 9608 次 | 
| 最近记录: |