简介
本文我们准备学习如何构建MongoDB Docker镜像。以及如何推送镜像到Docker Hub registr和与其他人共享。
使用docker和容器部署mongodb实例有几个好处:
易于维护,高度可配置的MongoDB实例
毫秒级运行和启动
可共享镜像
创建MongoDB Dockerfile
我们来创建Dockerfile并开始构建它:
以下说明的可选的,不过在Dockerfile开头添加注释可以说明它的目的:
- # Dockerizing MongoDB: Dockerfile for building MongoDB images
- # Based on ubuntu:latest, installs MongoDB following the instructions from:
- # http://docs.mongodb.org/manual/tutorial/install-mongodb-on-ubuntu/
我们使用从Docker Hub最新的Ubuntu版本来构建镜像。
- # Format: FROM repository[:version]
- FROM ubuntu:latest
然后声明此Dockerfile的维护者:
- # Format: MAINTAINER Name <email@addr.ess>
- MAINTAINER M.Y. Name <myname@addr.ess>
导入MongoDB公共GPG密钥。然后创建一个MongoDB仓库文件。
- # Installation:
- # Import MongoDB public GPG key AND create a MongoDB list file
- RUN apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10
- RUN echo "deb http://repo.mongodb.org/apt/ubuntu "$(lsb_release -sc)"/mongodb-org/3.0 multiverse" | tee /etc/apt/sources.list.d/mongodb-org-3.0.list
完成这些初始准备后我们就可以更新软件包并安装MongoDB。
- # Update apt-get sources AND install MongoDB
- RUN apt-get update && apt-get install -y mongodb-org
MongoDB需要一个数据目录。
- # Create the MongoDB data directory
- RUN mkdir -p /data/db
最后设置ENTRYPOINT来让docker从镜像运行一个容器时执行这个ENTRYPOINT。对于端口,使用EXPOSE暴露。
- # Expose port 27017 from the container to the host
- EXPOSE 27017
-
- # Set usr/bin/mongod as the dockerized entry-point application
- ENTRYPOINT ["/usr/bin/mongod"]
构建MongoDB Docker镜像
开始构建镜像。
- # Format: docker build --tag/-t <user-name>/<repository> .
- # Example:
- $ docker build --tag my/repo .
推送MongoDB镜像到Docker Hub
首先登录到docker hub。
- # Log-in
- $ docker login
-
- Username:
- ..
开始推送:
- # Push the image
- # Format: docker push <user-name>/<repository>
- $ docker push my/repo
-
- The push refers to a repository [my/repo] (len: 1)
- Sending image list
- Pushing repository my/repo (1 tags)
- ..
使用MongoDB镜像
使用刚构建好的MongoDB镜像,我们可以运行一个或多个MongoDB实例。
- # Basic way
- # Usage: docker run --name <name for container> -d <user-name>/<repository>
- $ docker run -p 27017:27017 --name mongo_instance_001 -d my/repo
-
- # Dockerized MongoDB, lean and mean!
- # Usage: docker run --name <name for container> -d <user-name>/<repository> --noprealloc --smallfiles
- $ docker run -p 27017:27017 --name mongo_instance_001 -d my/repo --smallfiles
-
- # Checking out the logs of a MongoDB container
- # Usage: docker logs <name for container>
- $ docker logs mongo_instance_001
-
- # Playing with MongoDB
- # Usage: mongo --port <port you get from `docker ps`>
- $ mongo --port 27017
-
- # If using docker-machine
- # Usage: mongo --port <port you get from `docker ps`> --host <ip address from `docker-machine ip VM_NAME`>
- $ mongo --port 27017 --host 192.168.59.103
如果需要在一个主机运行多个实例,需要映射不同的端口。
- # Start two containers and map the ports
- $ docker run -p 28001:27017 --name mongo_instance_001 -d my/repo
-
- $ docker run -p 28002:27017 --name mongo_instance_002 -d my/repo
-
- # Now you can connect to each MongoDB instance on the two ports
- $ mongo --port 28001
-
- $ mongo --port 28002