当前位置:首页 > linux教程 > 列表

linux中MongoDB数据库详细配置说明

发布:smiling 来源: PHP粉丝网  添加日期:2014-10-11 08:41:22 浏览: 评论:0 

设置noprealloc= true来禁用预分配的数据文件,会缩短启动时间,但在正常操作过程中,可能会导致性能显著下降。

noprealloc = false

noscripting:是否禁止脚本引擎。默认是false:不禁止。ture:禁止

要是设置成true:运行一些脚本的时候会出现:JavaScript execution failed: group command failed: { "ok" : 0, "errmsg" : "server-side JavaScript execution is disabled" }

#noscripting = true     <====> noscripting = false

notablescan:是否禁止表扫描操作。默认false:不禁止,ture:禁止

禁止要是执行表扫描会出现:error: { "$err" : "table scans not allowed:test.emp", "code" : 10111 }

可以动态修改设置:

db.adminCommand({setParameter:1, notablescan:false})

#notablescan = true  <====> notablescan = false

nssize:命名空间的文件(即NS)的默认大小,默认16M,最大2G。

所有新创建的默认大小命名空间的文件(即NS)。此选项不会影响现有的命名空间的文件的大小。默认值是16M字节,最大大小为2 GB。让小数据库不让浪费太多的磁盘空间,同时让大数据在磁盘上有连续的空间。

  1. -rwxrwxrwx 1 mongodb zhoujy  16M  6月 11 14:44 test.0 
  2. -rwxrwxrwx 1 mongodb zhoujy  32M  6月  1 21:36 test.1 
  3. -rwxrwxrwx 1 mongodb zhoujy  16M  6月 11 14:44 test.ns 
  4. drwxr-xr-x 2 root    root   4.0K  6月 10 11:57 _tmp 

nssize  = 16

profile:数据库分析等级设置。记录一些操作性能到标准输出或则指定的logpath的日志文件中,默认0:关闭。

级别 设置

0 关。无分析。

1 开。仅包括慢操作。

2 开。包括所有操作。

控制 Profiling  的开关和级别:2种

第一种是直接在启动参数里直接进行设置或则启动MongoDB时加上–profile=级别,其信息保存在 生成的system.profile 中。

profile = 2

第二种是在客户端用db.setProfilingLevel(级别)命令来实时配置,其信息保存在 生成的system.profile 中。

  1. [initandlisten] creating profile collection: local.system.profile 
  2.  
  3. > db.setProfilingLevel(2) 
  4. "was" : 0, "slowms" : 100, "ok" : 1 } 
  5. > db.getProfilingStatus() 
  6. "was" : 2, "slowms" : 100 } 

默认情况下,mongod的禁用分析。数据库分析可以影响数据库的性能,因为分析器必须记录和处理所有的数据库操作。所以在需要的时候用动态修改就可以了。

slowms:记录profile分析的慢查询的时间,默认是100毫秒。具体同上。

  1. slowms  = 200 
  2. > db.getProfilingStatus() 
  3. "was" : 2, "slowms" : 200 } 

quota:配额,默认false。是否开启配置每个数据库的最多文件数的限制。当为true则用quotaFiles来配置最多文件的数量。

quota = true

quotaFiles:配额数量。每个数据库的数据文件数量的限制。此选项需要quota为true。默认为8。

quotaFiles = 8

rest:默认false,设置为true,使一个简单的 REST API。

rest = true

设置为true,开启后,在MongoDB默认会开启一个HTTP协议的端口提供REST的服务(nohttpinterface = false),这个端口是你Server端口加上1000,即28017,默认的HTTP端口是数据库状态页面,(开启后,web页面的Commands 行中的命令都可以点进去)。mongodb自带的REST,不支持 增、删、改,同时也不支持 权限认证。

repair:修复数据库操作,默认是false。

设置为true时,启动后修复所有数据库,设置这个选项最好在命令行上,而不是在配置文件或控制脚本。如:

命令行修复:

  1. > db.repairDatabase('xxx'
  2. "ok" : 1 } 
  3. > db.repairDatabase() 
  4. "ok" : 1 } 

启动时修复:repair = true

root@m3:/var/log/mongodb# mongod --repair

启动时修复,需要关闭journal,否则报错:

Can't specify both --journal and --repair options.

并且启动时,用控制文件指定参数和配置文件里指定参数的方式进行修复之后,修复信息见log,需要再禁用repair参数才能启用mongodb.

注意:mongod修复时,需要重写所有的数据库文件。如果在同一个帐号下不能运行修复,则需要运行chown修改数据库文件的权限。

repairpath:修复路径,默认是在dbpath路径下的_tmp 目录。

drwxr-xr-x 2 root    root   4.0K  6月 11 20:23 _tmp

smallfiles:是否使用较小的默认文件。默认为false,不使用。

设置为true,使用较小的默认数据文件大小。smallfiles减少数据文件的初始大小,并限制他们到512M,也减少了日志文件的大小,并限制他们到128M。

如果数据库很大,各持有少量的数据,会导致mongodb创建很多文件,会影响性能。

smallfiles = true

syncdelay:刷写数据到日志的频率,通过fsync操作数据。默认60秒。

syncdelay = 60

默认就可以,不需要设置。不会对日志文件(journal files)有影响

警告:如果设置为0,SYNCDELAY 不会同步到磁盘的内存映射文件。在生产系统上,不要设置这个值。

sysinfo:系统信息,默认false。

设置为true,mongod会诊断系统有关的页面大小,数量的物理页面,可用物理页面的数量输出到标准输出。

  1. Tue Jun 11 21:07:15.031 sysinfo: 
  2. Tue Jun 11 21:07:15.035   page size: 4096 
  3. Tue Jun 11 21:07:15.035   _SC_PHYS_PAGES: 256318 
  4. Tue Jun 11 21:07:15.035   _SC_AVPHYS_PAGES: 19895 

当开启sysinfo参数的时候,只会打印上面的信息,不会启动mongodb的程序。所以要关闭该参数,才能开启mongodb。

upgrade:升级。默认为false。

当设置为true,指定DBPATH,升级磁盘上的数据格式的文件到最新版本。会影响数据库操作,更新元数据。大部分情况下,不需要设置该值。

traceExceptions:是否使用内部诊断。默认false。

traceExceptions = false

quiet:安静模式。

quiet = true

setParameter:2.4的新参数,指定启动选项配置。想设置多个选项则用一个setParameter选项指定,setParameter设置在这个文件中,使用下面的格式:

setParameter = <parameter>=<value>

如配置文件里设置syncdelay:

setParameter = syncdelay= 55,notablescan = true,journalCommitInterval = 50,traceExceptions = true

Replication Options  复制选项

replSet:使用此设置来配置复制副本集。指定一个副本集名称作为参数,所有主机都必须有相同的名称作为同一个副本集。

oplogSize:指定的复制操作日志(OPLOG)的最大大小。mongod创建一个OPLOG的大小基于最大可用空间量。对于64位系统,OPLOG通常是5%的可用磁盘空间。

一旦mongod第一次创建OPLOG,改变oplogSize将不会影响OPLOG的大小。

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,则配置当前实例作为主实例。

master = true

slave:默认为false,当设置为true,则配置当前实例作为从实例。

slave = true

source:默认为空,格式为:<:port>。用于从实例的复制:设置从的时候指定该选项会让从复制指定主的实例

source = 127.0.0.1:30001

only:默认为空,用于从选项,指定一个数据库进行复制。

only = abc #只同步abc集合(库)

slavedelay:设置从库同步主库的延迟时间,用于从设置,默认为0。

slavedelay = 60 #延迟60s同步主数据

autoresync:默认为false,用于从设置。是否自动重新同步。设置为true,如果落后主超过10秒,会强制从自动重新同步。如果oplogSize太小,此设置可能有问题。如果OPLOG大小不足以存储主的变化状态和从的状态变化之间的差异,这种情况下强制重新同步是不必要的。当设置autoresync选项设置为false,10分钟内从不会进行大于1次的自动重新同步。

autoresync = false

Tags: MongoDB配置 linux配置说明

分享到: