前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux下mongodb用户管理和设置远程登陆

Linux下mongodb用户管理和设置远程登陆

作者头像
ACK
发布2020-01-14 16:55:37
3.4K0
发布2020-01-14 16:55:37
举报
文章被收录于专栏:flytam之深入前端技术栈

折腾了下linux服务器上的mongodb的远程登陆,遇到了点问题,在这里记录下来。以备以后查询。

前提:已经在linux上安装好了mongodb。安装方法这里不说了,网上各种有。 本地用到的工具(windows):mongoChef(一个可视化操作工具,可以用于3.xx版本,romongo不行)

首先vim /etc/mongodb.conf。将

代码语言:javascript
复制
auth=true   //把#注释去掉,安全起见,远程登陆需要用户验证
#bind_ip 127.0.0.1  //注释掉这句,表明允许远程连接,或者指点允许远程登陆的ip

重启数据库 /etc/init.d/mongodb restart

然后连接到数据库

代码语言:javascript
复制
use admin
//创建root用户,root用户既可以创建用户,也可以对任何数据库操作,权限最高的
db.createUser(
...  {
...    user: "xxxx",
...    pwd: "xxx",
...    roles: [
...       { role: "root", db: "admin" }   //这里的role是设置用户的角色 ,db是指属于哪个数据库
...    ]
...  }
... )


//或者一般情况下不用root用户,而是创建一个管理用户权限的用户,注意这个用户只有管理用户权限的权力,而没有对其他数据库操作的权利
db.createUser(
...   {
...     user: "tanjiahui",
...     pwd: "123456@qq",
...     roles: [ { role: "root", db: "admin" } ]
...   }
... )

对用户进行认证

代码语言:javascript
复制
db.auth("name","passwd");
//返回了1表示成功

如果用户的权限不足的时候会报错

代码语言:javascript
复制
not authorized xxxxx

一些小tips: 如果忘记了用户的密码之类的,可以通过把auth:true注释再重启数据库再对用户进行相关创建。 - 常用的role值: 1. 数据库用户角色:read、readWrite; 2. 数据库管理角色:dbAdmin、dbOwner、userAdmin; 3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager; 4. 备份恢复角色:backup、restore; 5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase 6. 超级用户角色:root // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase) 7. 内部角色:__system - 相应的功能 - Read:允许用户读取指定数据库 - readWrite:允许用户读写指定数据库 - dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile - userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户 - clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。 - readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限 - readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限 - userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限 - dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。 - root:只在admin数据库中可用。超级账号,超级权限

然后就可以通过我们的mongochef对数据库进行远程连接了

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

连接后进行用用户认证,再测试相关命令 出现上图即表示成功连接到远程数据库了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MongoDB
腾讯云数据库 MongoDB(TencentDB for MongoDB)是腾讯云基于全球广受欢迎的 MongoDB 打造的高性能 NoSQL 数据库,100%完全兼容 MongoDB 协议,支持跨文档事务,提供稳定丰富的监控管理,弹性可扩展、自动容灾,适用于文档型数据库场景,您无需自建灾备体系及控制管理系统。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档