Docker -v 挂载主机目录到容器中(及数据卷容器)

简介: Docker -v 挂载主机目录到容器中(及数据卷容器)

一、简单挂载

  • 使用 Docker 的过程中,经常需要挂载主机上的目录或文件到 Docker 容器中,以实现数据的共享或持久化。而 docker run -v 命令便是用于挂载主机目录到 Docker 容器中的常用命令。
  • 在创建启动容器时,使用-v参数设置数据卷
# 挂载单个
$ docker run ... -v [主机目录]:[容器目录] [镜像名称]
# 挂载多个
$ docker run -v [主机目录1]:[容器目录1] -v [主机目录2]:[容器目录2] -v [主机目录3]:[容器目录3] [镜像名称]
  • 注意事项:
  • 目录必须是绝对路径
  • 如果目录不存在,会自动创建
  • 可以挂载多个数据卷,写多个 -v 就行

二、简单挂载案例

  • centos 举例挂载
# 拉取最新 centos
$ docker pull centos
# 一般可以放在 root 目录下,这里为了测试,随便写个文件名 dzmtest 作为效果区分
$ docker run -it --name dzm -v /dzmtest/data:/dzmtest/data_container centos /bin/bash
  • 进入容器后,查看容器目录
# 或者 $ ls -l
$ ls
# dzmtest 文件夹就被创建了,里面还有个 data_container 文件夹
bin  dev  dzmtest  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
  • 查看宿主机目录,需要回到宿主机最外层
# 或者 $ ls -l
$ ls
# 需要通过 $ cd .. 回到宿主机文件最外层,根目录,会发现创建好了 dzmtest,里面还有个 data 文件夹
Docker  bin  boot  dev  dzmtest  etc  home  init  lib  lib32  lib64  libx32  lost+found  media  mnt  opt  proc  root  run  sbin  snap  srv  sys  tmp  usr  var
  • 测试数据同步功能,在宿主机(/dzmtest/data)或容器(/dzmtest/data_container)内添加文件,或修改文件内容都会互相同步。
# 或 $ cd /dzmtest/data_container
$ cd /dzmtest/data
# 随便创建一个文件
$ touch dzm.txt
  • 如果创建文件报错 touch: cannot touch 'dzm.txt': Permission denied 是没有权限,加个权限就行。
    如果报错 -bash: cd: data/: Permission denied 也是一样,加个最高权限就行了。
# 回到上层文件夹
$ cd ..
# 对 data 文件添加权限
# chmod 修改权限指令
# -R 对目前目录下的所有档案与子目录进行相同的权限变更
# 777 是所有用户都拥有最高权限
$ sudo chmod -R 777 ./data/
  • 然后再次执行创建文件命令,就能创建成功了
dengzemiao@DESKTOP-D06B2J2:/dzmtest/data$ ls
# 宿主机上文件就创建好了,然后去容器内的绑定文件夹内查看下是否存在文件
dzm.txt
[root@037524b9fb04 /]# cd dzmtest/data_container/
[root@037524b9fb04 data_container]# ls
# 容器内也存在同样的文件了,这样就实现了共享
dzm.txt
  • 举例挂载多个目录
# 通过 \ + 回车进行换行输入
$ docker run -it --name dzm \
> -v /dzmtest/data1:/dzmtest/data1 \
> -v /dzmtest/data2:/dzmtest/data2 \
> centos /bin/bash

三、数据卷容器

  • 如果是多容器数据共通,那么按上面的办法就是每个容器都关联宿主机的一个文件夹,这样就能多容器数据共通
    还有种方式就是 数据卷容器,就是创建一个容器专门挂载宿主机文件夹,然后其他容器关联到这个容器即可。

    1、创建启动 c3 数据卷容器,使用 -v 设置数据卷
# -v /volume 这种写法会在容器内创建一个 /volume 目录,然后 docker 会在宿主机上自动分配一个目录作为绑定目录
$ docker run -it --name=c3 -v /volume centos:7 /bin/bash
# 执行命令后,如何查看容器自动分配的宿主机绑定目录呢
$ docker inspect c3
[
    {
        ......
        "HostConfig": {
            // 如果指定数据卷目录,这里会列出绑定信息
            "Binds": null,
            ......
        },
        ......
        // 挂着信息
        "Mounts": [
            {
                "Type": "volume",
                "Name": "8d89f84aa486fcf706e180e6aa17649929147bdbc32e8aa3391b4dffdce27d09",
                // 宿主机中的目录
                "Source": "/var/lib/docker/volumes/8d89f84aa486fcf706e180e6aa17649929147bdbc32e8aa3391b4dffdce27d09/_data",
                // 容器中的目录
                "Destination": "/dzmtest1",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ],
        .....
    }
]
dengzemiao@DESKTOP-D06B2
  • 2、创建启动 c1 c2 容器,使用 --volumes-from 设置数据卷容器
$ docker run -it --name=c1 --volumes-from c3 centos:7 /bin/bash
$ docker run -it --name=c2 --volumes-from c3 centos:7 /bin/bash
  • 3、然后就在 c1 c2 容器中正常增删改文件,实现互通了,同时也可以单独访问 c3 数据卷容器做处理。
相关文章
|
5天前
|
安全 关系型数据库 开发者
Docker Compose凭借其简单易用的特性,已经成为开发者在构建和管理多容器应用时不可或缺的工具。
Docker Compose是容器编排利器,简化多容器应用管理。通过YAML文件定义服务、网络和卷,一键启动应用环境。核心概念包括服务(组件集合)、网络(灵活通信)、卷(数据持久化)。实战中,编写docker-compose.yml,如设置Nginx和Postgres服务,用`docker-compose up -d`启动。高级特性涉及依赖、环境变量、健康检查和数据持久化。最佳实践涵盖环境隔离、CI/CD、资源管理和安全措施。案例分析展示如何构建微服务应用栈,实现一键部署。Docker Compose助力开发者高效驾驭复杂容器场景。
16 1
|
5天前
|
存储 监控 安全
Docker Compose:轻松实现容器编排的利器
【7月更文挑战第2天】 1. **基础与概念**:服务(多容器实例)、网络(灵活通信)、卷(数据持久化)和配置(安全管理)。 2. **实战指南**:安装Compose,编写`docker-compose.yml`文件,启动应用,并介绍依赖、环境变量、健康检查和数据持久化。 3. **最佳实践**:环境隔离、CI/CD集成、资源管理、日志监控、安全策略及案例分析,展示完整应用栈搭建。
15 1
|
10天前
|
jenkins 持续交付 开发者
利用Docker容器化部署应用的实战指南
【6月更文挑战第27天】本文详述Docker应用部署,涵盖Docker基本概念、安装、镜像制作及运行。通过编写Dockerfile构建镜像,使用`docker build`、`run`、`push`及`stop`命令管理。集成CI/CD工具如Jenkins,实现自动化构建、测试和部署,提升开发效率与部署质量。Docker助力轻量级、可移植的微服务架构。
|
5天前
|
Docker 容器
docker(四):数据卷
docker(四):数据卷
11 0
|
5天前
|
缓存 Linux 开发工具
docker的centos容器使用yum报错
docker的centos容器使用yum报错
17 0
|
9天前
|
Java API Docker
使用Spring Boot和Docker进行容器化部署
使用Spring Boot和Docker进行容器化部署
|
9天前
|
运维 Serverless 文件存储
函数计算产品使用问题之在利用Docker镜像部署应用时,容器内的应用如何能访问函数计算配置的NAS挂载
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
21天前
|
NoSQL 关系型数据库 Redis
Docker的通俗理解和通过宿主机端口访问Redis容器的实例
本文目标:引导初学者入门Docker,理解镜像、容器和宿主机概念,学习常用Docker命令,特别是如何创建并从Redis容器通过宿主机端口访问。 关键点: - Docker核心:镜像(类)、容器(实例)、宿主机(运行环境)。 - `docker pull` 拉取镜像,如 `redis:3.0`。 - `docker run -d --name` 后台运行容器,如 `my-redis`。 - `-p` 参数做端口映射,如 `6379:6379`。 - `docker exec -it` 交互式进入容器,如 `bash` 或执行命令。
100 4
|
18天前
|
前端开发 安全 数据库
Web架构&前后端分离站&Docker容器站&集成软件站&建站分配
Web架构&前后端分离站&Docker容器站&集成软件站&建站分配