本文主要介绍的是关于Mongodb参数说明与常见错误处理的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:
一、在 CentOS7 上安装 MongoDB
1 通过 SecureCRT 连接至 CentOS7 服务器;
2 进入到 /usr/local/ 目录:
1
|
cd /usr/local |
3 在当前目录下创建 tools 目录:
1
|
mkdir -p tools |
4 进入到 tools 目录中:
1
|
cd tools |
5 下载与 CentOS 系统匹配的 mongodb-linux-x86_64-rhel70-3.2.4.tgz 文件:
1
|
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 文件:
1
|
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:
1
|
mv mongodb-linux-x86_64-rhel70-3.2.4 mongodb3.2.4 |
8 返回到上一级目录,并创建 mongodb 目录:
1
2
|
cd ../ mkdir -p mongodb |
9 将 mongodb3.2.4 文件从 /usr/local/tools 目录中移动到 /usr/local/mongodb 目录中:
1
|
mv tools /mongodb3 .2.4/ mongodb/ |
10 进入到 /usr/local/mongodb/mongodb3.2.4 目录中:
1
|
cd mongodb /mongodb3 .2.4 |
11 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放日志的目录:
1
|
mkdir -p data /test/logs |
12 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中创建一个存放数据文件的目录:
1
|
mkdir -p data /test/db |
13 进入 bin 目录中:
1
|
cd bin/ |
14 创建配置文件 mongodb.conf:
1
|
vi mongodb.conf |
在 mongodb.conf 写入如下内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
# 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 配置文件方式启动:
1
|
. /mongod --config mongodb.conf |
15.2 以修复模式启动 mongodb:
1
|
. /mongod --repair -f mongodb.conf |
15.3 以参数式启动:
1
|
. /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 |
如果报如下错误:
1
|
ERROR: child process failed, exited with error number 1 |
很可能是 mongodb.conf 中配置的路径不一致问题;
如果报如下错误:
1
|
ERROR: child process failed, exited with error number 100 |
很可能是没有正常关闭导致的,那么可以删除 mongod.lock 文件
15 查看 mongodb 进程:
1
|
ps aux | grep mongodb |
16 查看 mongodb 服务的运行日志:
1
|
tail -200f /usr/local/mongodb/mongodb3 .2.4 /bin/data/test/logs/mongodb .log |
17 检查端口是否已被启动:
1
|
netstat -lanp | grep 27017 |
18 杀死 mongodb 进程,即可关闭 mongodb 服务:
1
|
kill -15 PID |
PID 可以通过步骤 16 查看到
19 如果出现如下情况
1
|
warning: Failed to connect to 127.0.0.1:27017, reason: errno:111 Connection refused |
可以采用如下两种方式解决:
19.1 若数据库出现如上不能连接的原因,可能是data目录下的mongod.lock文件问题,可以用如下命令修复:
1
|
. /bin/mongod --repair |
19.2 或者直接删除mongod.lock
1
|
rm -f /usr/local/mongodb/data/db/mongod .lock |
然后再启动 mongodb 服务:
1
|
. /mongod --config mongodb.conf |
如果以上两部依然解决不掉,则是路径文件,我们可以删除 /usr/local/mongodb/mongodb3.2.4/bin/data 目录及其子目录,并采用绝对路径的方式:
1
|
. /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 服务加入到自启动文件中:
1
|
vi /etc/rc . local |
在文件末尾追加如下命令:
1
|
/usr/local/mongodb/mongodb3 .2.4 /bin/mongod --config mongodb.conf |
保存并退出:
1
|
:wq! |
21 客户端常用命令:
1
2
|
db.version(); # 查看 mongodb 的版本 use test ; # 进入到指定的数据中,这里是 test 数据库 |
22 在 /usr/local/mongodb/mongodb3.2.4/bin/ 目录中,键入如下命令,打开一个 mongodb 的客户端程序,即打开一个 mongodb 的 shell 客户端,这个 shell 客户端同时也是一个 JavaScript 编辑器,即可用输入任何的 JavaScript 脚本:
1
|
. /mongo |
默认连接至 test 数据库
23 在浏览器中输入 IP:27017,如:
http://101.201.212.129:27017/
可以查看 MongoDB 的版本信息;
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.cnblogs.com/hanson1/p/7113560.html