十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
创新互联公司服务项目包括横峰网站建设、横峰网站制作、横峰网页制作以及横峰网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,横峰网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到横峰省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
1、安装相关软件包
[root@centos-01 ~]# wget -b http://downloads.mongodb.org/linux/mongodb-linux-x86_64-3.6.14.tgz
[root@centos-01 ~]# tar zxvf mongodb-linux-x86_64-3.6.14.tgz
[root@centos-01 ~]# mv mongodb-linux-x86_64-3.6.14 /ust/local/mongodb
2、创建MongoDB的数据存储目录,日志存储目录
[root@centos-01 ~]# mkdir -p /data/mongodb/data
[root@centos-01 ~]# mkdir -p /data/logs/mongodb
[root@centos-01 ~]# ln -s /usr/local/mongodb/bin/* /usr/bin/
3、当MongoDB处于频繁访问的状态时,如果shell启动进程所占用的资源设置过低的话,将会产生错误导致无法连接到MongoDB实例。需设置ulimit -n和ulimit -u的值大于20000。
[root@centos-01 ~]# ulimit -n 25000
[root@centos-01 ~]# ulimit -u 25000
4、创建MongoDB配置文件,定义启动所需相关参数
[root@centos-01 ~]# vim /etc/mongodb.cnf
#系统日志
systemLog:
#日志输出目的地,可以指定为 “file” 或者“syslog”
destination: file
#使用追加的方式写日志
logAppend: true
#日志存储目录
path: /data/logs/mongodb/mongo.log
storage:
#数据存储目录
dbPath: /data/mongodb/data
#是否开启 journal 日志持久存储,journal 日志用来数据恢复,是 mongod 最基础的特性,通常用于故障恢复
journal:
enabled: true
# engine: wiredTiger
# mmapv1:
#如下配置仅对 wiredTiger 引擎生效(3.0 以上版本)
wiredTiger:
engineConfig:
#wiredTiger 缓存工作集(working set)数据的内存大小
cacheSizeGB: 4
#是否将索引和 collections 数据分别存储在 dbPath 单独的目录中
directoryForIndexes: false
collectionConfig:
blockCompressor: zlib
indexConfig:
prefixCompression: false
# how the process runs
processManagement:
#以后台方式运行进程
fork: true
#PID File 的完整路径,如果没有设置,则没有PID文件
pidFilePath: /data/mongodb/mongod.pid
# network interfaces
net:
#默认服务器端口号
port: 27017
#mongodb所绑定的ip地址
bindIp: 127.0.0.1
security:
#表示是否开启用户访问控制
authorization: enabled
#性能分析器
operationProfiling:
#开启慢日志
slowOpThresholdMs: 100
mode: slowOp
#如果架构模式为 replication Set,那么还需要在所有的 “复制集”members 上增加如下配置:
#replication:
# oplogSizeMB: 2048
# replSetName: mongodb
#sharding:
## Enterprise-Only Options
#auditLog:
5、设置内核参数,关闭NUMA
[root@centos-01 ~]# echo 0 >/proc/sys/vm/zone_reclaim_mode //当某个节点可用内存不足时系统会从其他节点分配内存
[root@centos-01 ~]# sysctl -w vm.zone_reclaim_mode=0 //永久设置
6、mongodb启停
[root@centos-01 ~]# mongod -f /etc/mongodb.cnf //启动
[root@centos-01 ~]# mongod -f /etc/mongodb.cnf --shutdown //停止
[root@centos-01 ~]# netstat -anpt | grep mongod
tcp 0 0 127.0.0.1:27017 0.0.0.0:* LISTEN 33475/mongod
7、设置为开机自动启动
[root@centos-01 ~]# echo "mongod -f /etc/mongodb.cnf" >> /etc/rc.local
8、进入MongoDB之后也可以这样关闭mongoDBuse admin; db.shutdownServer();
9、为了便于运维人员管理,编写一个MongoDB数据库的控制脚本
[root@centos-01 ~]# vim /etc/init.d/mongod
#!/bin/bash
PROG="/usr/local/mongodb/bin/mongod"
CONFIG=$1
CONF="/etc/$CONFIG.cnf"
case "$2" in
start)
$PROG -f $CONF
;;
stop)
$PROG -f $CONF --shutdown
;;
restart)
$0 stop
sleep 1
$0 start
sleep 1
echo "mongod has been restarted successfully"
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 2
esac
exit 0
[root@centos-01 ~]# chmod +x /etc/init.d/mongod
[root@centos-01 ~]# chkconfig --add mongod
[root@centos-01 ~]# /etc/init.d/mongod start