1.下载安装包
将解压到/usr/local/mongodb 文件夹下
# mkdir /usr/local/mongodb
# tar zxvf mongodb-linux-x86_64-3.2.9.tgz -C /usr/local/mongodb
2.安装准备
创建数据库文件与日志文件、配置文件:
# mkdir -p data/db
# mkdir -p data/log
# touch data/log/mongod.log
# touch mongod.conf
mongod.conf配置文件如下:
#启用日志文件,默认启用
journal=true
#这个选项可以过滤掉一些无用的日志信息,若需要调试使用请设置为false
quiet=false
dbpath=/usr/local/mongodb/data/db
logpath=/usr/local/mongodb/data/log/mongod.log
logappend=true
# 端口号默认27019,这里只是为了防止冲突
port=27019
# 是否以守护进程方式运行
fork=true
# 是否以安全认证方式运行,默认是不认证的非安全方式
#auth = true
#noauth = true
# 详细记录输出
#verbose = true
# Inspect all client data for validity on receipt (useful for
# developing drivers)用于开发驱动程序时验证客户端请求
#objcheck = true
# Enable db quota management
# 启用数据库配额管理
#quota = true
# 设置oplog记录等级
# Set oplogging level where n is
# 0=off (default)
# 1=W
# 2=R
# 3=both
# 7=W+some reads
#diaglog=0
# Diagnostic/debugging option 动态调试项
#nocursors = true
# Ignore query hints 忽略查询提示
#nohints = true
# 禁用http界面,默认为localhost:28017
#nohttpinterface = true
# 关闭服务器端脚本,这将极大的限制功能
# Turns off server-side scripting. This will result in greatly limited
# functionality
#noscripting = true
# 关闭扫描表,任何查询将会是扫描失败
# Turns off table scans. Any query that would do a table scan fails.
#notablescan = true
# 关闭数据文件预分配
# Disable data file preallocation.
#noprealloc = true
# 为新数据库指定.ns文件的大小,单位:MB
# Specify .ns file size for new databases.
# nssize =
# Replication Options 复制选项
# in replicated mongo databases, specify the replica set name here
#replSet=setname
# maximum size in megabytes for replication operation log
#oplogSize=1024
# path to a key file storing authentication info for connections
# between replica set members
#指定存储身份验证信息的密钥文件的路径
#keyFile=/path/to/keyfile
3.启动mongodb
- 配置启动:
# cd bin
# ./mongod -config ../mongod.conf
- 参数启动
# ./mongod --dbpath=/usr/local/mongodb/data/db --logpath=/usr/local/mongodb/data/log/mongodb.log --logappend -port=27019 --fork
注:如果加权限就用 –auth 参数,不需要权限就去掉
- 系统服务启动:
# service mongod srart|stop|restart
将mongod服务添加为系统服务
1.创建文件
linux系统服务启动文件都存放在 /etc/init.d/ 下面,service mongod start 这样的命令是通过运行该目录下的脚本实现管理的,所以需要创建一个脚本文件mongod并修改读写权限
# cd /etc/init.d
# touch mongod
# chmod 755 mongod
另外还需要用到一个文件来保存服务pid,service mongod stop 命令就是通过这个文件读取服务pid的,可以建立在MongoDB的安装目录下面,
# cd /usr/local/mongodb/
# touch mongod.pid
# chmod 755 mongod.pid
2.编写mongod脚本,以下为脚本实例:
##-----------------------------------------
#!/bin/bash
#chkconfig:35 23 34
#description: MongoDB service
#set -x
if [ -f /etc/init.d/functions ] ; then
##载入functions,. 在这里相当于source的功能
. /etc/init.d/functions
fi
##服务名,会多处调用
prog=mongod
##状态返回值,functions 函数会调用这个值
RETVAL=0
mongod=/usr/local/mongodb/bin/mongod
MONGODB_CONF_FILE=/usr/local/mongodb/mongod.conf
lockfile=/var/lock/subsys/${prog} ##subsys目录下的文件是用于给其他程序判断服务的实例运行状态的
pidfile=/usr/local/mongodb/mongod.pid
start() {
echo -n $"Starting $prog: "
daemon $mongod --config $MONGODB_CONF_FILE ##daemon调用后面的命令执行情况
pgrep mongod>${pidfile} ##写入pid到pidfile
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch ${lockfile}
return $RETVAL
}
stop () {
echo -n $"Stopping $prog: "
killproc -p ${pidfile} ##killproc 从pidfile 获取到pid,并杀死
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && /bin/rm -f ${lockfile}
return $RETVAL
}
case $1 in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|restart}"
exit 2
;;
esac
exit $?
##-----------------------------------------
通过这个脚本可以实现系统服务启动、关闭、重启mongod服务了,然后我们可以让他开机启动:
# chkconfig mongod on
注:可以将mongodb临时加入系统路径变量中,这样可以不用输入路径直接启动,代码如下:
# export PATH=/usr/local/mongodb/bin:$PATH
然后查看是否成功:
# echo $PATH
- 配置参数解释:
–dbpath 数据库路径(数据文件)
–logpath 日志文件路径
–master 指定为主机器
–slave 指定为从机器
–source 指定主机器的IP地址
–pologSize 指定日志文件大小不超过64M.因为resync是非常操作量大且耗时,最好通过设置一个足够大的oplogSize来避免resync(默认的 oplog大小是空闲磁盘大小的5%)。
–logappend 日志文件末尾添加
–port 启用端口号
–fork 在后台运行
–only 指定只复制哪一个数据库
–slavedelay 指从复制检测的时间间隔
–auth 是否需要验证权限登录(用户名和密码)
–config 配置文件位置
用户授权和管理
//TODO
由于博主还未正常配置,所以。。。下次更新啦。。。