1.MongoDB权限介绍

  a 上篇文章中,我们在Linux下配置了MongoDB环境并且将其设置为服务随机器启动而启动,那么接下来这篇文章我们就来简单说一下MongoDB下对登录用户权限的管理。
  b  MongoDB安装完成后,默认是不需要输入用户名密码即可登录的,但是往往数据库方面我们会出于安全性的考虑而设置用户名密码,本篇文章主要介绍了MongoDB添加管理员/普通用户的方法。
  c 在我们使用的关系型数据库中,一般都是含有权限控制的,也就是说配置什么用户访问什么数据库,什么数据表,什么用户可以对表进行增删改,什么用户可以对表进行读取等等都是可以配置,那么MongoDB作为一个非关系型数据库的典型,它其实也是可以配置的,而掌握MongoDB的权限我们只需要简单理解下面几点,后面按照下面的几点去配置即可(网上学习所得到的总结)。
    c.1 MongoDB是没有默认管理员账号的,所以要先添加管理员账号,在开启权限认证。
    c.2 切换到admin数据库,添加的账号才是管理员的账号。
    c.3 用户只能在用户所在的数据库登录,包括管理员账号。
    c.4 管理员可以管理所有的数据库,但是不能直接管理其它数据库,要先在admin数据库中认证才可以,也是为了 安全性考虑。
  d 本学习笔记在linux下安装的MongoDB的版本是3.2.8,所以下面操作的命令都是以3.2.8版本为例,这是因为老版本和新版本的命令有所不同,请大伙周知,如果大家用的版本比较低,请自行查看命令是什么进行测试操作。

2 MongoDB添加管理员账户

  a 上面简单的说明之后,下面我们需要开始连接数据库进入CLI管理界面,只有进入此页面之后我们才能够对其进行操作(暂时为用客户端,后面会用客户端来进行说明)。
    a.1 首先跳转到MongoDB安装包下的bin文件夹下,然后使用命令(./mongo)启动,则会启动成功(确保MongoDB的服务已启动),如图所示(MongDB的安装路劲为自己的安装路径,可能会和我的不一致,请检查):
      
    a.2 如图所示,则连接成功,我们即可在>后面进行操作。
  b 连接数据库并且切换到用户表下
    b.1 连接成功之后首先我们输入命令:show dbs,我们发现其系统中内置了一个数据库名字为local(如果大家查询出来还有一个admin数据库,那是因为你使用的是低版本的MongoDB),admin库是不存在的,需要我们自己创建。
    b.2 (use admin) 使用此命令创建一个admin数据库,权限管理就要使用admin数据库,此命令也是切换数据库的命令。
    b.3 (show collections) 切换到admin库之后,使用show collections查询,我们发现该数据库下包含了一个system.user和system.version表,我们主要来看system.user表,这张表是用来存放超级管理员的。
    b.4 (db.system.users.find())首先使用命令查询system.user表中含有数据否,输入命令:db.system.users.find(),查询发现数据库是空的,这时候我们给这个表添加一个管理员账户。
  d 添加用户并且为用户指定角色和数据库,命令如图所示:
    
    d.1 user:用户名
    d.2 pwd:密码
    d.3 customData:描述字段
    d.4 roles:指定用户的角色,可以用一个空数组给新用户设置空角色,在roles字段可以指定内置角色和用户定义的角色,内置角色在在第四个模块我们专门回来说它。
  e (show users、db.system.users.find())当创建完用户之后,我们可以用前面的两个命令来查询用户的信息,自行查询眼看。
  f  当添加完用户信息之后,我们的想法就是马上重新连接验证是否权限已经控制,这里就打击你了,当然还没有控制,这里我们还需要开启用户权限验证,因为MongoDB默认是不开启权限验证的,下面我们简单说一下如何开启权限验证。

MongoDB开启用户权限验证

  a 通过上面的简单介绍我们已经配置了用户和密码以及角色,但是正如上面最后一步我所说,这里登录还是登录不了,那么是因为我们没有开启用户权限验证,如何开启这个权限验证呢。
  b 首先我们打开上一篇我们配置的mongodb.conf配置文件,我的安装路径是:(/usr/local/kencery/mongoDB/mongodb/bin/),使用vim打开,找到这样一个属性(auth=true),将前面的注释去掉,保存。
  c 重启MongoDB服务,因为我在前面已经将MongoDB设置为服务,所以我使用下面的命令即可对MongoDB进行关闭和重启
    c.1 service mongod stop
    c.2 service mongod start
  d 重启之后我们在连接数据库然后切换到admin数据库下,使用db.system.users.find()命令查看,如下图所示,则说明配置已经成功
    
  e 如上图所示,提示信息提示我们没有对其进行授权,此时,我们输入如下命令进行授权,授权之后我们使用查询命令去查询发现已经可以查询,到这里简单权限已经设置完成。
    e.1 db.auth("kencery","kencery")  

MongoDB的roles角色简单介绍

  a MongoDB内置角色官网文档介绍:http://docs.mongoing.com/manual-zh/reference/built-in-roles.html
  b 关于MongoDB的内置角色,我们大概可以分为以下几种来简单说一下
    b.1 Database User Roles(数据库用户角色):read、readWrite
    b.2 Database Administration Roles(数据库管理角色):dbAdmin、dbOwner、userAdmin
    b.3 Culster Administration Roles(管理员组,针对整个系统进行管理):clusterAdmin、clusterManager、clusterMonitor、hostManager
    b.4 Backup and Restoration Roles(备份还原角色组):backup、restore
    b.5 All-Database Roles(所有数据库角色):readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
    b.6 Superuser Roles(超级管理员):root、(dbOwner、userAdmin、userAdminAnyDatabase这几个角色角色提供了任何数据任何用户的任何权限的能力,拥有这个角色的用户可以在任何数据库上定义它们自己的权限)
    b.7  Internal Role(内部角色,一般情况下不建议设置):__system
  c 关于上面每一个角色的意义是什么,请自行去官网或者这篇文章去查看,地址是:http://www.cnblogs.com/SamOk/p/5162767.html
  d 我暂时只是理解了一些,还不能全部理解,因为毕竟只是自己学习,所以只是自己做实践测试了一些角色的意义,如果大家对那个不太懂,可以留言我们一块探讨。

MongoDB下创建一个新的数据库并且配置读写(read、readWrite)权限管理的案例说明

  a 在上面我们在admin数据库下为kencery用户建立了一个userAdminAnyDatabase角色,使用这个用户来管理用户,可以通过这个角色来创建、删除角色。首先我们切换到admin下授权用户登录(重新连接之后的操作),命令如下:
    a.1 use admin
    a.2 db.auth("kencery","kencery")  返回1则表示授权成功,否则授权失败
    a.3 show dbs  验证授权是否成功。
  b 授权成功之后,首先我们创建一个日志表(logs),给logs表创建一个read和readwrtite账号。read的账号对应制度账号,readwrite账号对应读写账号,命令如下:
    b.1 use logs
    b.2 db.createUser({
                  user:"read",                                   
                  pwd:"read",
                  roles:[{role:"read",db:"logs"}]
             })
    b.3 添加读写用户,将上面的命令中的user和pwd改为:readwrite,roles中的role改为readWrite,其它的不用改执行即可。
    b.4 最后查询我们添加的用户如下所示,则说明我们对其读和读写用户添加完成。
      
  c 上面我们创建了两个账号之后,首先我们来验证读写账号(readwrite(可以写入当前数据库的用户信息)),
    c.1 首先我们不要切换用户,直接在kencery用户下面对logs数据库下的payment表进行插入,会提示我们插入失败,没有权限,这是因为userAdminAnyDatabase权限只是针对用户管理的,对其它的表示没有操作权限的,如下如所示:
      
    c.2 从上面看到提示我们权授权失败,这时候用我们创建的readwriter(读写)账号授权,然后在进行插入和查询,则发现插入以及查询均成功,如图所示:
      
    c.3 从上面我们看到对于读写权限验证没有问题。
  d 上面测试了读写权限,下面我们测试一下读权限(read)
    d.1 继续上面的操作,首先我们授权给read用户,然后使用read用户去插入和查询,则发现插入提示没有授权,而查询成功,则我们期望的所实现,如图所示:
      
    d.2 如上图所示,则说明授权已经完成,完全可以配置给某些用户只能去读而不能插入修改的权限。

MongoDB超级管理员root

  a 上面我们简单介绍了读写权限以及读权限,那么下来我们说一下root权限,它是超级权限,也就是说你只要配置其账号,则可以对数据进行任何的操作,当然正常环境中不建议使用,危险性极高!但是为了学习,我们还是来讲述一下这个角色的使用,
  b  首先在上面的环境中我们继续授权给kencery用户,然后创建一个超级用户nouse(不建议使用)。但是当我们授权的时候发现报错了,报错截图:
    
        备注:原因是我们在admin数据库下面创建的用户,不能直接在其它库下面授权,只能在账号创建库下面授权,然后在去其他库访问。
  c 从上面得到,首先我们切换数据库到admin,然后创建用户nouse,权限角色给root,数据库对应admin,脚本在上面都已经写过,这里就不再累赘了。
  d 完成之后,我们切换授权给用nouse之后,切换到logs数据库下面进行各种操作,发现都是可以操作的,简单截图如下:
    
  e 因为账号始终都是在当前需呀授权的数据库下面进行授权的,那要不是在当前数据库下面授权呢,意思就是,我现在切换到admin数据库下添加用户给logs数据库,创建完成之后如何操作呢?始终记下来上面所述的那句:(哪里创建哪里认证)在admin数据库下面创建的用户,不能直接在其它库下面授权,只能在账号创建库下面授权,然后在去其他库访问。
  f 从文章开始到现在我们已经创建了很多账户,那么我们可以使用下面两条命令来查询账户以及账户总数
    f.1 db.system.users.find().pretty()
    f.2 db.system.users.find().count()
    
    因本人是学习笔记,故而部分内容来源于网络,希望能学有所得
       关于权限这块现在只是简单的了解以及配置,后面如果能够研究的更深的话还会继续来说这块

MongoDB学习笔记—权限管理的更多相关文章

  1. [转]Oracle学习笔记——权限管理

    本文转自:http://www.cnblogs.com/whgw/archive/2011/10/30.html 一.系统的默认用户 1)sys用户是超级用户,具有最高权限,具有sysdba角色,有c ...

  2. MongoDB学习笔记——索引管理

    索引 索引能够提升查询的效率.没有索引,MongoDB必须扫描集合中的所有文档,才能找到匹配查询语句的文档. 索引是一种特殊的数据结构,将一小块数据集保存为容易遍历的形式.索引能够存储某种特殊字段或字 ...

  3. MongoDB学习笔记——集合管理

    创建集合 使用db.createCollection(name, options) 方法创建集合 name 所创建的集合名称必选! options 可选.指定有关内存大小及索引的选项 db.creat ...

  4. MongoDB学习笔记(三)--权限 && 导出导入备份恢复 && fsync和锁

    权限                                                                                             绑定内网I ...

  5. mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...

  6. MongoDB学习笔记:快速入门

    MongoDB学习笔记:快速入门   一.MongoDB 简介 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.在高负载的情况下,添加更多的节点,可以保证服务器性能.M ...

  7. MongoDB学习笔记(四)--索引 && 性能优化

    索引                                                                                             基础索引 ...

  8. MongoDB学习笔记(二)--Capped集合 && GridFS存储文件

    Capped集合                                                            Capped集合的大小是固定的,如果空间都被用完了,新添加的对象 ...

  9. MongoDB学习笔记(1):MongoDB的安装和说明

    MongoDB学习笔记(1):MongoDB的安装和说明 快速开始 下载地址 官网下载: https://www.mongodb.com/download-center?jmp=nav#communi ...

随机推荐

  1. js事件(event)的运行原理

    昨天写click事件时候突然脑袋抽筋想了想浏览器是怎么执行click事件的,为什么我们可以用e或者window.event这个对象获取一些事件的属性呐?以下是我的理解.如果您有更好的理解,欢迎评论!! ...

  2. JQuery图片切换动画效果

    由于博主我懒,所以页面画的比较粗糙,但是没关系,因为我主要讲的是如何实现图片动画切换. 思路:想必大家都逛过淘宝或者其他的一些网站,一般都会有图片动画切换的效果,那是怎样实现的呢?博主我呢,技术不是很 ...

  3. iOS-在团队开发过程中控制代码版本

    Cornerstone Svn简单使用指南: -- what if 负责编写 一.安装并拷贝项目 1.第一步:安装svn.2.第二步:第一个使用svn,找到“Check Out Working Cop ...

  4. JQuery插件之Jquery.datatables.js用法及api

    1.DataTables的默认配置 $(document).ready(function() { $('#example').dataTable(); } ); 示例:http://www.guoxk ...

  5. Owin的URL编码怎么搞?以前都是HttpUtility.UrlEncode之类的,现在连system.web都没了,肿么办?

    Owin的URL编码怎么搞?以前都是HttpUtility.UrlEncode之类的,现在连system.web都没了,肿么办? 编码: Uri.EscapeDataString(name) 解码: ...

  6. webBrowser 加载网页

    事件 webBrowser_DocumentCompleted private void webBrowser_DocumentCompleted(object sender, WebBrowserD ...

  7. 自定义配置UEditor 工具栏上的按钮列表

    修改配置项的方法: 1. 方法一:修改 ueditor.config.js 里面的 toolbars 2. 方法二:实例化编辑器的时候传入 toolbars 参数 方法一:在ueditor.confi ...

  8. 关于SubSonic3.0插件使用实体进行更新操作时(执行T.Update()或T.Save()),某些列无法进行修改操作的问题处理

    SubSonic3.0插件在创建实体后,对实体进行赋值操作时,为了去除一些不必要更新的字段,减少更新的内容,会将更新内容与默认值进行比较,如果默认值与当前更新的内容相等时,则不提交更新本列,这主要是为 ...

  9. Linux异常表

    一.为什么需要异常表? 处于内核态的程序有下面四种情况会产生缺页异常: 1.内核试图访问属于进程地址空间的页,但是,该页对应的页框不存在或者内核试图去访问一个只读的页,分别对应“请求调页”和“写时复制 ...

  10. Java内存模型深度解析:重排序 --转

    原文地址:http://www.codeceo.com/article/java-memeory-2.html 数据依赖性 如果两个操作访问同一个变量,且这两个操作中有一个为写操作,此时这两个操作之间 ...