持久化容器数据
说明
容器启动时会使用镜像提供的文件和配置。每个容器都可以创建、修改和删除文件,且不会影响其他容器。当容器被删除时,这些文件更改也会被删除。
虽然容器的这种短暂特性非常有用,但当您希望持久化数据时,它会带来挑战。例如,如果您重启数据库容器,可能不希望从一个空的数据库开始。那么,如何持久化文件呢?
容器卷
卷是一种存储机制,它提供了在单个容器的生命周期之外持久化数据的能力。可以将其想象为从容器内部到容器外部提供快捷方式或符号链接。
例如,假设您创建一个名为 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 目录中。通过在此处附加卷,您将能够多次重启容器而不会丢失数据。
使用卷
-
下载并安装 Docker Desktop。
-
使用以下命令启动一个 Postgres 镜像 容器:
$ docker run --name=db -e POSTGRES_PASSWORD=secret -d -v postgres_data:/var/lib/postgresql postgres:18这将在后台启动数据库,使用密码进行配置,并将卷附加到 PostgreSQL 将持久化数据库文件的目录。
-
使用以下命令连接到数据库:
$ docker exec -ti db psql -U postgres -
在 PostgreSQL 命令行中,运行以下命令创建数据库表并插入两条记录:
CREATE TABLE tasks ( id SERIAL PRIMARY KEY, description VARCHAR(100) ); INSERT INTO tasks (description) VALUES ('Finish work'), ('Have fun'); -
通过在 PostgreSQL 命令行中运行以下命令验证数据是否在数据库中:
SELECT * FROM tasks;您应该会得到类似以下的输出:
id | description ----+------------- 1 | Finish work 2 | Have fun (2 rows) -
运行以下命令退出 PostgreSQL shell:
\q -
停止并删除数据库容器。请记住,即使容器已被删除,数据仍会持久化在
postgres_data卷中。$ docker stop db $ docker rm db -
使用以下命令启动新容器,附加包含持久化数据的相同卷:
$ docker run --name=new-db -d -v postgres_data:/var/lib/postgresql postgres:18您可能已经注意到
POSTGRES_PASSWORD环境变量已被省略。这是因为该变量仅在新数据库初始化时使用。 -
通过运行以下命令验证数据库是否仍包含记录:
$ docker exec -ti new-db psql -U postgres -c "SELECT * FROM tasks"
查看卷内容
Docker Desktop 仪表板提供了查看任何卷内容的功能,以及导出、导入和克隆卷的功能。
-
打开 Docker Desktop 仪表板并导航到 Volumes 视图。在此视图中,您应该能看到 postgres_data 卷。
-
选择 postgres_data 卷的名称。
-
Data 选项卡显示卷的内容,并提供导航文件的功能。双击文件可以查看其内容并进行更改。
-
右键单击任何文件可以保存或删除它。
删除卷
在删除卷之前,必须确保它没有附加到任何容器。如果您尚未删除之前的容器,请使用以下命令(-f 会先停止容器,然后将其删除):
$ docker rm -f new-db
有多种方法可以删除卷,包括:
-
在 Docker Desktop 仪表板中选择卷上的 Delete Volume 选项。
-
使用
docker volume rm命令:$ docker volume rm postgres_data -
使用
docker volume prune命令删除所有未使用的卷:$ docker volume prune
其他资源
以下资源将帮助您进一步了解卷:
下一步
现在您已经了解了如何持久化容器数据,是时候学习如何与容器共享本地文件了。
与容器共享本地文件