docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > Docker 部署 PostgreSQL

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

作者: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

参数说明:

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. 常用管理命令

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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文