本文共 4369 字,大约阅读时间需要 14 分钟。
MongoDB官方文档:
MongoDB中文社区:
MongoDB特点:
根据DB-Engines的排名统计,MongoDB综合排名第五(2017年10月数据,前四名分别是Oracle,MySQL,SQL Server,PostgreSQL),在NoSQL领域(非RDBMS)里排名第一。
适用场景不适用的场景
下载mongodb的版本,两点注意
根据业界规则,偶数为稳定版,如3.2.X;奇数为开发版,如3.3.X
32bit的mongodb最大只能存放2G的数据,64bit就没有限制。MongoDB官网安装包下载地址:MongoDB安装文档:
Ubuntu下安装MongoDB:
python@ubuntu:~$ sudo apt-get install mongodb
使用MongoDB,需要先启动服务端,再使用客户端连接数据库。
服务端MongoDB 默认的存储数据目录为 /data/db,默认端口27017
服务的命令为mongod,可以通过help查看所有参数
python@ubuntu:~$ mongod --help
启动注意事项:
[initandlisten] exception in initAndListen: 29 Data directory /data/db not found., terminating
python@ubuntu:~$ sudo mkdir -p /data/dbpython@ubuntu:~$ sudo chmod 777 /data/db
#### 此乃 Warning 1:[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.[initandlisten] ** We suggest setting it to 'never'[initandlisten] [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.[initandlisten] ** We suggest setting it to 'never'#### 此乃 Warning 2:[initandlisten] ** WARNING: soft rlimits too low. rlimits set to 1024 processes, 64000 files. Number of processes should be at least 32000 : 0.5 times number of files.#### 此乃 Warning 3:[initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
注意:这里的三个Warning并非必须处理,大家了解即可:
Warning 1:[initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. [initandlisten] ** We suggest setting it to 'never' [initandlisten] [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. [initandlisten] ** We suggest setting it to 'never'
Linux的内存分配默认由内核动态分配,而不是由程序自行管理。而MongoDB对内存占用有那么点...严重,所以为了防止MongoDB占用内存过大而被内核"管理",官方推荐关闭动态分配。
默认"always"表示允许动态分配,对应的"never"就是不允许,所以我们将这两个文件内容修改为"naver"后就没有warning了。
# Ctrl + c 退出 MongoDB 数据库服务# 然后进入 root 用户下,执行修改命令python@ubuntu:~$ sudo su[sudo] python 的密码: root@ubuntu:~# sudo echo "never" > /sys/kernel/mm/transparent_hugepage/enabledroot@ubuntu:~# sudo echo "never" > /sys/kernel/mm/transparent_hugepage/defrag
实际上,除非网站DBA对数据库性能有极限要求,在通常情况下系统动态分配的内存页大小足够我们正常使用,而且更能优化整个系统,所以一般不必理会这个warning。而且这样只是临时修改Linux内核的设置,在Linux服务器重启后则会失效。
Warning 2:[initandlisten] ** WARNING: soft rlimits too low. rlimits set to 1024 processes, 64000 files. Number of processes should be at least 32000 : 0.5 times number of files.
这个WARNING(如果有的话)含义为: 表示默认分配给MongoDB的进程和文件数量限制过低,需要重新分配值:
# 打开 相关配置文件:root@ubuntu:~# vi /etc/security/limits.conf# 在打开的 文件最下方,添加,然后保存退出mongod soft nofile 64000mongod hard nofile 64000mongod soft nproc 32000mongod hard nproc 32000
Warning 3:
[initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
意思是我们在用root权限做这些事,理论上是不安全的。我们可以通过附加--auth参数,来使用用户认证来处理这个情况,这个后面会讲到。
python@ubuntu:~$ ps aux | grep mongod
客户端
python@ubuntu:~$ mongo --help
> exit(或Ctrl+C)
本文最终解释权归本文作者所有,未经允许不得私自转载