为了账号安全,请及时绑定邮箱和手机立即绑定

MongoDB 的用户配置与基于Scala的使用

标签:
MongoDB

刚刚接触mongo,可能会踩到不少的坑,在此记录一发mongo的配置日记,之后随着学习的进行,将陆陆续续更新mongoDB的不同配置问题。

MongoDB 权限设置

  • 在安装MongoDB之后,由于没有在安装使设置任何的权限,需要进入MongoDB系统进行配置。默认情况下,MongoDB安装路径下bin目录下输入

    // 因为我的数据库目录存在了一个只有root有权限的地方,所以开启mongo需要sudo$ sudo ./mongod
    $ ./mongo

将会进入不通过权限认证(用户名,密码)访问mongo数据库的模式,在这个模式下,是没有办法进行新用户的创建的,所以我们在开启Mongo需要多加一个配置项

$ sudo ./mongod --auth
$ ./mongo

此时就会进入一个需要验证用户名,密码的模式,我们进入admin后,就可以创建一个超级用户了~具体执行代码如下:

// in MongoDB system;在3.0之后,db.addUser()不再使用>>> use admin;
>>> db.createUser({  
        user: "root",
        pwd: "root",
        roles:[{
            role: "root",  
            db: "当需要指定这个用户可以访问的database时,这个字段可以用来指定这个database"
        }]
        })

这样就创建了一个MongoDB的超级用户。

如何验证用户是否可用

  • 在创建好以上用户名密码之后,在--auth的模式下重启mongo。此时,如果输入

>>> show collections

系统将会弹出类似于"not authorized"的信息,表明你不是一个通过验证的用户。此时,如果执行以下代码:

>>> use admin;
>>> db.auth("root", "root");1>>> show collections;

我们看到系统在auth之后返回了1,表明已经通过了验证。此时show collections将会看到admin下面的所有信息。至此,该用户名已可用。

超级用户权限不够怎么办

  • 我们也有可能遇到在初始情况下因为手贱把db.createUser方法中的role设定为空的情况,这样的话我们创建的root的用户是没有任何的权限的,就连退出都不行。此时的解决方法是,退出auth模式,重新进入非认证的模式,使用db.updateUser()方法更改root的权限:

// 注意这个地方没有--auth的配置$ sudo ./mongod
$ ./mongo
>>> use admin;
>>> db.updateUser("root", {roles:[{role: "root", db: 指定的数据库名称}], 
                                     pwd: ”也可以修改密码“})

这样这个”root“就有了超级管理员的权限。

MongoDB后台运行服务

  • 通常,我们启动MongoDB需要先./mongod再mongo才可以启动这一服务,当./mongod这个会话被杀死后,mongo的服务就停止了。所以,如果是远程的跳板机,我们需要通过后台启动服务的方法,使得这台机器上的Mongo服务处于一直运行的状态:

    $ sudo ./mongod --fork --logpath /data/log/mongodb.log --dbpath /data/db/ --auth

    注意加上auth,这样你的mongo就可以随时使用

    $ ./mongo

    通过用户名认证来访问各个数据库了。

Mongo 可视化界面的使用

roboMongo新建mongo链接

  • 创建链接需要点击create,输入所需的address,和authentication下对应数据库访问的的用户名密码,即可建立连接。

使用Scala连接MongoDB数据库

  • 作者在经过一番比较之后,选择了mongo-scala-driver这个jar包,下面说一下这个包的配置方法(使用包管理框架为Maven)

      import scala.collection.immutable.IndexedSeq
      import org.mongodb.scala._  import Helpers
    • 对MongoDB进行操作
      这里再插一句关于MongoDB在认证模式下如何直接使用认证的uri访问MongoDB的方法:

        // 建立连接
        val mongoClient = MongoClient( [你的MongoDB uri] )  
        val database = mongoClient.getDatabase( [你有权限访问的database的名字] )
        val collection = database.getCollection( [你想要访问的collection名字] )  // 删除该collection
        collection.drop().results()  // 向该collection批量添加记录
        // 因为在操作的时候这个方法里的raw input是一个HashMap,  
        // 对于数据库的insert操作就用HashMap为例  
        val documents: IndexedSeq[bson.Document] = intToInfo.toIndexedSeq.map{  
                case (i, switchInfo) => {              // 注意这里用到了gson的jar包
                    val gson = new Gson()              // insert的数据格式要转换为IndexedSeq[bson.Document]
                    Document(gson.toJson(switchInfo))
                }}
        collection.insertMany(documents).results()

后续将会更新数据的读取,更新,前端展示等内容,由于本文太长不看,可能会另起一篇。



作者:冘若烦
链接:https://www.jianshu.com/p/1dc8f982600f

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消