docker-compose:数据卷volumes挂载规则说明
目录
- 案例compose
- 前言
- 结果
- 概念理解
- tips
- 总结
案例compose
# add this file
# default MySQL root password is 123456
version: '3.1'
services:
mysql:
image: mysql:5.7
container_name: mysql_5.7
restart: always
ports:
- 3305:3306
volumes:
- ./mysql_config/conf.d:/etc/mysql/conf.d
- ./mysql_data:/var/lib/mysql
- ./docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
environment:
MYSQL_ROOT_PASSWORD: 123456
前言
数据卷的挂载,是从host到container的,相当于linux系统中将host文件夹挂载在container的指定目录下,若挂载位置有文件/文件夹,则原文件夹隐藏,unmount后原文件夹恢复。
结果

概念理解
- 宿主机目录对应的物理储存地址被容器和宿主机操作系统同时管理。
- 宿主机目录可以看成一个硬盘被挂载在容器目录下
- 宿主机的目录和容器的目录可以看成两个指针指向同一个物理地址
- 非空容器目录为什么不行?数据卷的意义在于数据持久化,将应用数据分离,因此数据在宿主机,若容器目录非空,会造成逻辑冲突,也就是怎样去同步宿主机目录和容器目录,解决两边文件的差异。因此只能挂载在容器中的空目录下。
tips
- 若挂载的是目录,容器目录要为空目录
- 若容器目录不存在,也可以挂载会自动创建
- volumes基本规则->*文件夹:文件夹;文件:文件
只要指定目录挂载就会删除容器内的同名文件夹,例如:将mysql的配置目录映射出容器,就会被代替为宿主机的对应文件夹内容,无法在compose层面将原本的配置文件copy到宿主机。但是目前,docker-
compose不支持类似docker cp的功能将容器内的文件复制到宿主机。
可以参考github上官方的提问:https://github.com/docker/compose/issues/5523
以及Stack Overflow上的提问:https://stackoverflow.com/questions/39176561/copying-files-to-a-container-with-docker-compose
想要将容器内文件复制出容器的解决的方法只有通过手动或脚本执行docker cp。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章
- 02-02hadoop动态增加和删除节点方法介绍
- 02-02干货 | Linux新手入门好书推荐
- 02-02linux系统下MongoDB单节点安装教程
- 02-02Linux下nginx生成日志自动切割的实现方法
- 02-02Centos 6中编译配置httpd2.4的多种方法详解
- 02-02CentOS7 下安装telnet服务的实现方法
- 02-02分布式Hibernate search详解
- 02-02Hadoop对文本文件的快速全局排序实现方法及分析
- 02-02CentOS6.3添加nginx系统服务的实例详解
- 02-02Hadoop编程基于MR程序实现倒排索引示例


阅读排行
推荐教程
- 12-07解决tomcat启动报错:一个或多个listeners启动失败问题
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-07Tomcat启动报错:严重: Unable to process Jar entry [m
- 12-07Tomcat配置IPV6的实现步骤
- 12-07tomcat启动报错jar not loaded的问题
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-11docker存储目录迁移示例教程
- 01-07windows server 2008安装配置DNS服务器
- 12-07Tomcat部署war包并成功访问网页详细图文教程
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程




