errmsg" : "not authorized on test to execute command { listCollections: 1.0 }mo

在MongoDB操作中遇到'notauthorized'错误时,通过添加用户、指定角色并使用新用户登录来解决问题。具体步骤包括切换到admin库,使用createUser命令添加具有root权限的用户,然后使用新用户身份验证,最终执行所需命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mongodb进行操作时,出现errmsg" : "not authorized on test to execute command { listCollections: 1.0 }这个提示

表示没有权限,那就赶紧添加用户吧

切换到admin库

use admin;


添加用户
db.createUser( {
    user: "sa",
    pwd: "sa",
    roles: [ { role: "root", db: "admin" } ]
  });


既然已经添加了用户

用sa账号登录

db.auth('sa','sa');


再执行以前的命令,是否还会出现

errmsg" : "not authorized on test to execute command { listCollections: 1.0 }

### MongoDB 权限不足 (Error Code 13 Unauthorized) 的解决方案 当遇到 `error code 13 Unauthorized` 错误时,通常是因为当前用户缺乏执行特定操作所需的权限。以下是针对该问题的分析与解决方法: #### 1. **确认用户的权限** 如果尝试运行某些管理命令(如 `replSetGetConfig` 或访问 `admin.system.users`),需要确保当前登录的用户具有足够的权限。可以通过以下方式验证用户的角色和权限: ```javascript use admin; db.runCommand({ connectionStatus: 1 }); ``` 上述命令会返回当前连接的状态以及所使用的角色列表[^1]。 #### 2. **切换到管理员账户** 如果当前用户确实缺少必要的权限,则可以重新以具备更高权限的用户身份登录。例如,使用超级管理员账号 (`root`) 登录并授予适当权限给其他用户。 ```bash mongo -u rootUser -p --authenticationDatabase admin ``` #### 3. **授予权限** 对于目标用户,可通过以下脚本为其分配所需的角色。假设用户名为 `myAdminUser` 并希望赋予其读写管理和复制集配置的能力: ```javascript use admin; db.grantRolesToUser( "myAdminUser", [ { role: "clusterManager", db: "admin" }, { role: "readWriteAnyDatabase", db: "admin" } ] ); ``` 这里定义了两个主要角色:`clusterManager` 和 `readWriteAnyDatabase`,它们分别允许管理整个集群状态及跨数据库的数据修改操作[^2]。 #### 4. **检查安全设置** 有时即使拥有正确角色也可能遭遇授权失败的情况,这可能是由于启用了额外的安全策略所致。比如 IP 白名单限制或者 Kerberos 验证机制等都可能导致此类异常行为发生。因此建议核查服务器端的相关参数配置文件 `/etc/mongod.conf` 中是否存在特殊约束条件。 #### 示例代码片段用于测试修复效果 下面提供一段简单的 JavaScript 测试程序来验证更改后的环境是否正常工作: ```javascript // 进入 Admin 数据库上下文中 use admin; try { const result = db.adminCommand({ replSetGetConfig: 1 }); if (!result.ok || !result.config) throw new Error('Failed to get replica set config'); } catch(e){ print(`An error occurred while fetching the replica configuration: ${e.message}`); } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值