当前位置: 首页 > article >正文

Docker Compose安装部署PostgreSQL数据库

以下是一个完整的 PostgreSQL Docker Compose 部署教程,包括配置和部署详细步骤。本文将指导您如何在 Linux 服务器上使用 Docker Compose 来部署 PostgreSQL,并将数据持久化到指定路径。

1. 环境准备

确保您的系统上已经安装了以下软件:

  • Docker:用于容器化应用程序。参考 Docker 官方文档 进行安装。
  • Docker Compose:用于定义和运行多容器 Docker 应用程序。参考 Docker Compose 官方文档 进行安装。

验证安装是否成功:

docker --version
docker-compose --version

2. 创建所需的目录

为了确保数据持久化存储,先创建工作目录和持久化数据目录。

执行以下命令:

# 创建工作目录
mkdir -p /opt/postgresql

# 创建持久化目录
mkdir -p /opt/docker-data/postgresql && chmod 777 /opt/docker-data/postgresql

说明

  • /opt/postgresql 是用于存放项目文件的工作目录。
  • /opt/docker-data/postgresql 是持久化 PostgreSQL 数据的目录,设置权限为 777 确保容器可以读写。

3. 创建 docker-compose.yml 文件

进入工作目录 /opt/postgresql,然后创建 docker-compose.yml 文件:

cd /opt/postgresql
touch docker-compose.yml

编辑 docker-compose.yml 文件,内容如下:

version: '3.8'

services:
  postgres:
    image: postgres:15                # 使用 PostgreSQL 15 镜像
    container_name: postgres_db       # 容器名称
    environment:
      POSTGRES_USER: root             # 设置用户名为 'root'
      POSTGRES_PASSWORD: 123456       # 设置密码为 '123456'
      POSTGRES_DB: demo               # 设置数据库名为 'demo'
    ports:
      - "5433:5432"                   # 将容器的 5432 端口映射到主机的 5433 端口
    volumes:
      - /opt/docker-data/postgresql:/var/lib/postgresql/data  # 数据映射到主机指定路径

volumes:
  postgres_data:

文件解释

  • services: 定义了 PostgreSQL 服务。
    • image: 使用官方 PostgreSQL 15 镜像。
    • container_name: 给容器命名为 postgres_db
    • environment: 设置数据库的环境变量,包括用户名、密码和默认数据库名称。
    • ports: 将容器的默认 PostgreSQL 端口 5432 映射到主机的 5433 端口。
    • volumes: 将容器的数据目录 /var/lib/postgresql/data 映射到主机的 /opt/docker-data/postgresql,实现数据持久化。

4. 启动 PostgreSQL 服务

docker-compose.yml 文件所在的目录中,执行以下命令来启动服务:

docker-compose up -d

说明

  • -d 选项表示以“后台模式”运行容器。
  • 此时,PostgreSQL 容器将启动,数据将持久化到 /opt/docker-data/postgresql 目录。

5. 验证 PostgreSQL 部署

检查容器状态:

docker-compose ps

您应该会看到类似如下的输出,表示 PostgreSQL 容器正在运行:

   Name                 Command               State         Ports
-------------------------------------------------------------------------
postgres_db     docker-entrypoint.sh postgres   Up      0.0.0.0:5433->5432/tcp

登录到 PostgreSQL 容器进行验证:

docker exec -it postgres_db psql -U root -d demo

命令解释

  • docker exec -it postgres_db:进入名为 postgres_db 的容器。
  • psql -U root -d demo:使用 root 用户登录到 demo 数据库。

6. 连接 PostgreSQL 数据库

您可以使用任意数据库客户端连接 PostgreSQL。连接参数如下:

  • 主机localhost 或 Docker 主机 IP
  • 端口5433
  • 用户名root
  • 密码123456
  • 数据库demo

示例命令行连接:

psql -h localhost -p 5433 -U root -d demo

7. 停止和删除 PostgreSQL 容器

如需停止和删除容器,可以执行以下命令:

docker-compose down

该命令将停止容器并删除网络配置,但不会删除持久化的数据(数据保存在 /opt/docker-data/postgresql 目录下)。

8. 备份与恢复数据

备份数据库

您可以使用以下命令来备份数据库:

docker exec -t postgres_db pg_dump -U root demo > /opt/docker-data/postgresql/backup.sql

恢复数据库

如果您需要从备份中恢复数据,可以执行以下命令:

docker exec -i postgres_db psql -U root -d demo < /opt/docker-data/postgresql/backup.sql

结束语

通过以上步骤,您已经成功使用 Docker Compose 部署了 PostgreSQL,并且数据已经持久化到指定的路径 /opt/docker-data/postgresql。这个部署方案方便了数据库的管理和备份,适合在开发和生产环境中使用。


http://www.kler.cn/a/405405.html

相关文章:

  • 【Python系列】浅析 Python 中的字典更新与应用场景
  • 输出第二个整数
  • 智能安全配电装置在高校实验室中的应用
  • C++ 中的移动语义
  • FileProvider高版本使用,跨进程传输文件
  • aws凭证(一)凭证存储
  • 工商银行湖仓智一体创新应用实践
  • 数据结构——栈、队列
  • GCN分类预测 | 基于图卷积神经网络GCN多特征分类预测(多输入单输出) Matlab代码
  • Rust 的简介
  • 应用监控——springboot admin
  • TypeScript 的发展与基本语法
  • docker搭建私有仓库,实现镜像的推送和拉取
  • 2024 APMCM亚太数学建模C题 - 宠物行业及相关产业的发展分析和策略 完整参考论文(2)
  • ffmpeg视频滤镜:替换部分帧-freezeframes
  • sql注入报错分享(mssql+mysql)
  • 《Spring Cloud 微服务》
  • 基于Spring Boot的同城宠物照看系统的设计与实现
  • 【040】基于51单片机语音导盲仪【Proteus仿真+Keil程序+报告+原理图】
  • 雷军产品论
  • openGauss 主备架构及同步复制模式理论学习与验证测试
  • C# 调用系统级方法复制、移动和删除问津
  • 自定义协议
  • Arcgis 地图制作
  • openharmony napi调试笔记
  • 科研深度学习:如何精选GPU以优化服务器性能