2.2.数据

容器隔离环境容器程序文件配置运行时产生的容器都在容器内部我们读写容器内的文件非常不方便。大家思考几个问题

因此,容器提供程序运行环境,但是程序运行产生的数据程序运行依赖配置应该与容器解耦。

2.2.1.什么数据

数据卷(volume)是一个虚拟目录,是容器内目录宿主机目录之间映射桥梁
Nginx为例我们知道Nginx中有两个关键的目录:
html放置一些静态资源

在这里插入图片描述
在上图中:

**这样一来,容器内的confhtml目录就 与宿主机confhtml目录关联起来,我们称为挂载。**此时,我们操作宿主机/var/lib/docker/volumes/html/_data就是操作容器内的/usr/share/nginx/html/_data目录。只要我们将静态资源放入宿主机对应目录,就可以Nginx代理了。

提示
/var/lib/docker/volumes这个目录就是默认存放所有容器数据卷的目录,其下再根据数据卷名称创建新目录,格式/数据卷名/_data
为什么不让容器目录直接指向宿主机目录呢?
1.因为直接指向宿主机目录就与宿主机耦合了,如果切换环境,宿主机目录就可能发生改变了。由于容器一旦创建,目录挂载就无法修改,这样容器就无法正常工作了。
2.但是容器指向数据卷,一个逻辑名称,而数据卷再指向宿主机目录,就不存在耦合。如果宿主机目录发生改变,只要改变数据卷与宿主机目录之间的映射关系即可

不过,我们通过由于数据卷目录比较深,不好寻找,通常我们也允许让容器直接与宿主机目录挂载而不使用数据卷,具体参考2.2.3小节。

2.2.2.数据卷命令

数据卷的相关命令有:

命令 说明
docker volume create 创建数据卷
docker volume ls 查看所有数据卷
docker volume rm 删除指定数据卷
docker volume inspect 查看个数据卷的详情
docker volume prune 清除数据卷

注意:容器与数据卷的挂载要在创建容器时配置,对于创建好的容器,是不能设置数据卷的。而且创建容器的过程中,数据卷会自动创建

容器与数据卷的挂载需要在创建容器时进行配置,而不能对已经创建好的容器进行设置。在Docker中,数据卷是在容器运行动态挂载的,可以运行通过-v参数将主机上的目录挂载到容器内部的目录。但是,一旦容器被创建并运行,就不能再重新配置其数据卷的挂载。

2.2.2.1 演示一下nginxhtml目录挂载

在这里插入图片描述
1.通过dps(上一篇文章设置命令别名docker ps 查看容器是否存在

docker ps
dps

2.删除容器

docker rm -f nginx

在这里插入图片描述
3.首先创建容器并指定数据卷,注意通过 -v 参数来指定数据卷

 docker run -d --name nginx -p 80:80 -v html:/usr/share/nginx/html  nginx

挂载目录在哪找?上docker官网 查看文档
在这里插入图片描述
4.挂载完数据卷后,然后查看数据卷

docker volume ls
# 结果
DRIVER    VOLUME NAME
local     d408fc247fe5905a87c60b72657a05841e88a41798e76e51bbe2f9ce49928760
local     html

在这里插入图片描述
5. 查看数据卷详情

docker volume inspect html
# 结果
[
    {
        "CreatedAt": "2023-11-28T21:22:52+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/html/_data",
        "Name": "html",
        "Options": null,
        "Scope": "local"
    }
]

在这里插入图片描述
6.查看宿主机的 /var/lib/docker/volumes/html/_data目录

ll /var/lib/docker/volumes/html/_data
# 可以看到nginxhtml目录内容一样,结果如下
总用量 8
-rw-r--r--. 1 root root 497 1024 21:46 50x.html
-rw-r--r--. 1 root root 615 1024 21:46 index.html

查看容器内部文件

docker exec -it nginx bash
cd /usr/share/nginx/html
ls

在这里插入图片描述

因为容器内部没有vill这些命令,所以挂载数据卷的方式来修改宿主机的文件,从而改变容器内部的文件

7.进入该目录(数据卷目录),并随意修改index.html内容

cd /var/lib/docker/volumes/html/_data
vi index.html

不想通过vi 进行修改的话,可以点击 MobaXtermFollow terminal folder 勾选,就可以像在windows打开一个文件那样进行修改了
在这里插入图片描述
在这里插入图片描述

  1. 打开浏览器查看效果

在这里插入图片描述
9.添加静态资源
在这里插入图片描述
浏览器查看效果
在这里插入图片描述
10.进入容器内部,查看/usr/share/nginx/html目录内的文件是否变化

docker exec -it nginx bash
cd /usr/share/nginx/html
ls

在这里插入图片描述
大致流程

# 1.首先创建容器并指定数据卷,注意通过 -v 参数来指定数据卷
docker run -d --name nginx -p 80:80 -v html:/usr/share/nginx/html nginx

# 2.然后查看数据卷
docker volume ls
# 结果
DRIVER    VOLUME NAME
local     29524ff09715d3688eae3f99803a2796558dbd00ca584a25a4bbc193ca82459f
local     html

# 3.查看数据卷详情
docker volume inspect html
# 结果
[
    {
        "CreatedAt": "2024-05-17T19:57:08+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/html/_data",
        "Name": "html",
        "Options": null,
        "Scope": "local"
    }
]

# 4.查看/var/lib/docker/volumes/html/_data目录
ll /var/lib/docker/volumes/html/_data
# 可以看到与nginx的html目录内容一样,结果如下
总用量 8
-rw-r--r--. 1 root root 497 1228 2021 50x.html
-rw-r--r--. 1 root root 615 1228 2021 index.html

# 5.进入该目录,并随意修改index.html内容
cd /var/lib/docker/volumes/html/_data
vi index.html

# 6.打开页面,查看效果

# 7.进入容器内部,查看/usr/share/nginx/html目录内的文件是否变化
docker exec -it nginx bash

教学演示环节:演示一下MySQL的匿名数据卷

2.2.2.2.查看MySQL容器详细信息
docker inspect mysql
# 关注其中`.Config.Volumes`部分和`.Mounts`部分

我们关注部分内容,第一是.Config.Volumes部分

{
  "Config": {
    // ... 略
    "Volumes": {
      "/var/lib/mysql": {}
    }
    // ... 略
  }
}

可以发现这个容器声明一个本地目录,需要挂载数据卷,但是数据卷未定义。这就是匿名卷。
然后,我们再看结果中的.Mounts部分

{
  "Mounts": [
    {
      "Type": "volume",
      "Name": "29524ff09715d3688eae3f99803a2796558dbd00ca584a25a4bbc193ca82459f",
      "Source": "/var/lib/docker/volumes/29524ff09715d3688eae3f99803a2796558dbd00ca584a25a4bbc193ca82459f/_data",
      "Destination": "/var/lib/mysql",
      "Driver": "local",
    }
  ]
}

可以发现,其中有几个关键属性

接下来,可以查看该目录下的MySQL_data文件:

ls -l /var/lib/docker/volumes/29524ff09715d3688eae3f99803a2796558dbd00ca584a25a4bbc193ca82459f/_data

注意:每一个不同镜像,将来创建容器后内部有哪些目录可以挂载,可以参考DockerHub对应页面

2.2.3.挂载本地目录或文件

可以发现数据卷的目录结构较深,如果我们去操作数据卷目录会不太方便。在很多情况下,我们会直接容器目录与宿主机指定目录挂载。挂载语法与数据卷类似:

# 挂载本地目录
-v 本地目录:容器内目录
# 挂载本地文件
-v 本地文件:容器内文件

!!!注意:本地目录或文件必须以 /./开头如果直接以名字开头,会被识别为数据卷名而非本地目录名。
例如

-v mysql:/var/lib/mysql # 会被识别一个数据卷叫mysql,运行时会自动创建这个数据卷
-v ./mysql:/var/lib/mysql # 会被识别当前目录下的mysql目录,运行时如果不存在会创建目录

教学演示删除并重新创建mysql容器,并完成本地目录挂载:

# 1.删除原来的MySQL容器
docker rm -f mysql

# 2.进入root目录
cd ~

# 3.创建并运行新mysql容器,挂载本地目录
docker run -d 
  --name mysql 
  -p 3306:3306 
  -e TZ=Asia/Shanghai 
  -e MYSQL_ROOT_PASSWORD=123 
  -v ./mysql/data:/var/lib/mysql 
  -v ./mysql/conf:/etc/mysql/conf.d 
  -v ./mysql/init:/docker-entrypoint-initdb.d 
  mysql

# 4.查看root目录,可以发现~/mysql/data目录已经自动创建好了(注意,我这里是先创建的目录,如果创建,会自动帮你创建目录的,然后放置hm.cnf 和 hmall.sql文件即可)
ls -l mysql
# 结果:
总用量 4
drwxr-xr-x. 2 root    root   20 519 15:11 conf
drwxr-xr-x. 7 polkitd root 4096 519 15:11 data
drwxr-xr-x. 2 root    root   23 519 15:11 init

# 查看data目录,会发现里面有大量数据库数据,说明数据库完成初始化
ls -l data

# 5.查看MySQL容器内数据
# 5.1.进入MySQL
docker exec -it mysql mysql -uroot -p123
# 5.2.查看编码
show variables like "%char%";
# 5.3.结果,发现编码utf8mb4没有问题
+--------------------------+--------------------------------+
| Variable_name            | Value                          |
+--------------------------+--------------------------------+
| character_set_client     | utf8mb4                        |
| character_set_connection | utf8mb4                        |
| character_set_database   | utf8mb4                        |
| character_set_filesystem | binary                         |
| character_set_results    | utf8mb4                        |
| character_set_server     | utf8mb4                        |
| character_set_system     | utf8mb3                        |
| character_sets_dir       | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+

# 6.查看数据
# 6.1.查看数据库
show databases;
# 结果,hmall黑马商城数据库
+--------------------+
| Database           |
+--------------------+
| hmall              |
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)
# 6.2.切换hmall数据库
use hmall;
# 6.3.查看表
show tables;
# 结果:
+-----------------+
| Tables_in_hmall |
+-----------------+
| address         |
| cart            |
| item            |
| order           |
| order_detail    |
| order_logistics |
| pay_order       |
| user            |
+-----------------+
# 6.4.查看address表数据
select * from address
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
| id | user_id | province | city   | town     | mobile      | street        | contact   | is_default | notes |
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
| 59 |       1 | 北京     | 北京   | 朝阳区    | 13900112222 | 金燕龙办公| 李佳诚    | 0          | NULL  |
| 60 |       1 | 北京     | 北京   | 朝阳区    | 13700221122 | 修正大厦       | 李佳红    | 0          | NULL  |
| 61 |       1 | 上海     | 上海   | 浦东新区  | 13301212233 | 航头镇航头路   | 李佳星    | 1          | NULL  |
| 63 |       1 | 广东     | 佛山   | 永春      | 13301212233 | 永春武馆       | 李晓龙    | 0          | NULL  |
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
4 rows in set (0.00 sec)

数据卷 和 挂载本地目录 的区别:数据卷是双向的,挂载本地目录是单向的,数据卷:容器内部可以影响宿主机,挂载本地目录则不行。

原文地址:https://blog.csdn.net/qq_43322436/article/details/134701380

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_43760.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注