专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

layerxdocker/pg_partman_postgers Docker 镜像 - 轩辕镜像

pg_partman_postgers
layerxdocker/pg_partman_postgers
layerxdocker
基于PostgreSQL的Docker镜像,预安装并配置pg_partman扩展,用于自动化表分区的创建、维护和管理,简化时间序列数据等场景的分区操作,提升数据库性能。
0 次下载
📦 一套镜像服务,解决研发 / 测试 / 生产三套环境
中文简介版本下载
📦 一套镜像服务,解决研发 / 测试 / 生产三套环境

PostgreSQL with pg_partman 镜像文档

镜像概述

本镜像基于官方PostgreSQL镜像构建,预集成并配置了pg_partman扩展。pg_partman是一个PostgreSQL扩展,用于简化和自动化表分区的创建、维护与管理流程,特别适用于时间序列数据或需要按范围分区的场景,帮助用户减少手动分区操作,提升数据库性能和可维护性。

核心功能和特性

  • 预安装pg_partman扩展:基于官方PostgreSQL镜像,无需手动安装,开箱即可使用pg_partman功能。
  • 自动化分区管理:支持自动创建新分区(基于时间或数值范围)和自动清理旧分区,减少人工干预。
  • 多分区类型支持:兼容PostgreSQL原生分区功能,支持时间范围分区(如按天、月)和数值范围分区(如按ID范围)。
  • 灵活的分区策略:可配置分区间隔(如1小时、1个月)、保留策略(如保留最近3个月数据)、分区命名规则等。
  • 性能优化:通过分区减少单表数据量,提升查询效率,尤其适用于大数据量表的查询和维护。
  • 与PostgreSQL版本兼容:支持主流PostgreSQL版本(如12+),兼容原生分区语法和功能。

使用场景和适用范围

  • 时间序列数据存储:适用于监控指标、日志数据、传感器数据等按时间增长的海量数据场景。
  • 高性能查询需求:当数据库表数据量达到百万/千万级以上,需通过分区提升查询速度和索引效率。
  • 自动化运维场景:减少DBA手动创建/删除分区的操作成本,尤其适合需要定期维护分区的业务。
  • 合规性数据保留:需按要求自动保留指定时间段数据(如交易记录保留5年)的场景。

使用方法和配置说明

1. 镜像拉取

假设镜像已构建并推送到私有仓库或Docker Hub(实际使用时替换<image-name>为具体镜像名称):

bash
docker pull <image-name>:<tag>  # 示例:docker pull my-postgres-pgpartman:14
2. 环境变量配置
环境变量说明默认值
POSTGRES_DB初始化数据库名称postgres
POSTGRES_USER数据库管理员用户名postgres
POSTGRES_PASSWORD数据库管理员密码(必填)-
PGPARTMAN_PARTITION_TYPE分区类型:time(时间范围分区)或range(数值范围分区)time
PGPARTMAN_INTERVAL分区间隔(时间分区支持1min/1h/1d/1mon等;数值分区为整数)1d(按天分区)
PGPARTMAN_RETENTION数据保留策略(保留最近N个分区,0表示不自动删除)30(保留30个分区)
PGPARTMAN_SCHEMApg_partman元数据存储 schemapartman
3. Docker 部署示例
3.1 基础 docker run 命令
bash
docker run -d \
  --name postgres-pgpartman \
  -p 5432:5432 \
  -e POSTGRES_DB=myappdb \
  -e POSTGRES_USER=myuser \
  -e POSTGRES_PASSWORD=SecurePass123! \
  -e PGPARTMAN_PARTITION_TYPE=time \
  -e PGPARTMAN_INTERVAL=1d \
  -e PGPARTMAN_RETENTION=90 \
  -v postgres-data:/var/lib/postgresql/data \
  <image-name>:<tag>
3.2 Docker Compose 配置示例
yaml
version: '3.8'
services:
  postgres:
    image: <image-name>:<tag>
    container_name: postgres-pgpartman
    ports:
      - "5432:5432"
    environment:
      POSTGRES_DB: "metrics_db"
      POSTGRES_USER: "metrics_user"
      POSTGRES_PASSWORD: "MetricsPass456!"
      PGPARTMAN_PARTITION_TYPE: "time"
      PGPARTMAN_INTERVAL: "1h"  # 按小时分区
      PGPARTMAN_RETENTION: "720"  # 保留30天(720小时)数据
    volumes:
      - postgres-data:/var/lib/postgresql/data
    restart: unless-stopped

volumes:
  postgres-data:
4. 初始化分区表

容器启动后,需手动或通过初始化脚本创建分区表(以下为示例SQL,通过psql执行):

sql
-- 1. 切换到目标数据库
\c metrics_db

-- 2. 创建主表(需与pg_partman分区策略匹配)
CREATE TABLE metrics (
  time timestamp NOT NULL,
  metric_name text NOT NULL,
  value numeric NOT NULL
);

-- 3. 使用pg_partman创建分区(假设按time字段小时分区)
SELECT partman.create_parent(
  p_parent_table := 'public.metrics',
  p_control := 'time',  -- 分区控制字段
  p_type := 'time',     -- 分区类型(与环境变量一致)
  p_interval := '1 hour',  -- 分区间隔(与环境变量一致)
  p_retention := '720 hours'  -- 保留策略(与环境变量一致)
);
5. 验证分区配置
sql
-- 查看分区表结构
SELECT * FROM partman.show_partitions('public.metrics');

-- 查看pg_partman配置
SELECT * FROM partman.partition_config WHERE parent_table = 'public.metrics';

注意事项

  • 数据备份:分区表数据仍需通过PostgreSQL标准工具(如pg_dump)定期备份,避免数据丢失。
  • 版本兼容性:确保pg_partman版本与PostgreSQL版本匹配(参考pg_partman官方文档)。
  • 性能监控:分区操作(如自动创建/删除)可能影响数据库性能,建议在低峰期执行或调整pg_cron调度(如需定时任务)。
  • 权限管理:确保应用用户具有分区表的读写权限,以及对partman schema的访问权限。

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
layerxdocker/pg_partman_postgers
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.