用 docker 起 mongo,有两种限制方式:
- 通过 Docker 限制内存
- 通过 MongoDB 自己的配置文件限制
一、通过 Docker 限制内存
内存限制相关参数:
参数 | 简介 |
---|---|
-m, –memory | 内存限制,格式:数字+单位,单位可以是b, k, m, g,最小4M |
– -memory-swap | 存和交换空间总大小限制,注意:必须比-m参数大,-1 表示不受限 |
例子:
docker run -m 100M --memory-swap -1 mongo:5.0
二、通过 mongo 配置文件限制
配置文件位置:
3.x : /etc/mongod.conf
4.x : /etc/mongod.conf.orig
默认配置:
storage:
# mongod 进程存储数据目录,此配置仅对 mongod 进程有效
dbPath: /data/mongodb/db
是否开启 journal 日志持久存储,journal 日志用来数据恢复,是 mongod 最基础的特性,通常用于故障恢复。64 位系统默认为 true,32 位默认为 false,建议开启,仅对 mongod 进程有效。
journal:
enabled: true
# 存储引擎类型,mongodb 3.0 之后支持 “mmapv1”、“wiredTiger” 两种引擎,默认值为“mmapv1”;官方宣称 wiredTiger 引擎更加优秀。
engine: mmapv1
systemLog:
# 日志输出目的地,可以指定为 “file” 或者“syslog”,表述输出到日志文件,如果不指定,则会输出到标准输出中(standard output)
destination: file
# 如果为 true,当 mongod/mongos 重启后,将在现有日志的尾部继续添加日志。否则,将会备份当前日志文件,然后创建一个新的日志文件;默认为 false。
logAppend: true
# 日志路径
path: /var/log/mongodb/mongod.log
net:
# 指定端口
port: 27017
# 绑定外网 op 多个用逗号分隔
bindIp: 0.0.0.0
maxIncomingConnections: 10000
限制内存、使用 wiredTiger 引擎后配置:
# mongod.conf
# for documentation of all options, see:
# http://docs.mongodb.org/manual/reference/configuration-options/
# Where and how to store data.
storage:
dbPath: /data/db
journal:
enabled: true
engine: wiredTiger
wiredTiger:
engineConfig:
# 限制 5GB 内存大小
cacheSizeGB: 5
# where to write logging data.
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/mongod.log
# network interfaces
net:
port: 27017
bindIp: 0.0.0.0
maxIncomingConnections: 10000
# how the process runs
processManagement:
timeZoneInfo: /usr/share/zoneinfo
三、用 docker-compose 启动
docker-comopose 文件内容:
version: '2'
services:
mongo:
image: "mongo:5.0"
container_name: "mongo-v5"
restart: always
mem_limit: 6G
environment:
MONGO_INITDB_ROOT_USERNAME: admin
MONGO_INITDB_ROOT_PASSWORD: xxxxxx
ports:
- 27017:27017
volumes:
- ./db:/data/db
- ./logs:/var/log/mongodb
- ./mongod.conf.orig:/etc/mongod.conf.orig
command: mongod --auth
mongo-express:
image: "mongo-express:0.54"
container_name: "mongo-express"
links:
- mongo
depends_on:
- mongo
ports:
- 8081:8081
environment:
ME_CONFIG_BASICAUTH_USERNAME: admin
ME_CONFIG_BASICAUTH_PASSWORD: xxxxxx
ME_CONFIG_MONGODB_ADMINUSERNAME: admin
ME_CONFIG_MONGODB_ADMINPASSWORD: xxxxxx
做了 volume 映射,./db:/data/db
保证容器删了数据不会丢失,./mongod.conf.orig
记得放到该 docker-compose.yam
同目录。./logs
查看 MongoDB 日志。另外起了 mongo-express
容器方便查看数据。
至此,完。