Docker数据持久化: Volume: (1)创建mysql数据库的container docker run -d --name mysql01 -e MYSQL_ROOT_PASSWORD= mysql (2)查看volume  docker volume ls (3)具体查看该volume  docker volume inspect  bba71cbbe0f86c0208f62077974261fc80c6795b9a51995c4ba0d0c7d563d7a2 (4)名字不好看,nam…
写在前面的话 学到这里相信有心的朋友都发现问题了,我们每次都会去删掉容器,在创建新的容器.那数据怎么办?岂不删库跑路了? 就算不是数据库,假设公司有日志保留的需求,那每一次发布岂不日志都被干掉了? Data volume MySQL 镜像的官方文档如下,其中涉及到很多参数也是上面的: https://github.com/docker-library/docs/tree/master/mysql 该配置项对应到 Dockerfile 中的关键字就是 VOLUME,后面会详细学习,以下是 MySQ…
上节讲到当容器运行期间产生的数据是不会在写镜像里面的,重新用此镜像启动新的容器就会初始化镜像,会加一个全新的读写入层来保存数据.如果想做到数据持久化,Docker提供数据卷(Data volume)或者数据容器卷来解决问题,另外还可以通过commit提交一个新的镜像来保存产生的数据.那么,来一一看下各自的使用方法. 一.数据卷 数据卷特性: 可以绕过UFS文件系统,为一个或多个容器提供访问. 完全独立于容器的生存周期,因此不会在删除容器时删除其挂在的数据卷. 数据卷特点: 数据卷在容器启动初始化…
写在前面的话 首先说一下,我本身是做运维的,4 年工作,多家公司.所以可能接下来谈到的更多的是一些在工作过程中积累的个人看法.且有些并不具备普遍性,有不合适的地方,全当我在吹牛逼就行. 一开始我们得谈谈为啥要学 docker?在 17/18 年,有两个东西在业内特别火,一个是区块链比特币,但是现在似乎凉的差不多了.另外一个就是 docker. 那火到什么程度呢?你要是出去找运维的工作说不会 docker,薪资直接降了一档的感觉.越来越多公司陶醉其中,吹牛逼也好,真牛逼也好.它终究已经变成了一种不…
转载/参考: https://www.jianshu.com/p/ef0f24fd0674 Docker的数据持久化主要有两种方式: bind mount docker managed volume Docker的数据持久化即数据不随着container的结束而结束,数据存在于host机器上——要么存在于host的某个指定目录中(使用bind mount),要么使用docker自己管理的volume(/var/lib/docker/volumes下). 1.bind mount bind mou…
一.将Docker数据挂载到容器 在Docker中,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束),需要将数据从宿主机挂载到容器中.目前Docker提供了三种不同的方式将数据从宿主机挂载到容器中: (1)volumes:Docker管理宿主机文件系统的一部分,默认位于 /var/lib/docker/volumes 目录中:(最常用的方式) 由上图可以知道,目前所有Container的数据都保存在了这个目录下边,由于没有在创建时指定卷,所以Dock…
数据持久化(安装MySQL) 参考另一篇Docker安装mysql: https://www.cnblogs.com/all-smile/p/16778376.html MySQL的数据持久化问题 # 下载容器 docker pull mysql:5.7 -d 后台运行 -p 端口映射 -v 挂载数据卷 -e 环境配置 --name 容器名字 # 运行容器 docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /h…
写在前面的话 在之前的操作中,即使是单个容器每次都需要敲很长的命令,当需要多个容器组合着用的时候更加麻烦,此时我们急需找到一种一次配置,随便运行的方法. 这就是这一节重点,单机容器编排工具:docker-compose. 安装使用 docker-compose 官方文档如下: https://docs.docker.com/compose/install/ 安装 docker-compose,其实就是一个脚本: # 下载脚本和修改权限 curl -L "https://github.com/do…
写在前面的话 至此,docker 的基础知识已经了解的差不多了,接下来就来谈谈对于 docker 容器,我们如何来管理它. docker swarm 在学习 docker swarm 之前,得先知道容器编排工具的作用:提供了基于容器调度和集群的技术,并编排容器之间如何进行交互. docker swarm 不是唯一的容器编排工具,但却是 docker 自带的容器编排工具. 可以看看它的主要结构(图片来自互联网): docker swarm 以集群的形式运行,包括两个角色:Manager 和 wor…
写在前面的话 目前解决容器跨主机通信的方案有很多种,这里给出的只是其中的一种,而且还不是最好的方案,不过归根结底,大同小异.在学习 docker swarm 之前,大家可以先看看这种. 啥是 overlay 和 etcd 从这里开始正式引入 overlay 网络这个概念,那啥是 overlay 呢? 可以这样理解,在原本主机通信之上开通的通信隧道,覆盖于原本的主机网络之上,所以叫 overlay. 那 etcd 又是啥?它源于 zookeeper,一个用于分享配置和服务发现的分布式一致性 KV…