内存限制

说明

  1. 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 来更新容器使用内存(如果容器在运行中设置小于运行时内存可能会失败,可以停止容器后设置内存再启动容器)

  1. 本地运行则修改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 即可以看到内存下来了

重点参考:

MongoDB内存占用过高问题解决方案

限制mongodb内存占用过高方法

MongoDB 的内存使用限制

你可能感兴趣的:(性能优化,服务器)