Docker27.3.1中安装 PostgreSQL16的实现步骤

 更新时间:2025年07月28日 09:00:13   作者:吴启维  
本文主要介绍了Docker27.3.1中安装 PostgreSQL16的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言:为什么在 Docker 中部署 PostgreSQL?

在云原生时代,容器化部署已成为生产环境的首选方案。通过 Docker 部署 PostgreSQL 具有以下显著优势:

  • 环境一致性:消除“在我机器上能运行”的问题
  • 快速部署:秒级启动数据库实例
  • 资源隔离:精确控制 CPU、内存等资源
  • 简化运维:版本升级、备份恢复更便捷
  • 高可移植性:轻松迁移到任何支持 Docker 的环境

本文将以 Docker 27.3.1PostgreSQL 16 为例,手把手教你完成部署。

一、环境准备

1. 确认 Docker 版本

docker --version
# Docker version 27.3.1, build a224086

💡 提示:如版本低于27.0,请先升级:官方升级指南

2. 创建专用网络(生产环境必备)

docker network create pg-network

作用

  • 隔离数据库流量
  • 避免端口冲突
  • 方便后续扩展(如连接应用容器)

二、PostgreSQL 16 容器化部署

1. 拉取官方镜像(指定版本)

docker pull postgres:16

为什么指定版本?

  • 避免自动升级导致兼容性问题
  • 确保生产环境稳定性
  • PostgreSQL 16 是最新LTS版本(支持至2031年)

2. 创建持久化数据卷

docker volume create pgdata

生产环境重要性

  • 容器重启/删除时数据不丢失
  • 独立于容器生命周期管理
  • 方便备份迁移

3. 启动 PostgreSQL 容器(生产优化版)

docker run -d \
  --name prod-postgres \
  --network pg-network \
  -p 5432:5432 \
  -e POSTGRES_PASSWORD=Str0ngP@ss!2025 \
  -e POSTGRES_USER=prod_admin \
  -e POSTGRES_DB=production_db \
  -e TZ=Asia/Shanghai \
  -e POSTGRES_INITDB_ARGS="--data-checksums" \
  -v pgdata:/var/lib/postgresql/data \
  -v /etc/localtime:/etc/localtime:ro \
  --restart=unless-stopped \
  --memory=4g \
  --cpus=2 \
  --health-cmd="pg_isready -U prod_admin" \
  --health-interval=30s \
  --health-timeout=5s \
  --health-retries=3 \
  postgres:16 \
  -c max_connections=200 \
  -c shared_buffers=1GB

参数详解

参数说明生产环境重要性
--network pg-network加入专用网络⭐⭐⭐⭐⭐ 网络安全隔离
-e POSTGRES_PASSWORD管理员密码⭐⭐⭐⭐⭐ 必须使用强密码
-e TZ=Asia/Shanghai设置时区⭐⭐⭐⭐ 避免时间相关错误
-v pgdata:/var/...挂载数据卷⭐⭐⭐⭐⭐ 数据持久化
--restart=unless-stopped自动重启策略⭐⭐⭐⭐ 高可用保障
--memory=4g --cpus=2资源限制⭐⭐⭐⭐ 防止单容器耗尽资源
--health-cmd健康检查⭐⭐⭐ 自动故障检测
-c max_connections=200最大连接数⭐⭐⭐ 根据业务需求调整
-c shared_buffers=1GB共享内存大小⭐⭐⭐ 性能优化关键参数

三、验证与连接

1. 检查容器状态

docker ps --format "table {{.ID}}\t{{.Names}}\t{{.Status}}\t{{.Ports}}"

预期输出

CONTAINER ID  NAMES          STATUS                    PORTS
a1b2c3d4e5f6  prod-postgres  Up 2 minutes (healthy)   0.0.0.0:5432->5432/tcp

2. 查看实时日志

docker logs -f prod-postgres

关键日志确认

PostgreSQL init process complete; ready for start up
database system is ready to accept connections

3. 命令行连接测试

docker exec -it prod-postgres \
  psql -U prod_admin -d production_db -c "SELECT version();"

预期输出

PostgreSQL 16.3 on x86_64-pc-linux-gnu, compiled by gcc...

4. 客户端工具连接

使用 DBeaver/pgAdmin 连接:

  • Host: 服务器IP
  • Port: 5432
  • Database: production_db
  • Username: prod_admin
  • Password: Str0ngP@ss!2025

四、生产环境高级配置

1. 配置文件自定义

# 创建配置目录
mkdir -p /docker/pg-config

# 生成默认配置
docker run --rm postgres:16 \
  cat /usr/share/postgresql/postgresql.conf.sample > /docker/pg-config/postgresql.conf

# 编辑配置文件(优化关键参数)
nano /docker/pg-config/postgresql.conf

关键参数建议

listen_addresses = '*'  # 允许所有网络接口
max_connections = 250   # 根据实际负载调整
shared_buffers = 1GB    # 建议分配内存的25%
work_mem = 16MB         # 每个操作的内存
maintenance_work_mem = 512MB  # 维护操作内存
synchronous_commit = off  # 异步提交提升性能

重新启动容器

docker run ... \
  -v /docker/pg-config/postgresql.conf:/etc/postgresql/postgresql.conf \
  postgres:16 -c 'config_file=/etc/postgresql/postgresql.conf'

2. 定期备份方案

创建备份脚本 (pg-backup.sh):

#!/bin/bash
BACKUP_DIR=/backups/pg
DATE=$(date +%Y%m%d_%H%M%S)

docker exec prod-postgres \
  pg_dump -U prod_admin -Fc production_db > $BACKUP_DIR/prod_db_$DATE.dump

# 保留最近7天备份
find $BACKUP_DIR -mtime +7 -delete

设置定时任务

crontab -e
# 每天凌晨2点备份
0 2 * * * /path/to/pg-backup.sh

3. 监控配置

使用内置统计收集器:

ALTER SYSTEM SET track_activities = on;
ALTER SYSTEM SET track_counts = on;
ALTER SYSTEM SET track_io_timing = on;
SELECT pg_reload_conf();

推荐监控工具:

  • Prometheus + Grafana(配合 postgres_exporter)
  • pgAdmin 4 监控面板
  • Datadog / New Relic

五、故障排查与维护

1. 常见问题解决

问题1:端口冲突

# 检查占用5432端口的进程
sudo lsof -i :5432

# 解决方案:改用其他端口
docker run ... -p 5433:5432 ...

问题2:忘记管理员密码

# 进入容器bash
docker exec -it prod-postgres bash

# 以postgres用户连接
psql -U postgres

# 重置密码
ALTER USER prod_admin WITH PASSWORD 'NewStrongP@ss!2025';

问题3:磁盘空间不足

# 查看容器磁盘使用
docker system df

# 清理无用容器/镜像
docker system prune -f

# 扩展数据卷
docker volume inspect pgdata # 找到实际路径
# 然后扩展对应磁盘分区

2. 关键维护命令

查看资源使用

docker stats prod-postgres

进入维护模式

docker exec -it prod-postgres bash
psql -U prod_admin -d production_db

日志分析

docker logs --tail 100 prod-postgres | grep -i error

六、安全加固建议

网络层安全

# 限制访问IP(仅允许应用服务器)
docker network create --subnet=10.1.0.0/16 pg-secure-network

SSL加密连接

# 启动容器时添加SSL参数
-e POSTGRES_SSL=on \
-e POSTGRES_SSL_CERT_FILE=/etc/ssl/certs/server.crt \
-e POSTGRES_SSL_KEY_FILE=/etc/ssl/private/server.key

定期轮换凭证

# 每月更新密码
ALTER USER prod_admin WITH PASSWORD 'NewP@ssw0rd_$(date +%Y%m)';

审计日志

ALTER SYSTEM SET log_statement = 'all';
SELECT pg_reload_conf();

结语:容器化数据库的未来

通过 Docker 部署 PostgreSQL 不仅简化了运维流程,还为现代化应用架构提供了坚实基础。

到此这篇关于Docker27.3.1中安装 PostgreSQL16的实现步骤的文章就介绍到这了,更多相关Docker 安装 PostgreSQL16内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • docker 搭建单机PostgreSQL操作详解

    docker 搭建单机PostgreSQL操作详解

    本文通过实际案例操作演示了如何基于Docker搭建pg的完整过程,并补充了pg数据库操作的常用命令和授权命令,感兴趣的朋友一起看看吧
    2025-04-04
  • ES和Kibana如何设置账号密码

    ES和Kibana如何设置账号密码

    设置Elasticsearch和Kibana账号密码需进入容器修改配置文件,重启服务后访问时输入凭证,Elasticsearch需设置elastic等六种账户密码,Kibana通过配置文件启用安全功能
    2025-07-07
  • 常用的8个应用和中间件的Docker运行示例详解

    常用的8个应用和中间件的Docker运行示例详解

    Portainer是一个轻量级的管理 UI ,可让你轻松管理不同的 Docker 环境(Docker 主机或 Swarm 群集),这篇文章主要介绍了常用的8个应用和中间件的Docker运行示例,需要的朋友可以参考下
    2024-03-03
  • Windows Server 2016中文版安装docker的详细步骤

    Windows Server 2016中文版安装docker的详细步骤

    因业务需要所以需要安装Docker,但是在途中遇到了一些问题,所以下面这篇文章主要给大家介绍了关于Windows Server 2016中文版安装docker的详细步骤,需要的朋友可以参考下
    2022-07-07
  • Docker Compose如何编排多个容器

    Docker Compose如何编排多个容器

    使用Docker Compose编排多个容器是一种简单而强大的方式,可以在单个文件中定义、配置和管理多个容器,本文主要介绍了Docker Compose如何编排多个容器,感兴趣的可以了解一下
    2023-11-11
  • 使用Docker完成前端部署详细图文教程

    使用Docker完成前端部署详细图文教程

    这篇文章主要给大家介绍了关于使用Docker完成前端部署的相关资料,Docker变得越来越流行,它可以轻便灵活地隔离环境,进行扩容,运维管理,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-09-09
  • 解决docker日志挂载的问题

    解决docker日志挂载的问题

    这篇文章主要介绍了解决docker日志挂载的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Docker安装MySQL集群全过程(主从复制)

    Docker安装MySQL集群全过程(主从复制)

    本文介绍通过Docker实现数据库主从集群部署,涵盖网络创建、my.cnf配置、复制设置及测试,解决防火墙等常见问题,确保数据同步可靠
    2025-07-07
  • ubuntu 14.04 64位安装配置docker教程

    ubuntu 14.04 64位安装配置docker教程

    这篇文章主要为大家详细介绍了ubuntu 14.04 64位安装配置docker教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • 使用Docker Swarm 搭建Wordpress的方法

    使用Docker Swarm 搭建Wordpress的方法

    这篇文章主要介绍了使用Docker Swarm 搭建Wordpress的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05

最新评论