db.createUser({user:"$MONGODB_USERNAME",pwd:"$MONGODB_PASSWORD",roles:["readWrite","dbAdmin"]})
时间: 2023-08-13 09:08:04 浏览: 141
您好!要创建一个 MongoDB 用户,您可以使用以下命令:
```shell
db.createUser({
user: "YOUR_USERNAME",
pwd: "YOUR_PASSWORD",
roles: ["readWrite", "dbAdmin"]
})
```
请将 "YOUR_USERNAME" 替换为您想要创建的用户名,将 "YOUR_PASSWORD" 替换为您想要设置的密码。此命令将为用户授予 "readWrite" 和 "dbAdmin" 角色,以便其能够读写数据库并进行数据库管理操作。
请注意,您还需要先使用 `use DATABASE_NAME` 命令选择要创建用户的数据库。
相关问题
mongodb出现Authentication failed.
在执行db.auth(‘username’, ‘password’)时,如果出现了Error: Authentication failed的错误,可能是因为环境中的root、admin和业务数据库用户都认证失败了。解决这个问题的步骤如下:
1. 停止MongoDB服务。可以使用无身份认证的方式打开MongoDB。
2. 进入MongoDB的bin目录下。
3. 使用以下命令停止MongoDB服务:
mongod --shutdown --dbpath=/soft/mongo/mgserver/data/
4. 使用以下命令启动MongoDB服务:
./mongod --dbpath=/soft/mongo/mgserver/data/ --logpath=/soft/mongo/mgserver/logs/mongod.log --logappend --port=27017 --fork
5. 使用以下命令验证数据库和用户信息:
mongo
show dbs
use ${your db}
show users
use admin
show users
6. 修改密码:
- 修改root用户密码:
# mongo
# db.changeUserPassword('root','${new password}')
# exit退出
- 关闭MongoDB服务:
mongod --shutdown --dbpath=/soft/mongo/mgserver/data/
- 使用以下命令认证启动MongoDB服务:
./mongod --dbpath=/soft/mongo/mgserver/data/ --logpath=/soft/mongo/mgserver/logs/mongod.log --auth --logappend --port=27017 --fork
- 使用以下命令验证用户密码是否修改成功:
mongo
use admin
db.auth('','')
- 同样的步骤也可以修改其他用户的密码。
7. 新增用户:
- mongo
- use ${your db}
- db.createUser({ user: "", pwd:"", roles:[{role:"readWrite",db:""}] })
参考资料中提到,可能出现Authentication failed的错误是因为没有正确指定数据库。确保在创建用户时使用了正确的数据库名称。例如,使用use admin指定数据库。另外,还要确保创建的用户具有正确的权限角色。
综上所述,要解决mongodb出现Authentication failed的问题,可以按照上述步骤进行操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
mongodb7.0没有authorization: enabled
MongoDB 7.0版本默认情况下确实不会启用`authorization`。`Authorization`是用来控制数据库访问权限的安全特性,它允许管理员设置用户对集合、数据库甚至整个集群的操作权限。如果你看到`authorization: enabled`这个配置项未开启,意味着系统可能还处于开放模式,任何人都可以连接并操作数据库。
要启用`authorization`,你需要创建一个包含`users`角色的admin用户,并运行`db.runCommand({ enableSharding: "your-database" })`等命令来初始化认证和授权。具体步骤包括:
1. **添加管理员用户**:
```
use admin
db.createUser({
user: 'your-username',
pwd: 'your-password',
roles: [{ role: 'root', db: 'admin' }]
})
```
2. **启用安全性**:
```
db.auth('your-username', 'your-password')
db.runCommand({enableSharding: 'your-database'})
```
3. **为其他用户设置权限**:
```
use your-database
db.addUser({
user: 'other-user',
pwd: 'other-password',
roles: ['readWrite', 'dbAdmin']
})
```
如果你发现`authorization: enabled`没有自动启用,记得检查安全组设置和启动参数是否正确配置了`--auth`标志。
阅读全文