说明
-
Docker运行
1.1 启动容器时可使用启动时加参数 -m 1g 来限制容器内存;或者参考docker hub中简介使用wiredTigerCacheSizeGB参数启动:
docker run --name some-mongo -d mongo --wiredTigerCacheSizeGB 1.5
1.2 运行中的容器可使用 docker update -m 1g name 来更新容器使用内存(如果容器在运行中设置小于运行时内存可能会失败,可以停止容器后设置内存再启动容器)
-
本地运行则修改MongoDB配置文件
存储引擎类型,mongodb 3.0 之后支持 “mmapv1”、“wiredTiger” 两种引擎,默认值为“mmapv1”;官方宣称 wiredTiger 引擎更加优秀。
MongoDB的内存限制参数配置:
3.X: /etc/mongod.conf
4.X: /etc/mongod.conf.orig
操作如下:
将容器内的复制出来,修改后再复制进去。
docker cp shardsvr:/etc/mongod.conf.orig /home/yyt/mongodb/
docker cp /home/yyt/mongodb/mongod.conf.orig shardsvr:/etc/mongod.conf.orig
修改的配置(wiredTiger优于mmapv1)。
engine:
### mmapv1:
#注意空格格式
wiredTiger:
engineConfig:
cacheSizeGB: 5
如果是以进程的方式启动,此时mongodb 占用内存很高怎么办呢?
可以执行以下两条命令:
sync
echo 3 > /proc/sys/vm/drop_caches
然后使用free -m 即可以看到内存下来了