关于Mongodb参数说明与常见错误处理的总结

所属分类: 数据库 / MongoDB 阅读数: 108
收藏 0 赞 0 分享

本文主要介绍的是关于Mongodb参数说明与常见错误处理的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:

一、在 CentOS7 上安装 MongoDB

1 通过 SecureCRT 连接至 CentOS7 服务器;

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

cd /usr/local

3 在当前目录下创建 tools 目录:

mkdir -p tools

4 进入到 tools 目录中:

cd tools

5 下载与 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

6 解压缩 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 文件夹及其所属的文件;

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

mv mongodb-linux-x86_64-rhel70-3.2.4 mongodb3.2.4

8 返回到上一级目录,并创建 mongodb 目录:

cd ../
mkdir -p mongodb

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

mv tools/mongodb3.2.4/ mongodb/

10 进入到 /usr/local/mongodb/mongodb3.2.4 目录中:

cd mongodb/mongodb3.2.4

11 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放日志的目录:

mkdir -p data/test/logs

12 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放数据文件的目录:

mkdir -p data/test/db

13 进入 bin 目录中:

cd bin/

14 创建配置文件 mongodb.conf:

vi mongodb.conf

在 mongodb.conf 写入如下内容:

# idae - MongoDB config start - 2016-05-02

# 设置数据文件的存放目录
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 文件

15 查看 mongodb 进程:

ps aux |grep mongodb

16 查看 mongodb 服务的运行日志:

tail -200f /usr/local/mongodb/mongodb3.2.4/bin/data/test/logs/mongodb.log

17 检查端口是否已被启动:

netstat -lanp | grep 27017

18 杀死 mongodb 进程,即可关闭 mongodb 服务:

kill -15 PID

PID 可以通过步骤 16 查看到

19 如果出现如下情况

warning: Failed to connect to 127.0.0.1:27017, reason: errno:111 Connection refused

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

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

./bin/mongod --repair

19.2 或者直接删除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

20 将 mongodb 服务加入到自启动文件中:

vi /etc/rc.local 

在文件末尾追加如下命令:

/usr/local/mongodb/mongodb3.2.4/bin/mongod --config mongodb.conf

保存并退出:

:wq!

21 客户端常用命令:

db.version(); # 查看 mongodb 的版本
use test; # 进入到指定的数据中,这里是 test 数据库

22 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中,键入如下命令,打开一个 mongodb 的客户端程序,即打开一个 mongodb 的 shell 客户端,这个 shell 客户端同时也是一个 JavaScript 编辑器,即可用输入任何的 JavaScript 脚本:

./mongo

默认连接至 test 数据库

23 在浏览器中输入 IP:27017,如:

http://101.201.212.129:27017/

可以查看 MongoDB 的版本信息;

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

MongoDB插入、更新、删除文档实现代码

本文通过实例代码给大家简单介绍了mongodb插入、更新、删除文档的方法,需要的的朋友参考下吧
收藏 0 赞 0 分享

mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)

对于文档的更新除替换外,针对某个或多个文档只需要部分更新可使用原子的更新修改器,能够高效的进行文档更新。更新修改器是中特殊的键
收藏 0 赞 0 分享

mongodb 数据类型(null/字符串/数字/日期/内嵌文档/数组等)

MongoDB的文档类似于JSON,JSON只是一种简单的表示数据的方式,只包含了6种数据类型(null、布尔、数字、字符串、数组及对象),需要的朋友可以参考下
收藏 0 赞 0 分享

MongoDB的创建、更新和删除

下面开始学习MongoDB最重要也是最基础的部分:C(创建)R(查询)U(更新)D(删除);由于R(查询)操作相对来说内容比较多,也比较繁琐,同时使用频率也比较高,所以下一篇会拿出来单独介绍。废话不多说,连上服务器,我们直接进入正题
收藏 0 赞 0 分享

MongoDB的下载、安装与部署方法

这篇文章主要介绍了MongoDB的下载、安装与部署方法,需要的朋友可以参考下
收藏 0 赞 0 分享

MongoDB的基础知识简介

这篇文章主要介绍了MongoDB的基础知识简介,需要的朋友可以参考下
收藏 0 赞 0 分享

MongoDB的查询方法

这篇文章主要介绍了MongoDB的查询方法,需要的朋友可以参考下
收藏 0 赞 0 分享

MongoDB的索引

数据库中的索引就是用来提高查询操作的性能,但是会影响插入、更新和删除的效率,因为数据库不仅要执行这些操作,还要负责索引的更新
收藏 0 赞 0 分享

MongoDB数据查询方法干货篇

查询操作在我们日常操作数据库的时候是必不可少的一部分,最近有些空闲时间,所有就将MongoDB数据查询的一些方法技巧总结了处理,这篇文章主要介绍了MongoDB数据查询的相关资料,需要的朋友可以参考借鉴,一起来看看吧。
收藏 0 赞 0 分享

MongoDB数据更新方法干货篇

之前给大家分享了MongoDB中数据查询的相关方法和技巧,那么下面这篇文章主要给大家介绍了MongoDB中数据更新方法的相关资料,文中给出了详细的示例代码,需要的朋友可以参考借鉴,下面来一起看看吧。
收藏 0 赞 0 分享
查看更多