刚刚接触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服务处于一直运行的状态:
注意加上auth,这样你的mongo就可以随时使用$ sudo ./mongod --fork --logpath /data/log/mongodb.log --dbpath /data/db/ --auth
通过用户名认证来访问各个数据库了。$ ./mongo
Mongo 可视化界面的使用
- 本文使用的roboMongo,下载地址为https://robomongo.org/download。
- 进入roboMongo后,可以新增一个MongoDB的connection
- 创建链接需要点击create,输入所需的address,和authentication下对应数据库访问的的用户名密码,即可建立连接。
使用Scala连接MongoDB数据库
- 作者在经过一番比较之后,选择了mongo-scala-driver这个jar包,下面说一下这个包的配置方法(使用包管理框架为Maven)
-
pom中的配置:
<dependency> <groupId>org.mongodb.scala</groupId> <artifactId>mongo-scala-driver_2.11</artifactId> <version>2.0.0</version> </dependency>
在scala object文件中导入对应的库
(注意这个Helpers文件是一个对mongoDB进行操作的辅助文件,可以在:https://github.com/mongodb/mongo-scala-driver/blob/master/examples/src/test/scala/tour/Helpers.scala 下面找到代码)
import scala.collection.immutable.IndexedSeq import org.mongodb.scala._ import Helpers
-
对MongoDB进行操作
这里再插一句关于MongoDB在认证模式下如何直接使用认证的uri访问MongoDB的方法:- 使用的uri格式一般为:mongodb://[用户名]:[密码]@[host1]:[port1][,host2[:port2]]/database;如"mongodb://test:123456@localhost:27017/testBase"
// 建立连接 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()
-
后续将会更新数据的读取,更新,前端展示等内容,由于本文太长不看,可能会另起一篇。