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"
相关推荐
明灯L4 小时前
《Kubernetes 集群搭建全指南:从核心概念到环境部署!》
云原生·容器·kubernetes
insight^tkk4 小时前
【Docker】记录一次使用docker部署dify网段冲突的问题
运维·人工智能·docker·ai·容器
江湖人称小鱼哥4 小时前
WSL + Docker 网络访问详解
网络·docker·容器·wsl
韩宏伟4 小时前
使用 Loki + Promtail + Grafana 实现 Docker 容器日志采集与可视化
docker·容器·grafana
荣光波比5 小时前
K8S(十五)—— 企业级K8s集群管理实践:Rancher安装配置与核心功能实操
容器·kubernetes·rancher
JanelSirry6 小时前
微服务是不是一定要容器化(如 Docker)?我该怎么选
docker·微服务·架构
小屁不止是运维6 小时前
k8s问题详解1:k8s集群上传文件过大导致413 Request Entity Too Large(请求文件实体过大)
docker·容器·kubernetes
聆风吟º7 小时前
无需 VNC / 公网 IP!用 Docker-Webtop+cpolar,在手机浏览器远程操控 Linux
linux·运维·docker
科技D人生7 小时前
物联网开发学习总结(5)—— 深入对比 TDengine、InfluxDB 和 TimescaleDB 三大主流时序数据库的性能表现
物联网·postgresql·时序数据库·influxdb·tdengine·timescaledb
ZLRRLZ7 小时前
【Docker】Docker镜像仓库
docker·容器