持久化容器数据

说明

容器启动时,它使用镜像提供的文件和配置。每个容器都可以创建、修改和删除文件,并且这样做不会影响任何其他容器。删除容器时,这些文件更改也会被删除。

虽然容器的这种短暂性非常好,但在您想要持久化数据时,它会带来挑战。例如,如果您重新启动数据库容器,您可能不希望从空数据库开始。那么,如何持久化文件呢?

容器卷

卷是一种存储机制,它能够在单个容器的生命周期之外持久化数据。可以将其视为从容器内部到容器外部的快捷方式或符号链接。

例如,假设您创建了一个名为 `log-data` 的卷。

$ docker volume create log-data

使用以下命令启动容器时,该卷将被挂载(或附加)到容器中的 `/logs` 位置。

$ docker run -d -p 80:80 -v log-data:/logs docker/welcome-to-docker

如果卷 `log-data` 不存在,Docker 将自动为您创建它。

容器运行时,它写入 `/logs` 文件夹的所有文件都将保存在此卷中,位于容器外部。如果您删除容器并使用相同的卷启动一个新容器,这些文件仍然存在。

使用卷共享文件

您可以将相同的卷附加到多个容器,以在容器之间共享文件。这在日志聚合、数据管道或其他事件驱动应用程序等场景中可能很有用。

管理卷

卷具有超出容器生命周期的自身生命周期,并且根据您使用的类型数据和应用程序,其大小可能会变得非常大。以下命令将有助于管理卷

  • docker volume ls - 列出所有卷
  • docker volume rm <volume-name-or-id> - 删除卷(仅当卷未附加到任何容器时才有效)
  • docker volume prune - 删除所有未使用的(未附加的)卷

试一试

在本指南中,您将练习创建和使用卷来持久化 Postgres 容器创建的数据。数据库运行时,它将文件存储到 `/var/lib/postgresql/data` 目录中。通过在此处附加卷,您将能够多次重新启动容器,同时保留数据。

使用卷

  1. 下载并安装 Docker Desktop。

  2. 使用 Postgres 镜像 和以下命令启动容器

    $ docker run --name=db -e POSTGRES_PASSWORD=secret -d -v postgres_data:/var/lib/postgresql/data postgres
    

    这将在后台启动数据库,使用密码对其进行配置,并将卷附加到 PostgreSQL 将持久化数据库文件的目录。

  3. 使用以下命令连接到数据库

    $ docker exec -ti db psql -U postgres
    
  4. 在 PostgreSQL 命令行中,运行以下命令以创建数据库表并插入两条记录

    CREATE TABLE tasks (
        id SERIAL PRIMARY KEY,
        description VARCHAR(100)
    );
    INSERT INTO tasks (description) VALUES ('Finish work'), ('Have fun');
  5. 通过在 PostgreSQL 命令行中运行以下命令来验证数据是否在数据库中

    SELECT * FROM tasks;

    您应该获得如下所示的输出

     id | description
    ----+-------------
      1 | Finish work
      2 | Have fun
    (2 rows)
  6. 通过运行以下命令退出 PostgreSQL shell

    \q
    
  7. 停止并删除数据库容器。请记住,即使容器已被删除,数据仍然保存在 `postgres_data` 卷中。

    $ docker stop db
    $ docker rm db
    
  8. 通过运行以下命令启动一个新容器,并使用持久化数据附加相同的卷

    $ docker run --name=new-db -d -v postgres_data:/var/lib/postgresql/data postgres 
    

    您可能已经注意到,已省略了 `POSTGRES_PASSWORD` 环境变量。这是因为该变量仅在引导新数据库时使用。

  9. 通过运行以下命令验证数据库是否仍然具有这些记录

    $ docker exec -ti new-db psql -U postgres -c "SELECT * FROM tasks"
    

查看卷内容

Docker Desktop 仪表板提供了查看任何卷的内容以及导出、导入和克隆卷的功能。

  1. 打开 Docker Desktop 仪表板并导航到 **卷** 视图。在此视图中,您应该会看到 **postgres_data** 卷。

  2. 选择 **postgres_data** 卷的名称。

  3. **数据** 选项卡显示卷的内容,并提供导航文件的功能。双击文件将允许您查看内容并进行更改。

  4. 右键单击任何文件以保存或删除它。

删除卷

在删除卷之前,它不能附加到任何容器。如果您尚未删除之前的容器,请使用以下命令这样做(`-f` 将首先停止容器,然后将其删除)

$ docker rm -f new-db

有几种方法可以删除卷,包括以下方法

  • 在 Docker Desktop 仪表板中选择卷上的 **删除卷** 选项。

  • 使用 `docker volume rm` 命令

    $ docker volume rm postgres_data
    
  • 使用 `docker volume prune` 命令删除所有未使用的卷

    $ docker volume prune
    

其他资源

以下资源将帮助您了解有关卷的更多信息

后续步骤

现在您已经了解了持久化容器数据,是时候学习如何与容器共享本地文件了。