MongoDB开启用户密码访问

mongodb密码和传统数据如mysql等有些区别:

  1. mongodb的用户名和密码是基于特定数据库的,而不是基于整个系统的。所有所有数据库db都需要设置密码

mongodb设置管理用户和密码:

  1. show dbs
    在mongodb新版本里并没有admin数据库,但是并不妨碍第2步操作。
  2. use admin 进入admin数据库
  3. 创建管理员账户
    db.createUser({ user: "useradmin", pwd: "adminpassword", roles: [{ role: "userAdminAnyDatabase", db: "admin" }] })
    mongodb中的用户是基于身份role的,该管理员账户的 role是 userAdminAnyDatabase。 ‘userAdmin’代表用户管理身份,’AnyDatabase’ 代表可以管理任何数据库。
  4. 验证第3步用户添加是否成功
    db.auth("useradmin", "adminpassword") 如果返回1,则表示成功。
    exit退出系统
    db.auth()方法理解为 用户的验证功能
  5. 修改配置
    sudo vi /etc/mongod.conf
    找到#security: 取消注释,修改为:
     
    1. security:
    2. authorization: enabled #注意缩进,缩进参照配置文件其他配置。缩进错误可能第6步重启不成功。
  6. 重启mongodb sudo service mongod restart
  7. 进入mongodb,用第3步的 管理员账户登录,用该账户创建其他数据库管理员账号
     
    1. use admin
    2. db.auth("useradmin", "adminpassword")
  8. 新建你需要管理的mongodb 数据的账号密码。

     
    1. use yourdatabase
    2. db.createUser({ user: "youruser", pwd: "yourpassword", roles: [{ role: "dbOwner", db: "yourdatabase" }] })

    rote:dbOwner 代表数据库所有者角色,拥有最高该数据库最高权限。比如新建索引等

  9. 新建数据库读写账户

     
    1. use yourdatabase
    2. db.createUser({ user: "youruser2", pwd: "yourpassword2", roles: [{ role: "readWrite", db: "yourdatabase" }] })

    该用户用于该数据的读写,只拥有读写权限。

  10. 现在数据的用户名和密码就建好了。
    可以使用:mongodb://youruser2:yourpassword2@localhost/yourdatabase来链接

 

一、开启访问认证

  1. 1、Mongdb默认启动时是没有开启安全访问验证的,需要在启动服务的时候加上 --auth 参数来启动安全验证。

2、开启访问认证:

①、通过命令启动mongodb服务-开启认

./mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs --logappend  --port=27017 --fork --auth
--fork指定后台运行

--auth开启验证

--dbpath指定数据库目录

--logpath指定日志文件

--logappend日志累积添加

②、通过配置文件启动mongodb服务-开启认证
在配置文件中添加auth=true配置,开启安全认证。

启动服务即可。

 

二、创建mongoDB用户

开启认证后,连接mongodb时,就需要提供用户名和密码。

mongodb的用户分两种,一种是管理员,一种是普通用户。

管理员管理普通用户、普通用户管理数据库数据,所以我们要先创建管理员

1、创建管理员必须要在admin数据库下创建,首先关闭认证

2、选择admin

3、给管理员创建用户和密码

后面的db必须为admin

db.createUser({user:'admin',pwd:'admin',roles:[{role:'userAdminAnyDatabase',db:'admin'}]})


mongodb role类型

数据库用户角色(Database User Roles):
read:授予User只读数据的权限
readWrite:授予User读写数据的权限
数据库管理角色(Database Administration Roles):
dbAdmin:在当前dB中执行管理操作
dbOwner:在当前DB中执行任意操作
userAdmin:在当前DB中管理User
备份和还原角色(Backup and Restoration Roles):
backup
restore
跨库角色(All-Database Roles):
readAnyDatabase:授予在所有数据库上读取数据的权限
readWriteAnyDatabase:授予在所有数据库上读写数据的权限
userAdminAnyDatabase:授予在所有数据库上管理User的权限
dbAdminAnyDatabase:授予管理所有数据库的权限
集群管理角色(Cluster Administration Roles):
clusterAdmin:授予管理集群的最高权限
clusterManager:授予管理和监控集群的权限,A user with this role can access the config and local databases, which are used in sharding and replication, respectively.
clusterMonitor:授予监控集群的权限,对监控工具具有readonly的权限
hostManager:管理Server
4、创建普通用户

db为要操作的数据库

use shop  
db.createUser({user:'dev',pwd:'123456',roles:[{role:'dbOwner',db:'shop'}]})   
三、开启认证

1、登录,在mongo客户端界面,首先切换到admin下,在输入用户名和密码登录。

2、查看系统用户信息

3、修改用户密码

db.changeUserPassword(username, password)
①、修改用户密码,首先用管理员登录。

②、切换到要修改用户所管理的数据库上。例如,shopuser用户管理shop数据库。首先切换到shop数据库。

③、再修改shopuser用户的登录密码

4、删除用户

①、删除用户,首先用管理员登录。

②、切换到要删除的用户所管理的数据库上。例如,shopuser用户管理shop数据库。首先切换到shop数据库。

③、再删除shopuser用户

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MongoDB管理员密码重置的步骤如下: 1. 进入MongoDB的命令行界面。 2. 连接到admin数据库:`use admin` 3. 执行以下命令切换到system.users集合:`db.system.users.find()` 4. 找到你要重置密码用户,并将该用户的文档删除:`db.system.users.remove({user:"username"})` 5. 创建一个新的管理员用户,并赋予角色`userAdminAnyDatabase`:`db.createUser({user:"newuser", pwd:"newpassword", roles:[{role:"userAdminAnyDatabase", db:"admin"}]})` 6. 退出MongoDB命令行界面。 7. 使用新的管理员用户密码登录MongoDB。 注意:重置密码会中断与数据库的所有连接,因此应该在维护时间段内执行。 ### 回答2: 要重置MongoDB管理员密码,可以按照以下步骤进行操作: 1. 打开终端或命令提示符,并定位到MongoDB安装目录下的bin文件夹。 2. 运行mongod.exe --dbpath <MongoDB数据文件夹路径> --repair命令,来修复数据库。 3. 在命令行中输入mongod --dbpath <MongoDB数据文件夹路径> --nojournal,来启动MongoDB实例,并禁用日志记录。请确保<MongoDB数据文件夹路径>是指向实际的数据文件夹。 4. 打开另一个终端或命令提示符,并定位到MongoDB安装目录下的bin文件夹。 5. 运行mongo.exe命令,以连接到MongoDB实例。 6. 输入use admin,切换到admin数据库。 7. 输入db.dropUser("root"),以删除现有的管理员用户。 8. 输入db.createUser({user: "root", pwd: "<新密码>", roles: ["root"]}),以创建一个新的管理员用户。请将<新密码>替换为您要设置的新密码。 9. 退出mongo shell,重新启动MongoDB实例。 现在,您应该可以使用新的管理员密码访问和管理MongoDB了。请记住,确保保护好管理员密码,以确保数据库的安全性。 ### 回答3: 要重置MongoDB管理员密码,可以按照以下步骤进行: 1. 进入MongoDB的安装目录,找到bin文件夹下的mongod.exe程序。 2. 打开命令提示符,进入MongoDB的安装目录,执行以下命令:mongod.exe --dbpath 路径 --repair 其中,路径为MongoDB数据存储的目录。 3. 执行完修复命令后,再执行以下命令:mongod.exe --dbpath 路径 --journal 这一步是用来开启MongoDB的日志功能。 4. 接着,在命令提示符中输入mongo,进入MongoDB的命令行模式。 5. 输入以下命令,切换到admin数据库:use admin 6. 执行以下命令,以获取当前的管理员用户信息:db.system.users.find() 7. 找到管理员用户的文档,并记录下其_id字段的值。 8. 执行以下命令删除管理员用户:db.system.users.remove({_id: "管理员用户_id"}) 其中,将管理员用户_id替换为前一步记录的管理员用户的_id字段的值。 9. 输入以下命令添加新的管理员用户:db.createUser({user: "新用户名", pwd: "新密码", roles: ["root"]}) 将新用户名和新密码替换为您想要设置的管理员用户名和密码。 10. 重新启动MongoDB服务。 通过以上步骤,您就可以成功重置MongoDB的管理员密码了。重置密码后,记得将原来的管理员用户删除并添加新的管理员用户,以确保安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值