MongoDB的使用(1):在Centos7上安装MongoDB

一、简单介绍:

MongoDB是一个介于关系型数据库和非关系型型数据库之间的产品,是非关系数据库中功能最丰富的,最像关系数据库的,面向集合、模式自由、文档型的数据库。

大家很有必要理解一下几个要点:

  1. 面向集合:意思是数据被分组存储在数据集中被称为一个集合(collection),每一个集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档,集合的概念类似于关系型数据库中的表,不同的是集合不需要定义任何模式;

  2. 模式自由:意思是集合里面没有行或者列的概念,例如这两个记录 {“name”:”lsgogroup”}、{“age”:25} 可以存在于同一个集合里面;

  3. 文档型:意思是我们在MongoDB中存储的数据是 键-值 对的集合,键是字符串,值可以是数据类型集合里面的任意类型,包括数组和文档,每一个文档相当于关系数据库中的一条记录。

简而言之,言而总之,大家记住MongoDB的三要素:数据库,集合,文档,其中“集合”就是对应关系数据库中的“表”,“文档”对应“行”。

二、安装:

cd /usr/local/src

wget -c https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.2.9.tgz

tar -zxvf mongodb-linux-x86_64-3.2.9.tgz    //生成文件夹 mongodb-linux-x86_64-3.2.9

#在/usr/local/下生成mongodb文件夹,并存放解压出来的文件
mv mongodb-linux-x86_64-3.2.9 ../mongodb    

#在 /usr/local/mongodb/bin/ 目录中创建一个存放日志的目录:
cd /usr/local/mongodb/bin
mkdir -p data/test/logs

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

#创建配置文件:
vim mongodb.conf

#在配置文件中添加以下内容:
# idae - MongoDB config start - 2016-05-02

# 设置数据文件的存放目录
dbpath = /usr/local/mongodb/bin/data/test/db

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

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

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

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

保存退出。

mongodb.conf配置文件中参数解释:
–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访问服务

三、启动 mongodb 服务

#1、以自定义的 mongodb 配置文件方式启动:
./mongod --config mongodb.conf

#2、 以修复模式启动 mongodb:
./mongod --repair -f mongodb.conf

#3、以参数式启动:
/usr/local/mongodb/bin/mongod --dbpath=/usr/local/mongodb/bin/data/test/db --logpath=/usr/local/mongodb/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服务已经正常开启。

#查看 mongodb 进程:
ps aux |grep mongodb

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

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

#杀死 mongodb 进程,即可关闭 mongodb 服务:
kill -15 PID
#PID 可以通过 ps aux | grep mongodb 查看到

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

出现的常见问题及解决方法:
1、如果出现如下情况
warning: Failed to connect to 127.0.0.1:27017, reason: errno:111 Connection refused

可以采用如下两种方式解决:

1.1 若数据库出现如上不能连接的原因,可能是data目录下的mongod.lock文件问题,可以用如下命令修复:
./bin/mongod –repair

1.2 或者直接删除mongod.lock
rm -f /usr/local/mongodb/data/db/mongod.lock
然后再启动 mongodb 服务:
./mongod –config mongodb.conf

如果以上两部依然解决不掉,则是路径文件,我们可以删除 /usr/local/mongodb/bin/data 目录及其子目录,并采用绝对路径的方式:
/usr/local/mongodb/bin/mongod –dbpath=/usr/local/mongodb/bin/data/test/db –logpath=/usr/local/mongodb/bin/data/test/logs/mongodb.log –fork

四、总结:

如果我们用 ps aux |grep mongodb 能查看到mongodb的进程,或者直接 /usr/local/mongodb/bin/mongo 能打开客户端,则证明我们的 mongodb 已经安装并且开启服务成功!

在下一篇博客中,我将介绍mongodb的简单应用。

本博客大部分参考自在 CentOS7 上安装 MongoDB

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值