docker基础知识之挂载本地目录

原文地址:https://blog.youkuaiyun.com/weixin_37773766/article/details/80702926

https://my.oschina.net/piorcn/blog/324202

http://blog.youkuaiyun.com/yangzhenping/article/details/43667785


docker可以支持把一个宿主机上的目录挂载到镜像里。

docker run -it -v /home/dock/Downloads:/usr/Downloads ubuntu64 /bin/bash
    

通过-v参数,冒号前为宿主机目录,必须为绝对路径,冒号后为镜像内挂载的路径。

现在镜像内就可以共享宿主机里的文件了。

默认挂载的路径权限为读写。如果指定为只读可以用:ro

docker run -it -v /home/dock/Downloads:/usr/Downloads:ro ubuntu64 /bin/bash
    


docker还提供了一种高级的用法。叫数据卷。

数据卷:“其实就是一个正常的容器,专门用来提供数据卷供其它容器挂载的”。感觉像是由一个容器定义的一个数据挂载信息。其他的容器启动可以直接挂载数据卷容器中定义的挂载信息。

看示例:

docker run -v /home/dock/Downloads:/usr/Downloads  --name dataVol ubuntu64 /bin/bash
    

创建一个普通的容器。用--name给他指定了一个名(不指定的话会生成一个随机的名子)。

再创建一个新的容器,来使用这个数据卷。

docker run -it --volumes-from dataVol ubuntu64 /bin/bash
    

--volumes-from用来指定要从哪个数据卷来挂载数据。


如何在Docker容器内外互相拷贝数据?

 

从容器内拷贝文件到主机上

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. docker cp <containerId>:/file/path/within/container /host/path/target  

 

从主机上拷贝文件到容器内


参考自:

http://stackoverflow.com/questions/22907231/copying-files-from-host-to-docker-container


1.用-v挂载主机数据卷到容器内


 

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. docker run -v /path/to/hostdir:/mnt $container  
  2. 在容器内拷贝  
  3. cp /mnt/sourcefile /path/to/destfile  


 

 

2.直接在主机上拷贝到容器物理存储系统

 


A. 获取容器名称或者id :

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. $ docker ps  


 

 

B. 获取整个容器的id

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. $ docker inspect -f   '{{.Id}}'  步骤A获取的名称或者id  


 

 

C. 在主机上拷贝文件:

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. $ sudo cp path-file-host /var/lib/docker/aufs/mnt/FULL_CONTAINER_ID/PATH-NEW-FILE   
  2. 或者  
  3. $ sudo cp path-file-host /var/lib/docker/devicemapper/mnt/123abc<<id>>/rootfs/root  


 

例子:

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. $ docker ps  
  2.   
  3. CONTAINER ID      IMAGE    COMMAND       CREATED      STATUS       PORTS        NAMES  
  4.   
  5. d8e703d7e303   solidleon/ssh:latest      /usr/sbin/sshd -D                      cranky_pare  
  6.   
  7. $ docker inspect -f   '{{.Id}}' cranky_pare  
  8.   
  9. or   
  10. $ docker inspect -f   '{{.Id}}' d8e703d7e303  
  11.   
  12. d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5  
  13.   
  14. $ sudo cp file.txt /var/lib/docker/aufs/mnt/**d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5  


3.用输入输出符


 

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. docker run -i ubuntu /bin/bash -c 'cat > /path/to/container/file' < /path/to/host/file/  


或者

[plain]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. docker exec -it <container_id> bash -c 'cat > /path/to/container/file' < /path/to/host/file/  
<think>嗯,用户想了解在使用Docker部署MySQL时如何正确挂载目录的最佳实践。我需要结合之前的引用和Docker相关知识来回答这个问题。首先,用户提到的挂载目录,应该涉及到数据持久化,避免容器重启后数据丢失。记得之前引用中提到了docker-compose up -d命令,还有关于卷挂载的inspect命令,可能需要引用这些内容。 首先,应该从基本概念开始,解释为什么需要挂载目录,比如数据持久化的重要性。然后,使用Docker命令行的例子,比如用-v或--mount参数来挂载卷。这里要注意语法是否正确,比如使用绝对路径还是相对路径,以及宿主机的目录结构。 然后,用户可能更常用docker-compose,所以提供一个docker-compose.yml的示例会比较好。需要确保语法正确,比如volumes部分的配置,服务定义中的卷挂载点。同时,要提到最佳实践,比如使用命名卷还是主机目录,权限设置,尤其是MySQL对目录权限的要求,可能会碰到的问题,比如目录权限导致MySQL无法启动。 还要注意备份和恢复的策略,用户可能关心如何管理这些数据。另外,检查挂载是否成功的方法,可以用docker inspect命令,像引用[2]中的例子,不过需要调整一下,展示如何查看挂载点而不是Propagation属性。这部分可能需要修改命令,确保用户能正确验证挂载情况。 另外,用户可能遇到的问题,比如目录权限问题,或者挂载路径错误,导致MySQL无法写入数据。这时候需要提醒用户检查日志,使用docker logs命令来排查错误。安全问题方面,可能涉及到敏感数据的存储,比如配置文件和密码,需要建议避免将敏感信息直接挂载,而是使用Docker secrets或者其他安全措施。 最后,生成相关问题,可能需要包括如何备份Docker卷,如何处理权限问题,Compose的其他配置选项,以及如何优化MySQL性能的卷配置。这些相关问题可以帮助用户进一步深入学习。 总结一下,回答的结构应该是先介绍基本概念,然后分步骤讲解命令行和Compose两种方法,提供示例代码,接着讨论最佳实践,如权限、备份、安全等,最后给出验证方法和常见问题处理。需要确保所有Docker命令和Compose文件语法正确,并正确引用之前的参考资料,比如后台运行和卷检查的命令。</think>### 如何正确挂载目录部署MySQL容器 #### 1. 基础挂载方法 使用`-v`或`--mount`参数实现目录挂载,保证数据持久化: ```bash docker run -d \ --name mysql-server \ -v /host/data:/var/lib/mysql \ -v /host/config:/etc/mysql/conf.d \ -e MYSQL_ROOT_PASSWORD=your_password \ mysql:8.0 ``` 此命令将容器内的数据库文件($/var/lib/mysql$)和配置文件目录($/etc/mysql/conf.d$)映射到宿主机路径[^1] #### 2. 使用Docker Compose配置 推荐通过`docker-compose.yml`定义服务: ```yaml services: mysql: image: mysql:8.0 volumes: - mysql_data:/var/lib/mysql - ./my-custom-config:/etc/mysql/conf.d environment: MYSQL_ROOT_PASSWORD: your_password deploy: restart_policy: condition: on-failure volumes: mysql_data: ``` 此配置使用命名卷`mysql_data`存储数据库文件,本地目录`my-custom-config`存放配置文件 #### 3. 最佳实践要点 - **权限配置**:确保宿主机目录具有适当权限(建议设置`chown 999:999`,MySQL容器默认使用该UID/GID) - **配置文件管理**:通过挂载`/etc/mysql/conf.d`可覆盖默认配置,例如: ```ini # my-custom-config/custom.cnf [mysqld] max_connections=200 ``` - **备份策略**:定期备份宿主机上的`/host/data`目录,或使用`docker cp`命令导出数据 - **安全建议**:避免在Compose文件中明文存储密码,推荐使用Docker secrets #### 4. 验证挂载状态 使用以下命令检查挂载配置: ```bash docker inspect mysql-server --format '{{ .Mounts }}' ``` 或使用高级格式查看: ```bash docker inspect --format='{{range .Mounts}}{{.Source}}:{{.Destination}} ({{.Type}}){{"\n"}}{{end}}' mysql-server ``` 此方法可验证挂载路径和类型[^2] #### 5. 常见问题处理 - **启动失败**:检查目录权限和路径有效性,查看日志: ```bash docker logs mysql-server ``` - **数据不同步**:确认未同时使用多个容器访问同一宿主机目录 - **性能优化**:对生产环境推荐使用SSD存储,或配置`tmpfs`挂载临时文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值