方法一、通过 Dockerfile 构建
创建Dockerfile
首先,创建目录mongo, 用于存放后面的相关东西。
mkdir -p ~/mongo ~/mongo/db
db目录将映射为mongo容器配置的/data/db目录,作为mongo数据的存储目录
进入创建的mongo目录,创建Dockerfile
FROM debian:wheezy# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get addedRUN groupadd -r mongodb && useradd -r -g mongodb mongodbRUN apt-get update \ && apt-get install -y --no-install-recommends \numactl \ && rm -rf /var/lib/apt/lists/*# grab gosu for easy step-down from rootENV GOSU_VERSION 1.7RUN set -x \&& apt-get update && apt-get install -y --no-install-recommends ca-certificates wget && rm -rf /var/lib/apt/lists/* \&& wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \&& wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \&& export GNUPGHOME="$(mktemp -d)" \&& gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \&& gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \&& rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \&& chmod +x /usr/local/bin/gosu \&& gosu nobody true \&& apt-get purge -y --auto-remove ca-certificates wget# gpg: key 7F0CEB10: public key "Richard Kreuter <richard@10gen.com>" importedRUN apt-key adv --keyserver ha.pool.sks-keyservers.net --recv-keys 492EAFE8CD016A07919F1D2B9ECBEC467F0CEB10ENV MONGO_MAJOR 3.0ENV MONGO_VERSION 3.0.12ENV MONGO_MAJOR 3.0ENV MONGO_VERSION 3.0.12RUN echo "deb http://repo.mongodb.org/apt/debian wheezy/mongodb-org/$MONGO_MAJOR main" > /etc/apt/sources.list.d/mongodb-org.listRUN set -x \&& apt-get update \&& apt-get install -y \mongodb-org=$MONGO_VERSION \mongodb-org-server=$MONGO_VERSION \mongodb-org-shell=$MONGO_VERSION \mongodb-org-mongos=$MONGO_VERSION \mongodb-org-tools=$MONGO_VERSION \&& rm -rf /var/lib/apt/lists/* \&& rm -rf /var/lib/mongodb \&& mv /etc/mongod.conf /etc/mongod.conf.origRUN mkdir -p /data/db /data/configdb \&& chown -R mongodb:mongodb /data/db /data/configdbVOLUME /data/db /data/configdbCOPY docker-entrypoint.sh /entrypoint.shENTRYPOINT ["/entrypoint.sh"]EXPOSE 27017CMD ["mongod"]
通过Dockerfile 创建一个镜像,替换成自己的名字
docker build -t mongo:3.2 .
创建完成后,可在本地的镜像列表中查找到刚刚创建的镜像
docker images mongo:3.2
方法二、docker pull mogo:3.2
查找Docker Hub上的mongo镜像
docker search mongo
这里拉取官方的镜像,标签为3.2
docker pull mongo:3.2
使用mongo镜像
运行容器
docker run -p 27017:27017 -v $PWD/db:/data/db -d mongo:3.2
命令说明:
-p 27017:27017 :将容器的27017 端口映射到主机的27017 端口
-v $PWD/db:/data/db :将主机中当前目录下的db挂载到容器的/data/db,作为mongo数据存储目录
查看容器启动情况
docker ps
使用mongo镜像执行mongo 命令连接到刚启动的容器,主机IP为172.17.0.1
docker run -it mongo:3.2 mongo --host 172.17.0.1
