mongodb 基础

安装

[root@node-1 ~]# cat /etc/yum.repos.d/mongodb-org-3.6.repo
[mongodb-org-3.6]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.6.asc


然后执行

yum -y install mongodb-org

启动

systemctl enable mongod.service
systemctl start mongod.service
systemctl status mongod.service  

连接

mongodb的默认端口是27017,使用mongo –host 指定地址连接

[root@node-1 ~]# mongo --host 127.0.0.1:27017
MongoDB shell version v3.6.0
connecting to: mongodb://127.0.0.1:27017/
MongoDB server version: 3.6.0
Server has startup warnings:
2017-12-20T17:12:40.249+0800 I STORAGE  [initandlisten]
2017-12-20T17:12:40.249+0800 I STORAGE  [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2017-12-20T17:12:40.249+0800 I STORAGE  [initandlisten] **          See http://dochub.mongodb.org/core/prodnotes-filesystem
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten]
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] ** WARNING: Access control is not enabled for the database.
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] **          Read and write access to data and configuration is unrestricted.
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten]
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten]
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten]
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten]

执行基本的运算

> 2+2
4
> 3+3*2233
6702

在x集合中插入10 并查询

> db.runoob.insert({x:10})
WriteResult({ "nInserted" : 1 })
> db.runoob.find()
{ "_id" : ObjectId("5a3a2b34d603e2d7ed10cf8b"), "x" : 10 }
>

报错解决

报错

2017-12-20T17:12:40.367+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.

这个错误意思就是允许hugepage可以动态分配,而不是系统启动时预先分配,看上去对内存消耗很大的服务都不喜欢它。感觉这是一个lazy loading的设计思想。

解决

[root@node-1 ~]# echo never > /sys/kernel/mm/transparent_hugepage/enabled
[root@node-1 ~]# echo never > /sys/kernel/mm/transparent_hugepage/defrag

连接mongodo

格式:

mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
  • mongodb:// 这是固定的格式,必须要指定。

  • username:password@ 可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登陆这个数据库

  • host1 必须的指定至少一个host, host1 是这个URI唯一要填写的。它指定了要连接服务器的地址。如果要连接复制集,请指定多个主机地址。

  • portX 可选的指定端口,如果不填,默认为27017

  • /database 如果指定username:password@,连接并验证登陆指定数据库。若不指定,默认打开 test 数据库。

  • ?options 是连接选项。如果不使用/database,则前面需要加上/。所有连接选项都是键值对name=value,键值对之间通过&或;(分号)隔开

选项 描述
replicaSet=name 验证replica set的名称。 Impliesconnect=replicaSet.
slaveOk=true|false true:在connect=direct模式下,驱动会连接第一台机器,即使这台服务器不是主。在connect=replicaSet模式下,驱动会发送所有的写请求到主并且把读取操作分布在其他从服务器。false: 在 connect=direct模式下,驱动会自动找寻主服务器. 在connect=replicaSet 模式下,驱动仅仅连接主服务器,并且所有的读写命令都连接到主服务器。
safe=true|false true: 在执行更新操作之后,驱动都会发送getLastError命令来确保更新成功。(还要参考 wtimeoutMS).false: 在每次更新之后,驱动不会发送getLastError来确保更新成功。
w=n 驱动添加 { w : n } 到getLastError命令. 应用于safe=true。
wtimeoutMS=ms 驱动添加 { wtimeout : ms } 到 getlasterror 命令. 应用于 safe=true.
fsync=true|false true: 驱动添加 { fsync : true } 到 getlasterror 命令.应用于 safe=true.false: 驱动不会添加到getLastError命令中。
journal=true|false 如果设置为 true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true
connectTimeoutMS=ms 可以打开连接的时间。
socketTimeoutMS=ms 发送和接受sockets的时间。