持久化容器数据

解释

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

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

容器卷

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

例如,假设您创建了一个名为 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 Dashboard 提供查看任何卷内容的功能,以及导出、导入和克隆卷的功能。

  1. 打开 Docker Dashboard 并导航到 **卷** 视图。在此视图中,您应该看到 **postgres_data** 卷。

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

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

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

删除卷

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

$ docker rm -f new-db

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

  • 在 Docker Dashboard 中选择卷上的 **删除卷** 选项。

  • 使用 docker volume rm 命令

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

    $ docker volume prune
    

其他资源

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

下一步

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