Docker 部署 PostgreSQL数据库的两种方式

 更新时间:2025年07月03日 11:44:52   作者:liora6  
本文介绍了使用Docker部署PostgreSQL数据库的两种方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

1. 使用 docker命令部署

部署命令:

docker run --name dbname-postgres \
  -e POSTGRES_USER=postgres \
  -e POSTGRES_PASSWORD=postgrespwd \
  -e POSTGRES_DB=db-default \
  -p 5432:5432 \
  -v /path/to/data:/var/lib/postgresql/data \
  --restart always \
  -d postgres:latest

参数说明:

  • POSTGRES_USER: 设置数据库用户名(默认为 postgres)
  • POSTGRES_PASSWORD: 设置数据库密码
  • POSTGRES_DB: 设置默认数据库(默认为 POSTGRES_USER 的值)
  • -p 5432:5432: 将容器端口映射到主机端口,如果将主机端口改为5000,则为5000:5432
  • -v /path/to/data:/var/lib/postgresql/data: 数据持久化到主机目录
  • postgres:latest: 指定 PostgreSQL 版本为最新版本
  • postgres:13: 指定 PostgreSQL 版本为 13

2. 使用 Docker Compose 部署

创建 docker-compose.yml 文件:

# 指定 Docker Compose 文件格式版本
version: '3.8'
# 定义服务列表
services:
  # 定义 PostgreSQL 服务
  postgres:
    # 使用 PostgreSQL 官方镜像,版本13
    image: postgres:latest
    # 指定容器名称(如果不指定,Docker 会自动生成)
    container_name: db-postgres
    # 环境变量配置
    environment:
      # 设置 PostgreSQL 超级用户(默认为 postgres)
      POSTGRES_USER: postgres
      # 设置 PostgreSQL 超级用户密码(必须设置)
      POSTGRES_PASSWORD: postgrespwd
      # 设置默认创建的数据库名称(默认为 POSTGRES_USER 的值)
      POSTGRES_DB: db-default
    # 端口映射配置(主机端口:容器端口)
    ports:
      - "5432:5432"  # 将容器内部的5432端口映射到主机的5432端口
    # 数据卷配置(持久化数据)
    volumes:
      # 使用命名卷 postgres_data 挂载到容器中的数据库数据目录
      - postgres_data:/var/lib/postgresql/data
    # 容器重启策略
    restart: always  # 总是自动重启容器,无论退出状态如何
# 定义卷列表(用于数据持久化)
volumes:
  # 定义一个名为 postgres_data 的命名卷
  # Docker 会自动管理这个卷,确保数据库数据持久化
  # 即使容器被删除,数据也不会丢失
  postgres_data:

然后运行:

docker-compose up -d

3. 连接 PostgreSQL

容器运行后,可以通过以下方式连接:

  1. 从主机连接:
psql -h localhost -U myuser -d mydatabase
  1. 进入容器内部连接:
docker exec -it my-postgres psql -U myuser -d mydatabase

4. 常用管理命令

  • 查看运行中的容器:docker ps
  • 查看日志:docker logs my-postgres
  • 停止容器:docker stop my-postgres
  • 启动容器:docker start my-postgres
  • 删除容器:docker rm my-postgres(需要先停止)

5. 高级配置

如果需要自定义 PostgreSQL 配置,可以:

  1. 创建自定义配置文件 postgresql.conf
  2. 挂载到容器中:
-v /path/to/postgresql.conf:/etc/postgresql/postgresql.conf
  1. 启动时指定配置文件:
-e POSTGRES_CONFIG_FILE=/etc/postgresql/postgresql.conf

注意事项

  1. 数据持久化:务必使用卷或绑定挂载来持久化数据,否则容器删除后数据会丢失
  2. 安全性:不要使用弱密码,生产环境应考虑更复杂的安全配置
  3. 性能:对于生产环境,可能需要调整共享缓冲区等参数
  4. 备份:定期备份数据库数据

到此这篇关于Docker 部署 PostgreSQL 指南的文章就介绍到这了,更多相关Docker 部署 PostgreSQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • docker容器启动后添加端口映射

    docker容器启动后添加端口映射

    这篇文章主要介绍了docker容器启动后添加端口映射,,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • Docker创建自己的镜像与上传流程详解

    Docker创建自己的镜像与上传流程详解

    镜像也是 docker 的核心组件之一,镜像时容器运行的基础,容器是镜像运行后的形态。本文主要介绍Docker镜像的基本操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-09-09
  • 使用Docker+jenkins+python3环境搭建超详细教程

    使用Docker+jenkins+python3环境搭建超详细教程

    这篇文章主要介绍了使用Docker+jenkins+python3环境搭建超详细教程,本文通过多种方法结合示例代码给大家详细介绍,需要的朋友可以参考下
    2021-07-07
  • Docker学习笔记之Docker部署Java web系统

    Docker学习笔记之Docker部署Java web系统

    这篇文章主要介绍了Docker学习笔记之Docker部署Java web系统,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • 教你用100 行shell实现Docker详解

    教你用100 行shell实现Docker详解

    这篇文章主要为大家介绍了教你用100 行shell实现Docker详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Docker跨服务器通信Overlay解决方案(上)之 Consul单实例

    Docker跨服务器通信Overlay解决方案(上)之 Consul单实例

    这篇文章主要介绍了Docker跨服务器通信Overlay解决方案(上)之 Consul单实例,本文通过场景分析实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • Docker容器中查看Python版本的四种方法对比

    Docker容器中查看Python版本的四种方法对比

    在当今云原生和微服务架构盛行的时代,Docker 已成为应用部署和开发的标准工具,确保容器内 Python 环境的正确性至关重要,本文整理了四个Docker容器中查看Python版本的方法,希望对大家有所帮助
    2025-08-08
  • 基于docker安装mariadb配置过程解析

    基于docker安装mariadb配置过程解析

    这篇文章主要介绍了基于docker安装mariadb配置过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Docker中部署mysql服务的方法及遇到的坑

    Docker中部署mysql服务的方法及遇到的坑

    这篇文章主要介绍了Docker中部署mysql服务的方法及遇到的坑,本文是小编细心给大家收藏整理下来的,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • Docker本地镜像推送到阿里云的实现

    Docker本地镜像推送到阿里云的实现

    本文介绍了在阿里云上创建容器镜像服务实例,并将本地镜像推送到阿里云的镜像仓库,具有一定的参考价值,感兴趣的可以了解一下
    2024-12-12

最新评论