gpt4 book ai didi

postgresql - 我如何在docker中备份数据库

转载 作者:IT老高 更新时间:2023-10-28 12:42:09 25 4
gpt4 key购买 nike

我正在使用带有以下 yml 文件的 docker-compose 运行我的应用程序

  postgres:
container_name: postgres
image: postgres:${POSTGRES_VERSION}
volumes:
- postgresdata:/var/lib/postgresql/data
expose:
- "5432"
environment:
- POSTGRES_DB=42EXP
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}

node:
container_name: node
links:
- postgres:postgres
depends_on:
- postgres

volumes:
postgresdata:

正如您在此处看到的,我正在使用 命名卷 来管理 postgres 状态。

根据官方文档,我可以像下面这样备份一个卷

docker run --rm --volumes postgresdata:/var/lib/postgresql/data -v $(pwd):/backup ubuntu tar cvf /backup/backup.tar /dbdata

其他一些教程建议我使用 postgres 提供的 pg-dump 功能进行备份。

pg_dump -Fc database_name_here > database.bak

我想我必须进入 postgres 容器内才能执行此功能并将备份目录挂载到主机。

一种方法比另一种更好/更可取吗?

最佳答案

要运行 pg_dump,你可以使用 docker exec命令:

备份:

docker exec -u <your_postgres_user> <postgres_container_name> pg_dump -Fc <database_name_here> > db.dump

删除数据库(不要在生产环境中这样做,仅用于测试目的!!!):

docker exec -u <your_postgres_user> <postgres_container_name> psql -c 'DROP DATABASE <your_db_name>'

要恢复:

docker exec -i -u <your_postgres_user> <postgres_container_name> pg_restore -C -d postgres < db.dump

您也可以使用 docker-compose 类似的 exec。在这种情况下,您可以使用短服务名称 (postgres) 而不是完整的容器名称 (composeproject_postgres)。

docker exec

docker-compose exec

pg_restore

关于postgresql - 我如何在docker中备份数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39210274/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com