写在前面的话

学到这里相信有心的朋友都发现问题了,我们每次都会去删掉容器,在创建新的容器。那数据怎么办?岂不删库跑路了?

就算不是数据库,假设公司有日志保留的需求,那每一次发布岂不日志都被干掉了?

Data volume

MySQL 镜像的官方文档如下,其中涉及到很多参数也是上面的:

https://github.com/docker-library/docs/tree/master/mysql

该配置项对应到 Dockerfile 中的关键字就是 VOLUME,后面会详细学习,以下是 MySQL 5.7 的官方 Dockerfile,看看人家是怎么写的:

https://github.com/docker-library/mysql/blob/bb7ea52db4e12d3fb526450d22382d5cd8cd41ca/5.7/Dockerfile

首先删除掉目前所有容器,删除所有的 volume,运行一个 MySQL 容器,并设置不需要密码:

# 删除所有容器
docker rm -f $(docker ps -aq)

# 删除所有卷
docker volume rm $(docker volume ls -q)

# 创建 MySQL 容器
docker run -d --name db1 -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7

然后进入容器,登入数据库创建一个名为 hello 的库:

docker exec -it db1 /bin/sh

具体操作如图:

之后退出容器,再删除掉它:

docker container rm -f db1

此时查看数据卷:

docker volume ls

结果如图:

可以看到,虽然删除了容器,但是 VOLUME 中还是保留了一个卷。那这个卷怎么使用呢?

此时再度新建一个 MySQL 容器,和之前不同,这次把这个容器的卷指向这个之前的卷:

docker run -d --name db2 -v 651246525fdde44a562bace3388705562d477d28c200128a7a7af8c1e2bf11c2:/var/lib/mysql -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7

说明:在 -v 参数后面使用了 /var/lib/mysql,这个目录来自之前的 MySQL Dockerfile 中有定义一项:VOLUME /var/lib/mysql

此时查看卷:

docker volume ls

发现并没有新加新创建的卷,进入容器查看数据库:

docker exec -it db2 /bin/sh

查看数据库结果如图:

发现之前建立的 hello 库还在,唯一有点小遗憾,那就是 VOLUME NAME 因为是随机,当然这个是可以解决的。

新建一个 MySQL 容器,指定 VOLUME 名称:

docker run -d --name db3 -v my-data:/var/lib/mysql -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:5.7

查看:

docker volume ls

结果如图:

此时 VOLUME NAME 就变成自己定义的了。

Bind Mouting

这是数据持久化的第二种方式,相比于第一种以卷的形式存储,这种方式更适合用于前端静态文件更新,这里以 nginx 镜像为例:

docker run -d --name web1 -p 8080:80 -v /data/html:/usr/share/nginx/html nginx

进入本地宿主机 /data/html 目录,增加 index.html:

cd /data/html/
vim index.html

内容如下:

<h1>Hello world</h1>

访问测试:

这样实现的效果就相当于把容器里面某个指定的目录映射到宿主机本地某个目录,只需要在本地修改文件就达到了修改容器中文件的目的。

部署 Wordpress 实践

这里新增一个实践用于熟悉传参和数据持久化的问题。

【1】启动 MySQL 容器:

docker run -d -v wordpress-data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_DATABASE=wordpress --name wordpress-db mysql:5.7

设置了数据库的密码和新建了一个数据库,并给数据卷做了重命名。

【2】启动 Wordpress 容器:

docker run -d --link wordpress-db --name wordpress-web -e WORDPRESS_DB_HOST=wordpress-db:3306 -e WORDPRESS_DB_USER=root -e WORDPRESS_DB_PASSWORD=123456 -e WORDPRESS_DB_NAME=wordpress -p 8080:80 wordpress

具体参数可以参考:

https://github.com/docker-library/docs/tree/master/wordpress

采取 --link 的方式就行数据库连接。第一次由于需要下载,可能比较慢,完成以后访问测试:

小结

在本节中我们知道了数据的持久化,也接触了 Dockerfile 中一个新的关键字 VOLUME,将某个目录制作成数据卷,相当重要。

【07】循序渐进学 docker:数据持久化的更多相关文章

  1. Docker数据持久化及实战(Nginx+Spring Boot项目+MySQL)

    Docker数据持久化: Volume: (1)创建mysql数据库的container docker run -d --name mysql01 -e MYSQL_ROOT_PASSWORD= my ...

  2. Docker数据持久化与容器迁移

    上节讲到当容器运行期间产生的数据是不会在写镜像里面的,重新用此镜像启动新的容器就会初始化镜像,会加一个全新的读写入层来保存数据.如果想做到数据持久化,Docker提供数据卷(Data volume)或 ...

  3. 【01】循序渐进学 docker:到底是啥

    写在前面的话 首先说一下,我本身是做运维的,4 年工作,多家公司.所以可能接下来谈到的更多的是一些在工作过程中积累的个人看法.且有些并不具备普遍性,有不合适的地方,全当我在吹牛逼就行. 一开始我们得谈 ...

  4. docker数据持久化

    转载/参考: https://www.jianshu.com/p/ef0f24fd0674 Docker的数据持久化主要有两种方式: bind mount docker managed volume ...

  5. docker数据持久化/共享---volume,bind-mount,tmpfs-mount

    一.将Docker数据挂载到容器 在Docker中,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束),需要将数据从宿主机挂载到容器中.目前Docker提供 ...

  6. Docker | 数据持久化与数据共享

    数据持久化(安装MySQL) 参考另一篇Docker安装mysql: https://www.cnblogs.com/all-smile/p/16778376.html MySQL的数据持久化问题 # ...

  7. 【08】循序渐进学 docker:docker compose

    写在前面的话 在之前的操作中,即使是单个容器每次都需要敲很长的命令,当需要多个容器组合着用的时候更加麻烦,此时我们急需找到一种一次配置,随便运行的方法. 这就是这一节重点,单机容器编排工具:docke ...

  8. 【09】循序渐进学 docker:docker swarm

    写在前面的话 至此,docker 的基础知识已经了解的差不多了,接下来就来谈谈对于 docker 容器,我们如何来管理它. docker swarm 在学习 docker swarm 之前,得先知道容 ...

  9. 【06】循序渐进学 docker:跨主机通信

    写在前面的话 目前解决容器跨主机通信的方案有很多种,这里给出的只是其中的一种,而且还不是最好的方案,不过归根结底,大同小异.在学习 docker swarm 之前,大家可以先看看这种. 啥是 over ...

随机推荐

  1. 解剖Nginx·自动脚本篇(6)编译器名称变量脚本 auto/cc/name

    回顾变量 CC 最初是在auto/options脚本中初始化的: CC=${CC:-gcc} 1 C Compiler 的 feature Windows 平台的编译器叫做MSVC,其他平台的都统称为 ...

  2. iOS 打印结构体

    关于OC直接打印结构体,点(CGRect,CGSize,CGPoint,UIOffset)等数据类型,我们完全可以把其转换为OC对象来进项打印调试,而不必对结构体中的成员变量进行打印.就好比我们可以使 ...

  3. iOS端一次视频全屏需求的实现(转)

    对于一个带有视频播放功能的app产品来说,视频全屏是一个基本且重要的需求.虽然这个需求看起来很简单,但是在实现上,我们前后迭代了三套技术方案.这篇文章将介绍这三种实现方案中的利弊和坑点,以及实现过程中 ...

  4. Cocos2dx之touch事件

    今天看了下ccocos2dx touch事件部分的源码,从CCTouch.CCTouchHandler和CCTouchDispatcher简单的做了分析和总结,先直接看源码吧! 1.CCTouch c ...

  5. code1039 数的划分

    来自http://blog.csdn.net/WhiStLenA/article/details/51585992 重点内容 设F(i,j)为用j个数组成i,答案为F(7,3)的话. 一个思路是,对于 ...

  6. spring.net事件的注入

    .c#代码 TestObject source = new TestObject(); TestEventHandler eventListener1 = new TestEventHandler() ...

  7. Part3_lesson2---ARM指令分类学习

    1.算术和逻辑指令 mov.mvn.cmp.tst.sub.add.and.bic 2.比较指令 cmp和tst 3.跳转指令 b和bl 4.移位指令 lsl和ror 5.程序状态字访问指令 msr与 ...

  8. System.Reflection.Emit摘记

    动态类型在.net中都是用什么类型来表示的.程序集:System.Reflection.Emit.AssemblyBuilder(定义并表示动态程序集)构造函数:System.Reflection.E ...

  9. Charles 4.2.5 破解原理.RP

    请支持正版,仅供技术交流. 写了个小工具方便在线处理,在线破解 https://github.com/8enet/Charles-Crack 2018/4/8 Charles 4.2.5 替换类名和方 ...

  10. Sql的行列转换

    创建表scores 一.传统的行列转换 纵表转横表 我们要转成的横表是这样子的: pivot是sql server 2005 提供的运算符,所以只要数据库在05版本以上的都可以使用.主要用于行和列的转 ...