使用 mongo docker 镜像

使用 mongo 镜像是很方便的,直接使用官方镜像就好了,为了今后更方便使用,这里给出依据 restheart-docker 中的 docker-compose.yml 裁剪出一个还不错的方案(也就是剪除 restheart 部分而已):

  1. # vi docker-compose.yml
  2. version: '2'
  3. ### Creates a named network with the default bridge driver
  4. networks:
  5. backend:
  6. ### Creates a permanent, named data volume
  7. # This makes much easier to identify where the mongodb data is stored on host
  8. # See: https://docs.docker.com/engine/userguide/containers/dockervolumes/#mount-a-shared-storage-volume-as-a-data-volume
  9. volumes:
  10. datavolume:
  11. services:
  12. mongodb:
  13. image: mongo:3.2
  14. ### Uncomment to name the container explicitly
  15. # container_name: your-mongo-name
  16. volumes:
  17. - datavolume:/data/db
  18. networks:
  19. - backend
  20. ports:
  21. - "27017:27017"

运行 docker-compose -f docker-compose.yml up 后便会成功启动镜像了。上面需要解释的有两个地方,networksvolumes 会在第一次启动后新建一个网络与卷,名字分别为 <nowpath>_backend<nowpath>_datavolume,假设当前路径为 testmongo,则有如下输出(第一次):

  1. Creating network "testmongo_backend" with the default driver
  2. Creating volume "testmongo_datavolume" with default driver
  3. Creating testmongo_mongodb_1
  4. Attaching to testmongo_mongodb_1
  5. mongodb_1 | 2016-12-11T13:15:09.269+0000 I CONTROL [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=4929d787dd14
  6. [...]

此时可以查看网络与 volume 信息:docker network inspect testmongo_backend docker volume inspect testmongo_datavolume,特别是 volume inspect 可以看到存储的挂载点:

  1. [
  2. {
  3. "Name": "testmongo_datavolume",
  4. "Driver": "local",
  5. "Mountpoint": "/var/lib/docker/volumes/testmongo_datavolume/_data",
  6. "Labels": null,
  7. "Scope": "local"
  8. }
  9. ]

另外,container_name 是可配的,在实际使用时最好是进行配置。

数据库导出

上面得到的挂载点是存储着 mongo 信息的,但是当我们想到导出当前数据库时这些数据是不可用的(格式不对)。

预计需要用到的指令:MongoDB 备份(mongodump)与恢复(mongorestore)mongodumpmongoexport

docker-compose up 后,我们在数据表中添加一行记录:

在本地(Linux 主机或虚拟机)安装了 mongo (客户端)之后,运行 mongo 命令:

  1. MongoDB shell version: 2.6.10
  2. connecting to: test
  3. Server has startup warnings:
  4. [...]
  5. >
  1. # 新的数据,参考 http://www.runoob.com/mongodb/mongodb-insert.html
  2. > use test
  3. > db.col.insert({title: 'MongoDB 教程',
  4. description: 'MongoDB 是一个 Nosql 数据库',
  5. by: '菜鸟教程',
  6. url: 'http://www.runoob.com',
  7. tags: ['mongodb', 'database', 'NoSQL'],
  8. likes: 100
  9. })

数据表/集合(collection)导出可以直接使用 mongoexport 来导出:mongoexport --db test --collection users --out users.json

但是对一个数据库的导出是不可用的,mongodump --db test --out . 会在当前路径下生成一个空的 test 文件夹,而事实上是有一条数据的。这是一个需要解决的问题,在 SO 上有类似的解决方案:docker-machine ssh command for mongodump,答案中也有我的一些注释,整理一下如下:

想法是新建一个与挂载 volume(这里最好是一个本机路径,容易获取结果)的 mongo container,与当前正在运行的 mongo container 进行连接,执行 dump 指令:

  1. # vi mongodumpFromDocker.sh
  2. # A nice method to mongodump from Docker container
  3. sudo docker run \
  4. --net testmongo_backend \
  5. --link testmongo_mongodb_1:mongo \
  6. -v $(pwd):/backup mongo:3.2 bash \
  7. -c 'mongodump --out /backup --host $MONGO_PORT_27017_TCP_ADDR'
  1. $ chmod +x mongodumpFromDocker.sh
  2. $ ./mongodumpFromDocker.sh

这会当前路径下生成正确的包含数据与数据库信息的 test 文件夹。上面的 bash 文件中 testmongo_backend 是我们上面生成的网络,testmongo_mongodb_1 是因为我们没有指定 container 的名称,$MONGO_PORT_27017_TCP_ADDR 需要换为一个真实的 IP 地址,0.0.0.0 是不可用的,以我跑在 virtualbox 中的虚拟机为例,最后一行可以改为:

-c 'mongodump --out /backup --host 100.100.100.10'

-c 'mongodump --out /backup --host 100.100.100.10:27017'

数据库导入

mongorestore 可以很好的工作:

mongorestore -d test2 test 会在 mongo container 中新建一个与 test 文件夹包含的数据信息相同的数据表(collection) test2

总结

1.上面的用法并非是 production ready 的,特别是没有设置用户名与密码

2.mongo 的几个数据库/表迁移命令只有 mongodump 对 docker 不透明,感觉今后也许会有更新,毕竟我们是可以直接查询到数据内容的,无法一键备份是有些没有道理。

Good Luck & Have Fun!

user_mongo_in_a_docker_and_dump_database的更多相关文章

随机推荐

  1. java 面向对象 — 多态

    注意:如果用父类引用指向子类对象的时候.不可以调用,子类中有但是父类中没有的方法. 抽象 方法没有具体方法,以分号结束.例:public abstract void call(); 1.接口必须要有a ...

  2. sqlnet.ora限制客户端IP访问

    实现功能: 只允许某几个IP访问数据库服务端(白名单): $ORACLE_HOME/network/admin/sqlnet.ora 添加2个主要参数 TCP.VALIDNODE_CHECKING=y ...

  3. 微信JS接口汇总及使用详解

    这篇文章主要介绍了微信JS接口汇总及使用详解,十分的全面.详尽,包含分享到朋友圈,分享给朋友,分享到QQ,拍照或从手机相册中选图,识别音频并返回识别结果,使用微信内置地图查看位置等接口,有需要的小伙伴 ...

  4. Mysql 备份脚本和window下如何实现自动备份

    @echo offecho.echo      MySQL数据库备份 echo *****************************echo.echo 今天是 %date%echo 时间是 %t ...

  5. [nginx]lua操作redis

    local redis = require "resty.redis" local red = redis:new() red:set_timeout() -- sec -- or ...

  6. canvas绘制曲线

    canvas绘制曲线 方法 quadraticCurveTo(cp1x, cp1y, x, y) 只有一个控制点的贝塞尔曲线(其实就是控制点分别与起始点和结束点连线的公切线) bezierCurveT ...

  7. Nginx代理配置文件

    #user nginx; worker_processes 5; #error_log /var/log/nginx/error.log warn; #pid /var/run/nginx.pid; ...

  8. leetcode111

    /** * Definition for a binary tree node. * public class TreeNode { * public int val; * public TreeNo ...

  9. Android开发:实时处理摄像头预览帧视频------浅析PreviewCallback,onPreviewFrame,AsyncTask的综合应用(转)

    原文地址:http://blog.csdn.net/yanzi1225627/article/details/8605061# 很多时候,android摄像头模块不仅预览,拍照这么简单,而是需要在预览 ...

  10. 如何用MaskBlt实现两个位图的合并,从而实现背景透明

    我有两个位图,一个前景图,一个背景图(mask用途).请问如何用MaskBlt实现两个位图的合并,从而实现背景透明! 核心代码:dcImage.SetBkColor(crColour);dcMask. ...