写在前面的话

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

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

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. [iOS]在xcode的iOS虚拟机中对BLE(蓝牙4.0)进行调试

    本文档的主要内容可参考苹果官方资料: http://developer.apple.com/library/ios/#technotes/tn2295/_index.html 1. 买一个CSR蓝牙4 ...

  2. C#获取类里面的所有的方法名称

    Type trypInfo = typeof(Program);// Program为类名//获得方法名string str = "包括的方法名列表:\r\n"; MethodIn ...

  3. guestfs-python 手册

    Help on module guestfs: NAME guestfs - Python bindings for libguestfs FILE /usr/lib64/python2.7/site ...

  4. Nginx负载均衡高可用

    1.   Nginx负载均衡高可用 首先介绍一下Keepalived,它是一个高性能的服务器高可用或热备解决方案,Keepalived主要来防止服务器单点故障的发生问题,可以通过其与Nginx的配合实 ...

  5. strncmp memcmp区别

    内部实现:前者逐每个字符进行比较,并判当前字符是否为0: 后者逐内存块进行比较. 效率:后者自然要优,不论从内部实现上,还是系统优化上. 场景:后者无法替代前者.在项目中遇到一种情况,两个字符串比较, ...

  6. 144. Binary Tree Preorder Traversal (Tree, Stack)

    Given a binary tree, return the preorder traversal of its nodes' values. For example: Given binary t ...

  7. 虚拟机安装centos发现inet为127.0.0.1,导致Xshell连接不上

    问题如标题所示: 设置网卡开机自动启动: 实质linux是看一个网卡文件的配置,就是/etc/sysconfig/network-scripts/ifcfg-eth0 (这个文件名看你网卡名称而异,具 ...

  8. cs api测试

    更新磁盘方案 http://192.168.150.16:8900/client/api?command=updateDiskOffering&id=199e3be4-2af1-47a3-9f ...

  9. ServiceStack.Redis泛型存储后getById问题

    关于ServiceStack.Redis实体存储常用的有一下几个方法 StoreAsHash<T>(T entity)  //将对象按照Hash存储 Redis.As<T>() ...

  10. DOM0级与DOM2级

    定义: 0级DOM 分为2个:一是在标签内写onclick事件  二是在JS写onlicke=function(){}函数 1) <input id="myButton" t ...