一 简介:讲讲如何优化mongo配置文件
二 常规参数
port= //端口
fork=true//守护进程方式启动mongo
logpath=shard.log //mongo日志存放路径
journal= true//redo log开启
nohttpinterface = true //关闭http端口,提高安全性
directoryperdb = true // 每个db会创建一个单独的目录
logappend = true //日志输出模式,当重启后才会触发,默认为false
maxConns= 5000 //最大连接数
slowms=1000 //慢日志记录开启,单位是秒
三 WT引擎优化
engine=wiredTiger//mongo3.2以后都是wt为默认引擎
prefixCompression: true//索引压缩,默认开启
blockCompressor: snappy(zlib,snap,none可选 db压缩)//默认snappy,推荐snappy
journalCompressor:snappy(zlib,snap,none可选 log压缩)//默认snappy,推荐snappy
directoryForIndexes: true//数据和索引文件分离,默认开启
cacheSizeGB=linux memory/2 //默认为系统内存的一半,缓存数据和索引,可以理解成innodb_buffer_pool,推荐默认值,单位G,目的是限制mongo内存的使用
四 集群配置
shardsvr=true//是否开启分片集群
chunkSize=64//单chunk大小,单位MB,默认64,推荐64
oplogSize=10240//oplog大小 单位是MB 建议调大
replSet: rs0//副本集名称
五 验证配置
auth=true//开启认证
keyFile=keyfile//集群认证密钥
六 切换日志
1 默认Mongodb是开启--logRotaterename选项的
2 mongo版本需要大于3.0X
3 执行切换命令
mongo --port admin --quiet --eval "db.runCommand( { logRotate : 1 } )"
七 注意:由于mongo版本更新频繁,所以配置文件参数选项可能有变化,本文只做参考