启动MongoDB有2种方式,一是直接指定配置参数,二是指定配置文件。这里先介绍配置文件,启动方式如下: 1.mongod –config /etc/mongodb.conf 配置如下: verbose:日志信息冗余。默认false。提高内部报告标准输出或记录到logpath配置的日志文件中。要启用verbose或启用verbosity 用vvvv参数,如:
1.verbose = true ps:启动verbose冗长信息,它的级别有 vv~vvvvv,v越多级别越高,在日志文件中记录的信息越详细。 port:端口。默认27017,MongoDB的默认服务TCP端口,监听客户端连接。要是端口设置小于1024,比如1021,则需要root权限启动,不能用mongodb帐号启动,(普通帐号即使是27017也起不来)否则报错:[mongo –port=1021 连接] 1.ERROR: listen(): bind() failed errno:13 Permission denied for socket: 127.0.0.1:1021 1.port = 27017 bind_ip:绑定地址。默认127.0.0.1,只能通过本地连接。进程绑定和监听来自这个地址上的应用连接。要是需要给其他服务器连接,则需要注释掉这个或则把IP改成本机地址,如192.168.200.201[其他服务器用 mongo –host=192.168.200.201 连接] ,可以用一个逗号分隔的列表绑定多个IP地址。 1.bind_ip = 127.0.0.1 maxConns:最大连接数。默认值:取决于系统(即的ulimit和文件描述符)限制。MongoDB中不会限制其自身的连接。当设置大于系统的限制,则无效,以系统限制为准。这对于客户端创建很多“表”,允许连接超时而不关闭“表”的时候很有用。设置该值的高于连接池和总连接数的大小,以防止尖峰时候的连接。注意:不能设置该值大于20000。 1.maxConns = 100 objcheck:强制验证客户端请求。2.4的默认设置为objcheck成为true,在早期版本objcheck默认为false。因为它强制验证客户端请求,确保客户端绝不插入无效文件到数据库中。对于嵌套文档的对象,会有一点性能影响。设置noobjcheck 关闭。
1.objcheck = true noobjcheck:同上,默认关闭false。 1.#noobjcheck = false logpath:指定日志文件,该文件将保存所有的日志记录、诊断信息。除非另有指定,mongod将所有的日志信息输出到标准输出。如果没有指定logappend,重启则日志会进行覆盖操作。 1.logpath=/var/log/mongodb/mongodb.log logappend:写日志的模式:设置为true为追加。默认是覆盖。如果未指定此设置,启动时MongoDB的将覆盖现有的日志文件。 1.logappend=true syslog:日志输出都发送到主机的syslog系统,而不是标准输出到logpath指定日志文件。syslog和logpath不能一起用,会报错: 1.Cant use both a logpath and syslog 1.syslog = true pidfilepath:进程ID,没有指定则启动时候就没有PID文件。默认缺省。 1.pidfilepath = /var/run/mongo.pid keyFile:指定存储身份验证信息的密钥文件的路径。默认缺省。详情见:” word-spacing: 0px; display: inline; white-space: normal; orphans: 2; widows: 2; font-size-adjust: none; font-stretch: normal; background-color: #ffffff; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;”>Replica Set Security” and “Replica Set Administration.” 1.keyFile = /srv/mongodb/keyfile nounixsocket:套接字文件,默认为false,有生成socket文件。当设置为true时,不会生成socket文件。 1.nounixsocket = false unixSocketPrefix:套接字文件路径,默认/tmp 1.unixSocketPrefix = /tmp fork:是否后台运行,设置为true 启动 进程在后台运行的守护进程模式。默认false。 1.fork = true auth:用户认证,默认false。不需要认证。当设置为true时候,进入数据库需要auth验证,当数据库里没有用户,则不需要验证也可以操作。直到创建了第一个用户,之后操作都需要验证。 1.auth = true 比如:通过db.addUser(‘sa’,’sa’) 在admin库下面创建一个超级用户,只能在在admin库下面先认证完毕了:ab.auth(‘sa’,’sa’) ,才能去别的库操作,不能在其他库验证。这样连接数据库也需要指定库: 1.mongo -usa -psa admin #sa 帐号连接admin 1.mongo -uaa -paa test #aa 帐号连接test noauth:禁止用户认证,默认true。同上 1.noauth = true cpu:设置为true会强制mongodb每4s报告cpu利用率和io等待,把日志信息写到标准输出或日志文件。默认为false。 1.cpu = true 开启日志会出现: 1.Mon Jun 10 10:21:42.241 [snapshotthread] cpu: elapsed:4000 writelock: 0% dbpath:数据存放目录。默认: word-spacing: 0px; white-space: normal; orphans: 2; widows: 2; font-size-adjust: none; font-stretch: normal; background-color: #ffffff; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px;”>/data/db/ 1.dbpath=/var/lib/mongodb diaglog:创建一个非常详细的故障排除和各种错误的诊断日志记录。默认0。设置为1,为在dbpath目录里生成一个diaglog.开头的日志文件,他的值如下:
1.Value Setting 设置不等于0,日志会每分钟flush 一次:
1.Mon Jun 10 11:16:17.504 [DataFileSync] flushing diag log 产生的日志可以用mongosniff 来查看:要是mongosniff[类似于tcpdump的作为一个MongoDB的特定的TCP/ IP网络流量]出现报错和具体用法,请见这里,之前先执行:apt-get install libpcap-dev 1.root@m3:/var/lib/mongodb# mongosniff –source DIAGLOG diaglog.51b542a9 注意:当重新设置成0,会停止写入文件,但mongod还是继续保持打开该文件,即使它不再写入数据文件。如果你想重命名,移动或删除诊断日志,你必须完全关闭mongod实例。 1.diaglog = 3
directoryperdb:设置为true,修改数据目录存储模式,每个数据库的文件存储在DBPATH指定目录的不同的文件夹中。使用此选项,可以配置的MongoDB将数据存储在不同的磁盘设备上,以提高写入吞吐量或磁盘容量。默认为false。 1.directoryperdb = ture
01.原始数据结构:
journal:日志,(redo log,更多的介绍请看这里和这里)
1.#journal=true 32位OS:
1.Tue Jun 11 12:17:09.628 [initandlisten] ** NOTE: This is a 32 bit MongoDB binary. 64位OS:
1.Tue Jun 11 12:29:34 [initandlisten] journal dir=/var/lib/mongodb/journal
nojournal:禁止日志 1.nojournal=true
journalCommitInterval:刷写提交机制,默认是30ms或则100ms。较低的值,会更消耗磁盘的性能。 1.journalCommitInterval=100 ipv6:是否支持ipv6,默认false。 jsonp:是否允许JSONP访问通过一个HTTP接口,默认false。 nohttpinterface:是否禁止http接口,即28017 端口开启的服务。默认false,支持。 1.nohttpinterface = false
noprealloc:预分配方式。 1.noprealloc = false
noscripting:是否禁止脚本引擎。默认是false:不禁止。ture:禁止 1.JavaScript execution failed: group command failed: { “ok” : 0, “errmsg” : “server-side JavaScript execution is disabled” } 1.#noscripting = true <====> noscripting = false notablescan:是否禁止表扫描操作。默认false:不禁止,ture:禁止 禁止要是执行表扫描会出现: 1.error: { “$err” : “table scans not allowed:test.emp”, “code” : 10111 } 可以动态修改设置: 1.db.adminCommand({setParameter:1, notablescan:false}) 1.#notablescan = true <====> notablescan = false
nssize:命名空间的文件(即NS)的默认大小,默认16M,最大2G。
1.-rwxrwxrwx 1 mongodb zhoujy 16M 6月 11 14:44 test.0 1.nssize = 16 profile:数据库分析等级设置。记录一些操作性能到标准输出或则指定的logpath的日志文件中,默认0:关闭。
1.级别 设置
控制 Profiling 的开关和级别:2种 1.profile = 2 第二种是在客户端用db.setProfilingLevel(级别)命令来实时配置,其信息保存在 生成的system.profile 中。 1.[initandlisten] creating profile collection: local.system.profile
1.> db.setProfilingLevel(2) 默认情况下,mongod的禁用分析。数据库分析可以影响数据库的性能,因为分析器必须记录和处理所有的数据库操作。所以在需要的时候用动态修改就可以了。 slowms:记录profile分析的慢查询的时间,默认是100毫秒。具体同上。 1.slowms = 200
1.> db.getProfilingStatus() quota:配额,默认false。是否开启配置每个数据库的最多文件数的限制。当为true则用quotaFiles来配置最多文件的数量。 1.quota = true quotaFiles:配额数量。每个数据库的数据文件数量的限制。此选项需要quota为true。默认为8。 1.quotaFiles = 8 rest: 默认false,设置为true,使一个简单的 REST API。 1.rest = true
设置为true,开启后,在MongoDB默认会开启一个HTTP协议的端口提供REST的服务(nohttpinterface = false),这个端口是你Server端口加上1000,即28017,默认的HTTP端口是数据库状态页面,(开启后,web页面的Commands 行中的命令都可以点进去)。mongodb自带的REST,不支持 增、删、改,同时也不支持 权限认证。
1.> db.repairDatabase(‘xxx’) 启动时修复: 1.repair = true 1.root@m3:/var/log/mongodb# mongod –repair 启动时修复,需要关闭journal,否则报错: 1.Can’t specify both –journal and –repair options.
并且启动时,用控制文件指定参数和配置文件里指定参数的方式进行修复之后,(修复信息见log),需要再禁用repair参数才能启用mongodb。 repairpath:修复路径,默认是在dbpath路径下的_tmp 目录。 1.drwxr-xr-x 2 root root 4.0K 6月 11 20:23 _tmp
smallfiles:是否使用较小的默认文件。默认为false,不使用。 1.smallfiles = true syncdelay:刷写数据到日志的频率,通过fsync操作数据。默认60秒。 1.syncdelay = 60 默认就可以,不需要设置。不会对日志文件(journal files)有影响 警告:如果设置为0,SYNCDELAY 不会同步到磁盘的内存映射文件。在生产系统上,不要设置这个值。 sysinfo:系统信息,默认false。 设置为true,mongod会诊断系统有关的页面大小,数量的物理页面,可用物理??页面的数量输出到标准输出。
1.Tue Jun 11 21:07:15.031 sysinfo: 当开启sysinfo参数的时候,只会打印上面的信息,不会启动mongodb的程序。所以要关闭该参数,才能开启mongodb。
upgrade:升级。默认为false。 traceExceptions:是否使用内部诊断。默认false。 1.traceExceptions = false quiet:安静模式。 1.quiet = true
setParameter:2.4的新参数,指定启动选项配置。想设置多个选项则用一个setParameter选项指定,可以setParameter的参数请见这里,详情请见这里 1.setParameter = <parameter>=<value> 如配置文件里设置syncdelay:
1.setParameter = syncdelay= 55,notablescan = true,journalCommitInterval = 50,traceExceptions = true replSet:使用此设置来配置复制副本集。指定一个副本集名称作为参数,所有主机都必须有相同的名称作为同一个副本集。
oplogSize:指定的复制操作日志(OPLOG)的最大大小。mongod创建一个OPLOG的大小基于最大可用空间量。对于64位系统,OPLOG通常是5%的可用磁盘空间。 fastsync:默认为false。在副本集下,设置为true,从一个dbpath里启用从库复制服务,该dbpath的数据库是主库的快照,可用于快速启用同步,否则的mongod将尝试执行初始同步。注意:如果数据不完全同步,mongod指定fastsync开启,secondary或slave与主永久不同步,这可能会导致显着的一致性问题。 replIndexPrefetch:2.2版本出现的新参数,默认是all。可以设置的值有:all, none, and _id_only。只能在副本集(replSet)中使用。默认情况下,secondary副本集的成员将加载所有索引到内存中(从OPLOG之前的操作有关的)。您可以修改此行为,使secondary只会加载_id索引。指定_id_或none,防止mongod的任何索引加载到内存。 Master/Slave Replication:主从复制的相关设置 master:默认为false,当设置为true,则配置当前实例作为主实例。 1.master = true slave:默认为false,当设置为true,则配置当前实例作为从实例。 1.slave = true source:默认为空,格式为:<host><:port>。用于从实例的复制:设置从的时候指定该选项会让从复制指定主的实例 1.source = 127.0.0.1:30001 only:默认为空,用于从选项,指定一个数据库进行复制。 1.only = abc #只同步abc集合(库) slavedelay:设置从库同步主库的延迟时间,用于从设置,默认为0。 1.slavedelay = 60 #延迟60s同步主数据 autoresync:默认为false,用于从设置。是否自动重新同步。设置为true,如果落后主超过10秒,会强制从自动重新同步。如果oplogSize太小,此设置可能有问题。如果OPLOG大小不足以存储主的变化状态和从的状态变化之间的差异,这种情况下强制重新同步是不必要的。当设置autoresync选项设置为false,10分钟内从不会进行大于1次的自动重新同步。 1.autoresync = false (责任编辑:IT) |