Docker 运行 PolarDB-for-PostgreSQL 的命令,并已包含数据持久化配置

拉取官方 Docker 镜像

从 Docker Hub 拉取 PolarDB-for-PostgreSQL 的官方镜像。

bash 复制代码
docker pull polardb/polardb_pg_local_instance

如果无法拉去使用本人的阿里云的

x86架构

bash 复制代码
docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/polardb_pg_local_instance:latest

ARM架构的

bash 复制代码
docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/linux_arm64_polardb_pg_local_instance:latest
bash 复制代码
docker run -d \
    --name polardb_pg_prod \
    --restart=unless-stopped \
    --cpus=4 \
    --memory=8g \
    --memory-swap=9g \
    --shm-size=1g \
    -p 32682:5432 \
    -e LANG=C.UTF-8 \
    -e TZ=Asia/Shanghai \
    -e POSTGRES_USER=polardb_admin \
    -e POSTGRES_PASSWORD=JmpBqVaqky2auE9k \
    -e POSTGRES_DB=polardb_prod \
    -v /data/polardb/data:/var/lib/postgresql/data \
    -v /data/polardb/backups:/backups \
    -v /data/polardb/conf:/etc/postgresql \
    -v /etc/localtime:/etc/localtime:ro \
    --health-cmd="pg_isready -U polardb_admin" \
    --health-interval=30s \
    --health-timeout=10s \
    --health-retries=3 \
    registry.cn-hangzhou.aliyuncs.com/qiluo-images/polardb_pg_local_instance:latest

生产环境增强配置说明:

资源限制:

--cpus=4:限制容器使用最多 4 个 CPU 核心

--memory=8g:限制容器使用最大 8GB 内存

--memory-swap=9g:设置交换分区大小

--shm-size=1g:增加共享内存大小,对 PostgreSQL 性能很重要

自动重启:

--restart=unless-stopped:Docker 守护进程重启时自动重启容器,除非手动停止

安全认证:

-e POSTGRES_PASSWORD=JmpBqVaqky2auE9k:务必修改为强密码

-e POSTGRES_USER=polardb_admin:创建指定管理员用户

-e POSTGRES_DB=polardb_prod:创建指定数据库

多卷挂载:

-v /data/polardb/data:/var/lib/postgresql/data:主数据目录

-v /data/polardb/backups:/backups:备份目录

-v /data/polardb/conf:/etc/postgresql:配置文件目录(方便自定义配置)

-v /etc/localtime:/etc/localtime:ro:保持容器时间与主机同步

健康检查:

--health-cmd 等参数:配置容器健康检查,便于监控和自动恢复

连接示例:

使用 psql 连接

bash 复制代码
psql -h localhost -p 32682 -U polardb_admin -d polardb_prod

或者使用连接字符串

bash 复制代码
psql "postgresql://polardb_admin:JmpBqVaqky2auE9k @localhost:32682/polardb_prod"
相关推荐
运维全栈笔记7 小时前
K8S部署Redis高可用全攻略:1主2从3哨兵架构实战
redis·docker·云原生·容器·架构·kubernetes·bootstrap
审判长烧鸡8 小时前
PostgreSQL之索引/函数/触发器
数据库·postgresql·触发器·函数·索引
SCBAiotAigc9 小时前
2026.5.1:`DockerDesktop must be owned by an elevated account`错误的解决办法
人工智能·docker·具身智能
AI木马人10 小时前
9.人工智能实战:GPU 服务如何上 Kubernetes?从单机部署到 K8s + NVIDIA Device Plugin + HPA 的生产级改造
人工智能·容器·kubernetes
of Watermelon League11 小时前
5、使用 pgAdmin4 图形化创建和管理 PostgreSQL 数据库
数据库·postgresql
Dontla12 小时前
Python asyncpg库介绍(基于Python asyncio的PostgreSQL数据库驱动)连接池、SQLAlchemy
数据库·python·postgresql
张~颜12 小时前
PostgreSQL数据压缩技术
数据库·postgresql
身如柳絮随风扬16 小时前
使用 Docker 部署禅道并实现自动化部署——从项目搭建到运维自动化的完整指南
运维·docker·自动化
eRTE XFUN17 小时前
docker下搭建redis集群
redis·docker·容器
一只小bit18 小时前
Docker 存储卷:本地文件与容器内部文件建立绑定关系
运维·docker·容器