持久化容器数据

说明

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

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

容器卷

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

例如,假设您创建一个名为 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 目录中。通过在此处附加卷,您将能够多次重启容器而不会丢失数据。

使用卷

  1. 下载并安装 Docker Desktop。

  2. 使用以下命令启动一个 Postgres 镜像 容器:

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

    这将在后台启动数据库,使用密码进行配置,并将卷附加到 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 postgres:18
    

    您可能已经注意到 POSTGRES_PASSWORD 环境变量已被省略。这是因为该变量仅在新数据库初始化时使用。

  9. 通过运行以下命令验证数据库是否仍包含记录:

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

查看卷内容

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

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

  2. 选择 postgres_data 卷的名称。

  3. Data 选项卡显示卷的内容,并提供导航文件的功能。双击文件可以查看其内容并进行更改。

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

删除卷

在删除卷之前,必须确保它没有附加到任何容器。如果您尚未删除之前的容器,请使用以下命令(-f 会先停止容器,然后将其删除):

$ docker rm -f new-db

有多种方法可以删除卷,包括:

  • 在 Docker Desktop 仪表板中选择卷上的 Delete Volume 选项。

  • 使用 docker volume rm 命令:

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

    $ docker volume prune
    

其他资源

以下资源将帮助您进一步了解卷:

下一步

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

与容器共享本地文件