文档章节

MongoDB入坑

秋风醉了
 秋风醉了
发布于 2016/04/15 16:13
字数 993
阅读 141
收藏 0

MongoDB入坑

安装略

MongoDB启动方式

安装完mongodb后,就可以这样启动,

➜  mongodb pwd
/Users/xinxingegeya/IDE/mongodb
➜  mongodb bin/mongod

还可以通过指定参数方式启动,

➜  mongodb bin/mongod --dbpath=/data/db --bind_ip=127.0.0.1 --port=12345

然后就可以通过下面的方式连接到mongodb,

➜  mongodb bin/mongo 127.0.0.1:12345
MongoDB shell version: 3.2.4
connecting to: 127.0.0.1:12345/test
>

以上两种方式都是以非daemon方式启动的。如何以daemon方式启动呢?

可以使用mongodb自带的参数--fork,还要注意当使用fork参数的时候,必须指定logpath参数,如下,

➜  mongodb bin/mongod --dbpath=/data/db --bind_ip=127.0.0.1 --port=12345 --fork
BadValue: --fork has to be used with --logpath or --syslog
try 'bin/mongod --help' for more information
➜  mongodb bin/mongod --dbpath=/data/db --bind_ip=127.0.0.1 --port=12345 --fork --logpath=/Users/xinxingegeya/IDE/mongodb/log/mongodb.log
about to fork child process, waiting until server is ready for connections.
forked process: 1620
child process started successfully, parent exiting
➜  mongodb ps -ef | grep mongod
  501  1620     1   0 12:11下午 ??         0:01.15 bin/mongod --dbpath=/data/db --bind_ip=127.0.0.1 --port=12345 --fork --logpath=/Users/xinxingegeya/IDE/mongodb/log/mongodb.log
  501  1632   965   0 12:11下午 ttys002    0:00.00 grep --color=auto --exclude-dir=.bzr --exclude-dir=CVS --exclude-dir=.git --exclude-dir=.hg --exclude-dir=.svn mongod
➜  mongodb

为了方便,可以把配置参数写入到配置文件中,每次启动的时候都可以指定配置文件的方式启动。

mongodb的配置文件是基于yaml格式的,如下是部分配置,

systemLog:
   destination: file
   path: ./log/mongodb.log
   logAppend: true
net:
   port: 12345
   bindIp: 127.0.0.1
   maxIncomingConnections: 1000
processManagement:
   fork: true
security:
    authorization: disabled

指定配置文件方式启动,

➜  mongodb bin/mongod --config mongodb.yaml
about to fork child process, waiting until server is ready for connections.
forked process: 1717
child process started successfully, parent exiting
➜  mongodb ps -ef |grep mongod
  501  1717     1   0 12:26下午 ??         0:00.76 bin/mongod --config mongodb.yaml
  501  1723   965   0 12:26下午 ttys002    0:00.00 grep --color=auto --exclude-dir=.bzr --exclude-dir=CVS --exclude-dir=.git --exclude-dir=.hg --exclude-dir=.svn mongod
➜  mongodb

好的可以看到启动成功。


MongoDB添加用户

像mysql一样,mongodb也可以使用用户名和密码登录指定的数据库,如果不指定登录的数据库的话,默认是test数据库。如下,

➜  mongodb bin/mongo 127.0.0.1:12345
MongoDB shell version: 3.2.4
connecting to: 127.0.0.1:12345/test

下面就来演示一下如何使用用户名和密码来登。

首先在mydb数据库中添加用户,

> show dbs
testdb  0.000GB
> use mydb
switched to db mydb
> db.myCollection.insert({"name":"hello world"})
WriteResult({ "nInserted" : 1 })
> show dbs
mydb    0.000GB
testdb  0.000GB
> db.createUser(
...   {
...     user: "root",
...     pwd: "034039",
...     roles: [
...        { role: "readWrite", db: "mydb" },
...     ]
...   }
...  )
Successfully added user: {
	"user" : "root",
	"roles" : [
		{
			"role" : "readWrite",
			"db" : "mydb"
		}
	]
}
> show users
{
	"_id" : "mydb.root",
	"user" : "root",
	"db" : "mydb",
	"roles" : [
		{
			"role" : "readWrite",
			"db" : "mydb"
		}
	]
}
> show dbs
admin   0.000GB
mydb    0.000GB
testdb  0.000GB
> use admin
switched to db admin
> show users
> show collections
system.users
system.version
> db.system.users.find()
{ "_id" : "mydb.root", "user" : "root", "db" : "mydb", "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "ru0tsPFgcsem2Wca1ALZgA==", "storedKey" : "TEjwrgDStoS/C4CEXX0YWp5US/8=", "serverKey" : "Yx0Eji3t3RnrO0/LfFP6+rTs5es=" } }, "roles" : [ { "role" : "readWrite", "db" : "mydb" } ] }
>

从上面的操作来看,在mydb创建用户之后,多了一个admin数据库。

其实admin数据库是用来管理其他数据库的用户的。

总之现在在mydb数据库的用户创建好了,看一下如何来使用该用户认证,首先要开启mongodb的--auth参数,这里我们使用yaml配置文件选项来开启auth,

systemLog:
   destination: file
   path: ./log/mongodb.log
   logAppend: true
net:
   port: 12345
   bindIp: 127.0.0.1
   maxIncomingConnections: 1000
processManagement:
   fork: true
security:
    authorization: enabled

重启mongodb,

➜  mongodb bin/mongo 127.0.0.1:12345
MongoDB shell version: 3.2.4
connecting to: 127.0.0.1:12345/test
> show dbs
2016-04-15T16:07:30.725+0800 E QUERY    [thread1] Error: listDatabases failed:{
	"ok" : 0,
	"errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }",
	"code" : 13
} :
_getErrorWithCode@src/mongo/shell/utils.js:23:13
Mongo.prototype.getDBs@src/mongo/shell/mongo.js:53:1
shellHelper.show@src/mongo/shell/utils.js:700:19
shellHelper@src/mongo/shell/utils.js:594:15
@(shellhelp2):1:1

> use mydb
switched to db mydb
> show collections
2016-04-15T16:07:44.433+0800 E QUERY    [thread1] Error: listCollections failed: {
	"ok" : 0,
	"errmsg" : "not authorized on mydb to execute command { listCollections: 1.0, filter: {} }",
	"code" : 13
} :
_getErrorWithCode@src/mongo/shell/utils.js:23:13
DB.prototype._getCollectionInfosCommand@src/mongo/shell/db.js:746:1
DB.prototype.getCollectionInfos@src/mongo/shell/db.js:758:15
DB.prototype.getCollectionNames@src/mongo/shell/db.js:769:12
shellHelper.show@src/mongo/shell/utils.js:695:9
shellHelper@src/mongo/shell/utils.js:594:15
@(shellhelp2):1:1

> db.auth("root","034039")
1
> show collections
myCollection
>

可以看到,只有在auth通过后,命令才能执行成功。

也可以直接通过登录的时候完成用户认证,如下操作

➜  mongodb bin/mongo 127.0.0.1:12345/mydb -uroot -p034039
MongoDB shell version: 3.2.4
connecting to: 127.0.0.1:12345/mydb
> show collections
myCollection
>

=========END=========

© 著作权归作者所有

共有 人打赏支持
秋风醉了
粉丝 236
博文 577
码字总数 418437
作品 0
朝阳
程序员
MongoDB 最佳实践及2.8版本特性与功能

主要流程 MongoDB 2.8 版本特性与功能 MongoDB 在赶集网的应用 MongoDB 最佳实践 MongoDB 2.8 版本特性与功能 TJ MongoDB 开发者 TJ 强调 MongoDB 没有实际意义上的锁,只有 Latch,门栓。 ...

eui988
2015/04/18
0
1
10-【MongoDB入门教程】 Journaling日志机制

运行MongoDB如果开启了journaling日志功能,MongoDB先在内存保存写操作,并记录journaling日志到磁盘,然后才会把数据改变刷入到磁盘上的数据文件。为了保证journal日志文件的一致性,写日志...

jockchou
2015/06/24
0
3
win7下安装mongoDB数据库

第一步:到 http://www.mongodb.org/downloads 网站去下载对应系统的版本mongoDB数据库,如我下载的 (1)创建一个D:Program FilesmongoDB目录作为mongoDB的安装的目录,解压下载的数据库包,...

EDIAGD
2013/01/24
0
0
最全面MongoDB安装与配置

数据是每一前端人员必定接触的一样,所有的数据都是后端来编写,如果自己想练习项目,却没有数据,而是写一些假数据,去编写,或者通过json-server搭建一个数据,今天我们就通过MongoDB来搭建...

小周sri的码农
08/06
0
0
如何使用tableau连接mongodb数据库?

今天遇到了一个坑,我想把mongodb数据库中的数据导入到tableau中,好利用tableau来学习数据分析,结果我一直没连上…. 摸索了一番,过程如下: 首先在tableau官网上下载tableau desktop: 下...

爱吃西瓜的番茄酱
06/23
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Java 并发编程原理

为什么要使用多线程? 通过多线程提高吞吐量 伸缩性比较好,可以增加 CPU 核心来提高程序性能 什么场景下使用多线程? 如:tomcat BIO Java 如何实现多线程? Thread、Runnable、ExecutorSer...

aelchao
35分钟前
2
0
谨慎的覆盖clone方法

说在前面 有些专家级程序员干脆从来不去覆盖clone方法,也从来不去调用它,除非拷贝数组。 其他方式 可以提供一个构造函数或者工厂去实现clone功能。 相比于clone,它们有如下优势: 不依赖于...

XuePeng77
36分钟前
1
0
什么是最适合云数据库的架构设计?

分布式数据库技术发展多年,但是在应用、业务的驱动下,分布式数据库的架构一直在不断发展和演进。 开源金融级分布式数据库SequoiaDB,经过6年的研发,坚持从零开始打造数据库核心引擎。在技...

巨杉数据库
45分钟前
4
0
源码模仿之RPC

源码模仿之RPC RPC - 远程过程调用,概念不多赘述,可自行百度。 场景 统一api接口 生产者(提供远程接口调用方) 使用者(主动调用远程接口) 代码实现 API接口(公共依赖包) DemoEntity (...

GMarshal
46分钟前
1
0
Linux之安装Tomcat8

最近要在Linux上安装Tomcat,记录下 1.进入tomcat8的安装目录 List-1 root@iZwz9bjiawhqzfsklyht4rZ bin]# pwd/opt/app/tomcat8/bin[root@iZwz9bjiawhqzfsklyht4rZ bin]# ll总用量 83......

克虏伯
46分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部