MongoDB

来源:互联网 发布:unity3d素材包 编辑:程序博客网 时间:2024/06/11 19:06

http://www.linuxidc.com/Linux/2016-06/132675.htm
在 CentOS7 上安装 MongoDB

进入到 /usr/local/ 目录:
cd /usr/local

在当前目录下创建 tools 目录:
mkdir -p tools

进入到 tools 目录中:
cd tools

下载与 CentOS 系统匹配的 mongodb-linux-x86_64-rhel70-3.2.4.tgz 文件:
wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.2.4.tgz

解压缩 mongodb-linux-x86_64-rhel70-3.2.4.tgz 文件:
tar -zxvf mongodb-linux-x86_64-rhel70-3.2.4.tgz
解压完成后得到 mongodb-linux-x86_64-rhel70-3.2.4 文件夹及其所属的文件;

重命名 mongodb-linux-x86_64-rhel70-3.2.4 文件为 mongodb3.2.4:
mv mongodb-linux-x86_64-rhel70-3.2.4 mongodb3.2.4

返回到上一级目录,并创建 mongodb 目录:
cd ../
mkdir -p mongodb

将 mongodb3.2.4 文件从 /usr/local/tools 目录中移动到 /usr/local/mongodb 目录中:
mv tools/mongodb3.2.4/ mongodb/

进入到 /usr/local/mongodb/mongodb3.2.4 目录中:
cd mongodb/mongodb3.2.4
在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放日志的目录:
mkdir -p data/test/logs

在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放数据文件的目录:
mkdir -p data/test/db

进入 bin 目录中:
cd bin/

创建配置文件 mongodb.conf:
vi mongodb.conf

在 mongodb.conf 写入如下内容:
设置数据文件的存放目录
dbpath = /usr/local/mongodb/mongodb3.2.4/bin/data/test/db

设置日志文件的存放目录及其日志文件名
logpath = /usr/local/mongodb/mongodb3.2.4/bin/data/test/logs/mongodb.log

设置端口号(默认的端口号是 27017)
port = 27017

设置为以守护进程的方式运行,即在后台运行
fork = true

nohttpinterface = true
nohttpinterface = true
idae - MongoDB config end - 2016-05-02

按英文状态下的“:wq”保存并退出;

参数解释:
–dbpath 数据库路径(数据文件)
–logpath 日志文件路径
–master 指定为主机器
–slave 指定为从机器
–source 指定主机器的IP地址
–pologSize 指定日志文件大小不超过64M.因为resync是非常操作量大且耗时,最好通过设置一个足够大的oplogSize来避免resync(默认的 oplog大小是空闲磁盘大小的5%)。
–logappend 日志文件末尾添加,即使用追加的方式写日志
–journal 启用日志
–port 启用端口号
–fork 在后台运行
–only 指定只复制哪一个数据库
–slavedelay 指从复制检测的时间间隔
–auth 是否需要验证权限登录(用户名和密码)
–syncdelay 数据写入硬盘的时间(秒),0是不等待,直接写入
–notablescan 不允许表扫描
–maxConns 最大的并发连接数,默认2000
–pidfilepath 指定进程文件,不指定则不产生进程文件
–bind_ip 绑定IP,绑定后只能绑定的IP访问服务

15 启动 mongodb 服务:
15.1 以自定义的 mongodb 配置文件方式启动:
./mongod –config mongodb.conf
15.2 以修复模式启动 mongodb:
./mongod –repair -f mongodb.conf
15.3 以参数式启动:
./mongod /usr/local/mongodb/mongodb3.2.4/bin/mongod –dbpath=/usr/local/mongodb/mongodb3.2.4/bin/data/test/db –logpath=/usr/local/mongodb/mongodb3.2.4/bin/data/test/logs/mongodb.log –fork
如果报如下错误:
ERROR: child process failed, exited with error number 1
很可能是 mongodb.conf 中配置的路径不一致问题;
如果报如下错误:
ERROR: child process failed, exited with error number 100
很可能是没有正常关闭导致的,那么可以删除 mongod.lock 文件

查看 mongodb 进程:
ps aux |grep mongodb

查看 mongodb 服务的运行日志:
tail -200f /usr/local/mongodb/mongodb3.2.4/bin/data/test/logs/mongodb.log

检查端口是否已被启动:
netstat -lanp | grep 27017

杀死 mongodb 进程,即可关闭 mongodb 服务:
kill -15 PID

如果出现如下情况
warning: Failed to connect to 127.0.0.1:27017, reason: errno:111 Connection refused

可以采用如下两种方式解决:
若数据库出现如上不能连接的原因,可能是data目录下的mongod.lock文件问题,可以用如下命令修复:
./bin/mongod –repair
或者直接删除mongod.lock
rm -f /usr/local/mongodb/data/db/mongod.lock
然后再启动 mongodb 服务:
./mongod –config mongodb.conf
如果以上两部依然解决不掉,则是路径文件,我们可以删除 /usr/local/mongodb/mongodb3.2.4/bin/data 目录及其子目录,并采用绝对路径的方式:
./mongod /usr/local/mongodb/mongodb3.2.4/bin/mongod –dbpath=/usr/local/mongodb/mongodb3.2.4/bin/data/test/db –logpath=/usr/local/mongodb/mongodb3.2.4/bin/data/test/logs/mongodb.log –fork

将 mongodb 服务加入到自启动文件中:
vi /etc/rc.local
在文件末尾追加如下命令:
/usr/local/mongodb/mongodb3.2.4/bin/mongod –config mongodb.conf
保存并退出:
:wq!

客户端常用命令:
db.version(); # 查看 mongodb 的版本
use test; # 进入到指定的数据中,这里是 test 数据库

在服务器本地测试一下,使用命令
./mongo 127.0.0.1
MongoDB shell version: 3.2.4
connecting to: 127.0.0.1/test

mongo常用指令
use db
show dbs
show collections
db.db.find()