摘要:显示所有数据卷命令如其中命令具体其它的几个个命令,都比较简单更多参考官网说明总结虽然在学习过程中,发现使用的挂载方式要多于使用数据卷容器的方式,主要是因为在本地学习为主,或者以单项目开发为主。
在很早的一篇帖子里 http://dockone.io/question/24 就有人问:「请教下代码放在 Docker 里面还是外面呢」多数人评论类似下面的观点:
由于开发环境代码一直在变动,而且多人通过 git 协作,于是代码都是放在外面,构建一个运行环境的 image,然后代码部分用 volume 映射进去,方便随时调整。
我的观点也是这样的,目前我学习的 docker 更多的是本地开发使用,还未到测试或者真实环境下部署的时候,所以我目前赞同将 docker 作为部署开发环境使用,然后将代码和数据库用 volume 映射到容器中。
所以今天的文章话题是:学习 Docker Volume
Docker VolumeDocker Volume 挂载A volume is a specially-designated directory within one or more containers that bypasses the Union File System. Volumes are designed to persist data, independent of the container’s life cycle. Docker therefore never automatically delete volumes when you remove a container, nor will it “garbage collect” volumes that are no longer referenced by a container. Also known as: data volume
There are three types of volumes: host, anonymous, and named:
A host volume lives on the Docker host’s filesystem and can be accessed from within the container.
A named volume is a volume which Docker manages where on disk the volume is created, but it is given a name.
An anonymous volume is similar to a named volume, however, it can be difficult, to refer to the same volume over time when it is an anonymous volumes. Docker handle where the files are stored.
主要有两种参数方式挂载,一种是 -v,另一种是创建数据卷容器,以--volumes-from 挂载。
-v 方式挂载-v [host-dir]:[container-dir]:[rw|wo]
其中,
· host-dir:表示主机上的目录,如果不存在,Docker 会自动在主机上创建该目录。
· container-dir:表示容器内部对应的目录,如果该目录不存在,Docker 也会在容器内部创建该目录。
· rw|ro:用于控制卷的读写权限。
所以[host-dir]:[container-dir] 一共就有四种组合,其中 container-dir 有没有存在,先不做尝试考虑。
一、假如不指定 host-dir,我们看看:
docker run -it -p 8890:8080 --rm -v /usr/local/tomcat/webapps --name test1 tomcat:8.0
接着使用查看容器中挂载数据卷的情况:
docker inspect test1
这时候看到的挂载的路径是临时的;而容器中对应的目录,也没有被覆盖:
二、假如指定了 host-dir,我们来看看:
docker run -it -d -p 8891:8080 --rm -v /Users/ye/docker/learning/javademo/volume2:/usr/local/tomcat/webapps --name test2 tomcat:8.0
接着使用查看容器中挂载数据卷的情况:
docker inspect test2
可以看出,将主机本地的文件夹挂在上去了:
这时候我们可以看到,在容器中对应的目录下的文件,和主机目录下的保持一致了
如果在主机中增加一个文件 world.java,我们再看看:
保持一致了!
--volumes-from 挂载很多时候,我们会将一些相关的容器部署到同一个主机上,这时候希望这些容器之间可以共享一些数据。这时,我们可以创建一个数据卷容器,然后就可以供多个容器挂载使用了。
这里我就不继续往下进行阐述了,因为我学到 Docker Volume 还没真正使用过数据卷容器,所以没有发言权,等我使用过了,我将补充这方面的学习内容。
数据卷操作命令主要有create、inspect、ls、prune、rm这几个命令,其中拿 ls 举个例子。
docker volume lsList volumes
显示所有数据卷
命令:
docker volume ls [OPTIONS]
如:
其中:[OPTIONS] 命令:
Name, shorthand | Default | Description |
---|---|---|
--filter, -f | Provide filter values (e.g. ‘dangling=true’) | |
--format | Pretty-print volumes using a Go template | |
--quiet, -q | false | Only display volume names |
具体其它的几个个命令,都比较简单:
Command | Description |
---|---|
docker volume create | Create a volume |
docker volume inspect | Display detailed information on one or more volumes |
docker volume ls | List volumes |
docker volume prune | Remove all unused volumes |
docker volume rm | Remove one or more volumes |
总结更多参考官网说明:https://docs.docker.com/engine/reference/commandline/volume_create/#extended-description
虽然在学习过程中,发现使用 -v 的挂载方式要多于使用数据卷容器的方式,主要是因为在本地学习为主,或者以单项目开发为主。但在现实产品开发中,我相信用--volume from 的方式会很多,尤其是生产环境下。有待于我们继续学习,也希望有人能提点我~~~,万谢!
coding01 期待您关注
也很感谢您能看到这了
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/27023.html
摘要:系统有两个程序服务端和客户端。其中服务端是一个服务进程,管理着所有的容器。客户端则扮演着服务端的远程控制器,可以用来控制的服务端进程。守护进程会处理复杂繁重的任务,例如建立运行发布你的容器。客户端和守护进程之间通过或者进行通信。 预期学习目标 Docker基本概念 配置本地Docker环境 容器的生命周期与配置 端口映射和容器链接 利用volume保存持久化容器数据 检查容器日志 监...
摘要:在前一篇文章学习与和应用一初步认识中,我们初步介绍了解决了什么问题,容器化技术与传统的虚拟化方式的区别,以及简要介绍了的几大核心概念镜像容器和仓库。针对上述问题,提供了的,通过使用指令配置的方式来创建镜像。 在前一篇文章 Docker学习与和应用(一)_初步认识中,我们初步介绍了Docker解决了什么问题,Docker容器化技术与传统的虚拟化方式的区别,以及简要介绍了Docker的几大...
摘要:并且各种各样的货物被集装箱标准化了,集装箱和集装箱之间不会互相影响。容器可以被创建启动停止删除暂停等。默认情况下,为了排障需求,退出的容器并不会立即删除,除非手动。这是指用镜像为基础来启动容器。 简明docker教程 一、什么是docker 二、docker与虚拟机比较 三、安装docker 四、基本概念 1、镜像 2、容器 3、数据卷 4、挂载 五、参考资料 有收...
摘要:在配置下上面启动的配置数据库名为账号密码也为。突出点是,即非阻塞的。四对象修改包里面的城市实体对象类。修改城市对象,代码如下城市实体类城市编号省份编号城市名称描述注解标记对应库表的主键或者唯一标识符。 摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第104篇原创 文章工程: JDK...
摘要:正式上线已经大约两年,基本已经成熟,为宜信大数据创新中心各个团队提供了统一的测试和生产环境,简化了服务的部署与上线流程,也降低了运维人员对系统管理的复杂度。地址白皮书原文发布于高可用架构作者宜信大数据创新中心团队王超一 一、基于Docker的PaaS平台LAIN 在金融的场景下,LAIN 是为解放各个团队和业务线的生产力而设计的一个云平台。LAIN 正式上线已经大约两年,基本已经成熟,...
阅读 768·2023-04-26 00:30
阅读 2661·2021-11-23 09:51
阅读 1026·2021-11-02 14:38
阅读 2528·2021-09-07 10:23
阅读 2207·2021-08-21 14:09
阅读 1266·2019-08-30 10:57
阅读 1590·2019-08-29 11:20
阅读 1112·2019-08-26 13:53