2019独角兽企业重金招聘Python工程师标准>>>
mongodb 配置项详解
dbpath
数据文件存放路径,每个数据库会在其中创建一个子目录,用于防止同一个实例多次运, 行的 mongod.lock 也保存在此目录中
logpath
错误日志文件
logappend
错误日志采用追加模式(默认是覆写模式)
bind_ip
对外服务的绑定 ip,一般设置为空,及绑定在本机所有可用 ip 上,如有需要可以单独指定
port
对外服务端口。Web 管理端口在这个 port 的基础上+1000
fork
以后台 Daemon 形式运行服务
journal
开启日志功能,通过保存操作日志来降低单机故障的恢复时间,在 1.8 版本后正式加入,取代在 1.7.5 版本中的 dur 参数。
syncdelay
系统同步刷新磁盘的时间,单位为秒,默认是 60 秒。
directoryperdb
每个 db 存放在单独的目录中,建议设置该参数。与 MySQL 的独立表空间类似
maxConns
最大连接数
repairpath
执行 repair 时的临时目录。在如果没有开启 journal,异常 down 机后重启,必须执行 repair操作。
以下为配置文件(参考):
systemLog:
# verbosity: 0 #日志等级,0-5,默认0
# quiet: false #限制日志输出,
# traceAllExceptions: true #详细错误日志
# syslogFacility: user #记录到操作系统的日志级别,指定的值必须是操作系统支持的,并且要以--syslog启动
path: /Users/mhq/projects/db/mongo/logs/log.txt #日志路径。
logAppend: false #启动时,日志追加在已有日志文件内还是备份旧日志后,创建新文件记录日志, 默认false
logRotate: rename #rename/reopen。rename,重命名旧日志文件,创建新文件记录;reopen,重新打开旧日志记录,需logAppend为true
destination: file #日志输出方式。file/syslog,如果是file,需指定path,默认是输出到标准输出流中
timeStampFormat: iso8601-local #日志日期格式。ctime/iso8601-utc/iso8601-local, 默认iso8601-local
# component: #各组件的日志级别
# accessControl:
# verbosity:
# command:
# verbosity:
processManagement:
fork: true #以守护进程运行 默认false
# pidFilePath: #PID 文件位置
net:
port: 27017 #监听端口,默认27017
bindIp: 127.0.0.1 #绑定监听的ip,deb和rpm包里有默认的配置文件(/etc/mongod.conf)里面默认配置为127.0.0.1,若不限制IP,务必确保认证安全,多个Ip用逗号分隔
maxIncomingConnections: 65536 #最大连接数,可接受的连接数还受限于操作系统配置的最大连接数
wireObjectCheck: true #校验客户端的请求,防止错误的或无效BSON插入,多层文档嵌套的对象会有轻微性能影响,默认true
ipv6: false #是否启用ipv6,3.0以上版本始终开启
unixDomainSocket: #unix socket监听,仅适用于基于unix的系统
enabled: false #默认true
pathPrefix: /tmp #路径前缀,默认/temp
filePermissions: 0700 #文件权限 默认0700
http: #警告 确保生产环境禁用HTTP status接口、REST API以及JSON API以防止数据暴露和漏洞攻击
enabled: false #是否启用HTTP接口、启用会增加网络暴露。3.2版本后停止使用HTTP interface
JSONPEnabled: false #JSONP的HTTP接口
RESTInterfaceEnabled: false #REST API接口
# ssl: #估计用不到,所以没有自己看
# sslOnNormalPorts: # deprecated since 2.6
# mode:
# PEMKeyFile:
# PEMKeyPassword:
# clusterFile:
# clusterPassword:
# CAFile:
# CRLFile:
# allowConnectionsWithoutCertificates:
# allowInvalidCertificates:
# allowInvalidHostnames:
# disabledProtocols:
# FIPSMode:
security:
authorization: enabled # enabled/disabled #开启客户端认证
javascriptEnabled: true #启用或禁用服务器端JavaScript执行
# keyFile: #密钥路径
# clusterAuthMode: #集群认证方式
# enableEncryption:
# encryptionCipherMode:
# encryptionKeyFile:
# kmip:
# keyIdentifier:
# rotateMasterKey:
# serverName:
# port:
# clientCertificateFile:
# clientCertificatePassword:
# serverCAFile:
# sasl:
# hostName:
# serviceName:
# saslauthdSocketPath:
# setParameter: #设置参数
# :
# :
storage:
dbPath: /Users/mhq/projects/db/mongo/test/ #数据库,默认/data/db,如果使用软件包管理安装的查看/etc/mongod.conf
indexBuildRetry: true #重启时,重建不完整的索引
# repairPath: #--repair操作时的临时工作目录,默认为dbPath下的一个_tmp_repairDatabase_的目录
journal:
enabled: true #启动journal,64位系统默认开启,32位默认关闭
# commitIntervalMs: #journal操作的最大时间间隔,默认100或30
directoryPerDB: false #使用单独的目录来存储每个数据库的数据,默认false,如果需要更改,要备份数据,删除掉dbPath下的文件,重建后导入数据
# syncPeriodSecs: 60 #使用fsync来将数据写入磁盘的延迟时间量,建议使用默认值
engine: wiredTiger #存储引擎,mmapv1/wiredTiger/inMemory 默认wiredTiger
# mmapv1:
# preallocDataFiles:
# nsSize:
# quota:
# enforced:
# maxFilesPerDB:
# smallFiles:
# journal:
# debugFlags:
# commitIntervalMs:
# wiredTiger:
# engineConfig:
# cacheSizeGB: #缓存大小
# journalCompressor: #数据压缩格式 none/snappy/zlib
# directoryForIndexes: #将索引和集合存储在单独的子目录下,默认false
# collectionConfig:
# blockCompressor: #集合数据压缩格式
# indexConfig:
# prefixCompression: #启用索引的前缀压缩
# inMemory:
# engineConfig:
# inMemorySizeGB:
operationProfiling: #性能分析
slowOpThresholdMs: 100 #认定为查询速度缓慢的时间阈值,超过该时间的查询即为缓慢查询,会被记录到日志中, 默认100
mode: off #operationProfiling模式 off/slowOp/all 默认off
# replication: #复制集相关
# oplogSizeMB:
# replSetName:
# secondaryIndexPrefetch:
# enableMajorityReadConcern:
# sharding: #集群分片相关
# clusterRole:
# archiveMovedChunks:
# auditLog:
# destination:
# format:
# path:
# filter:
# snmp:
# subagent: #当设置为true,SNMP作为代理运行
# master: #当设置为true,SNMP作为主服务器运行
# basisTech:
# rootDirectory: