标签:一个 pair root 网络流量 守护 嵌套 大连 tab options
本文源自:https://www.jianshu.com/p/cc3b14e3621c
启动MongoDB有2种方式
配置如下:
[注]:启动verbose冗长信息,它的级别有 vv~vvvvv,v越多级别越高,在日志文件中记录的信息越详细。
mongo --port=1021
连接]
192.168.200.201
[其他服务器用mongo --host=192.168.200.201
连接] ,可以用一个逗号分隔的列表绑定多个IP地址。
注意:不能设置该值大于20000。
Replica Set Security” and “Replica Set Administration.
unixSocketPrefix:套接字文件路径,默认/tmp
unixSocketPrefix = /tmp
fork:是否后台运行,设置为true 启动 进程在后台运行的守护进程模式。默认false。
开启日志会出现:
/data/db/
Value | Setting |
---|---|
0 | off. No logging. #关闭。没有记录。 |
1 | Log write operations. #写操作 |
2 | Log read operations. #读操作 |
3 | Log both read and write operations. #读写操作 |
7 | Log write and some read operations. #写和一些读操作 |
设置不等于0,日志会每分钟flush 一次:
产生的日志可以用mongosniff来查看:要是mongosniff[类似于tcpdump的作为一个MongoDB的特定的TCP/IP网络流量]出现报错和具体用法,请见这里,之前先执行:apt-get install libpcap-dev
注意:当重新设置成0,会停止写入文件,但mongod还是继续保持打开该文件,即使它不再写入数据文件。如果你想重命名,移动或删除诊断日志,你必须完全关闭mongod实例。
注意:要是在运行一段时间的数据库中,开启该参数,会导致原始的数据都会消失(注释参数则会回来)。因为数据目录都不同了,除非迁移现有的数据文件到directoryperdb产生的数据库目录中,如:
把test数据文件迁移到directoryperdb产生的数据库test目录中。 所以需要在规划好之后确定是否要开启。
原始数据结构:
开启 directoryperdb,并把数据文件迁移到相关的数据目录后的结构:
journal:日志,
默认值:(在64位系统)true。
默认值:(32位系统)false。
设置为true,启用操作日志,以确保写入持久性和数据的一致性,会在dbpath目录下创建journal目录。
设置为false,以防止日志持久性的情况下,并不需要开销。为了减少磁盘上使用的日志的影响,您可以启用nojournal,并设置为true。注意:在64位系统上禁用日志必须使用带有nojournal的。
32位OS:
64位OS:
nojournal:禁止日志默认值:(在64位系统)false。默认值:(32位系统)true。设置nojournal为true关闭日志,64位,2.0版本后的mongodb默认是启用 journal日志。
journalCommitInterval:刷写提交机制,默认是30ms或则100ms。较低的值,会更消耗磁盘的性能。此选项接受2和300毫秒之间的值:
如果单块设备提供日志和数据文件,默认的日记提交时间间隔为100毫秒。
如果不同的块设备提供的日志和数据文件,默认的日记提交的时间间隔为30毫秒。
ipv6:是否支持ipv6,默认false。
jsonp:是否允许JSONP访问通过一个HTTP接口,默认false。
nohttpinterface:是否禁止http接口,即28017 端口开启的服务。默认false,支持。
noprealloc:预分配方式。默认false:使用预分配方式来保证写入性能的稳定,预分配在后台进行,并且每个预分配的文件都用0进行填充。这会让MongoDB始终保持额外的空间和空余的数据文件,从而避免了数据增长过快而带来的分配磁盘空间引起的阻塞。
设置noprealloc= true
来禁用预分配的数据文件,会缩短启动时间,但在正常操作过程中,可能会导致性能显著下降。
noscripting:是否禁止脚本引擎。默认是false:不禁止。ture:禁止要是设置成true:运行一些脚本的时候会出现:
notablescan:是否禁止表扫描操作。默认false:不禁止,ture:禁止禁止要是执行表扫描会出现:
可以动态修改设置:
nssize:命名空间的文件(即NS)的默认大小,默认16M,最大2G。所有新创建的默认大小命名空间的文件(即NS)。此选项不会影响现有的命名空间的文件的大小。默认值是16M字节,最大大小为2 GB。让小数据库不让浪费太多的磁盘空间,同时让大数据在磁盘上有连续的空间。
profile:数据库分析等级设置。记录一些操作性能到标准输出或则指定的logpath的日志文件中,默认0:关闭。
级别 | 设置 |
---|---|
0 关 | 无分析。 |
1 开 | 仅包括慢操作。 |
2 开 | 包括所有操作。 |
控制 Profi[ling]的开关和级别:2种
第一种是直接在启动参数里直接进行设置或则启动MongoDB时加上–profile=级别,其信息保存在 生成的system.profile 中。
第二种是在客户端用db.setProfilingLevel(级别)命令来实时配置,其信息保存在 生成的system.profile 中。
默认情况下,mongod的禁用分析。数据库分析可以影响数据库的性能,因为分析器必须记录和处理所有的数据库操作。所以在需要的时候用动态修改就可以了。
slowms:记录profile分析的慢查询的时间,默认是100毫秒。具体同上。
quota:配额,默认false。是否开启配置每个数据库的最多文件数的限制。当为true则用quotaFiles来配置最多文件的数量。
quotaFiles:配额数量。每个数据库的数据文件数量的限制。此选项需要quota为true。默认为8。
rest: 默认false,设置为true,使一个简单的 REST API。
设置为true,开启后,在MongoDB默认会开启一个HTTP协议的端口提供REST的服务(nohttpinterface = false
),这个端口是你Server端口加上1000,即28017,默认的HTTP端口是数据库状态页面,(开启后,web页面的Commands 行中的命令都可以点进去)。mongodb自带的REST,不支持 增、删、改,同时也不支持 权限认证。
repair:修复数据库操作,默认是false。
设置为true时,启动后修复所有数据库,设置这个选项最好在命令行上,而不是在配置文件或控制脚本。如:
命令行修复:
repair = true
root@m3:/var/log/mongodb# mongod --repair
Can‘t specify both --journal and --repair options.
drwxr-xr-x 2 root root 4.0K 6月 11 20:23 _tmp
smallfiles = true
syncdelay = 60
Tue Jun 11 21:07:15.031 sysinfo:
Tue Jun 11 21:07:15.035 page size: 4096
Tue Jun 11 21:07:15.035 _SC_PHYS_PAGES: 256318
Tue Jun 11 21:07:15.035 _SC_AVPHYS_PAGES: 19895
traceExceptions = false
quiet = true
setParameter = <parameter>=<value>
setParameter = syncdelay= 55,notablescan = true,journalCommitInterval = 50,traceExceptions = true
master = true
slave = true
source = 127.0.0.1:30001
only = abc #只同步abc集合(库)
1.slavedelay = 60 #延迟60s同步主数据
autoresync = false
作者:iMichael_Zhang
链接:https://www.jianshu.com/p/cc3b14e3621c
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
标签:一个 pair root 网络流量 守护 嵌套 大连 tab options
原文地址:https://www.cnblogs.com/lhdz_bj/p/12214993.html