pgclone

在不同环境间克隆 PostgreSQL 数据库、模式、表和函数

概览

扩展包名版本分类许可证语言
pgclone4.3.2ETLPostgreSQLC
ID扩展名BinLibLoadCreateTrustReloc模式
9590pgclone-
相关扩展db_migrator pglogical repmgr pgactive

preload for async/progress

版本

类型仓库版本PG 大版本包名依赖
EXTPIGSTY4.3.21817161514pgclone-
RPMPIGSTY4.3.21817161514pgclone_$v-
DEBPIGSTY4.3.21817161514postgresql-$v-pgclone-
OS / PGPG18PG17PG16PG15PG14
el8.x86_64
el8.aarch64
el9.x86_64
el9.aarch64
el10.x86_64
el10.aarch64
d12.x86_64
d12.aarch64
d13.x86_64
d13.aarch64
u22.x86_64
u22.aarch64
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
u24.x86_64
u24.aarch64
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
PIGSTY 4.3.2
u26.x86_64
u26.aarch64

构建

您可以使用 pig build 命令构建 pgclone 扩展的 RPM / DEB 包:

pig build pkg pgclone         # 构建 RPM / DEB 包

安装

您可以直接安装 pgclone 扩展包的预置二进制包,首先确保 PGDGPIGSTY 仓库已经添加并启用:

pig repo add pgsql -u          # 添加仓库并更新缓存

使用 pig 或者是 apt/yum/dnf 安装扩展:

pig install pgclone;          # 当前活跃 PG 版本安装
pig ext install -y pgclone -v 18  # PG 18
pig ext install -y pgclone -v 17  # PG 17
pig ext install -y pgclone -v 16  # PG 16
pig ext install -y pgclone -v 15  # PG 15
pig ext install -y pgclone -v 14  # PG 14
dnf install -y pgclone_18       # PG 18
dnf install -y pgclone_17       # PG 17
dnf install -y pgclone_16       # PG 16
dnf install -y pgclone_15       # PG 15
dnf install -y pgclone_14       # PG 14
apt install -y postgresql-18-pgclone   # PG 18
apt install -y postgresql-17-pgclone   # PG 17
apt install -y postgresql-16-pgclone   # PG 16
apt install -y postgresql-15-pgclone   # PG 15
apt install -y postgresql-14-pgclone   # PG 14

预加载配置

shared_preload_libraries = 'pgclone';

创建扩展

CREATE EXTENSION pgclone;

用法

来源:README, Usage guide, Async guide, Release v4.3.2, changelog, SQL install script

pgclone 可直接从 SQL 克隆表、schema、函数、角色和整个数据库。在 v4.x 中,公共 API 位于 pgclone schema 下;上游和 Pigsty 当前都跟踪 PostgreSQL 14-18。

核心克隆函数

CREATE EXTENSION pgclone;
SELECT pgclone.version();

SELECT pgclone.table(
  'host=source-server dbname=mydb user=postgres password=secret',
  'public',
  'customers',
  true
);

SELECT pgclone.schema(
  'host=source-server dbname=mydb user=postgres password=secret',
  'sales',
  true
);

SELECT pgclone.database(
  'host=source-server dbname=mydb user=postgres password=secret',
  true
);
  • pgclone.table(...)pgclone.schema(...)pgclone.functions(...)pgclone.database(...)
  • pgclone.database_create(...) 会创建本地目标数据库并克隆进去。
  • _ex 变体暴露显式布尔参数,用于控制 indexes、constraints 和 triggers。

选项与 masking

  • JSON options 支持 columnswhereconflict,以及 indexesconstraintstriggers 等对象开关。
  • JSON options 也包含 consistent;v4.3.0+ 默认使用跨表一致快照,并可通过 {"consistent": false} 按调用禁用。
  • 上游 usage guide 记录了 masking、敏感列自动发现、static masking、dynamic masking、clone verification,以及 GDPR/compliance reporting。
SELECT pgclone.table(
  'host=source-server dbname=mydb user=postgres',
  'public', 'users', true, 'users_lite',
  '{"columns":["id","name","email"],"where":"status = ''active''"}'
);

一致性、diff 与 preflight

SELECT pgclone.diff(
  'host=source-server dbname=prod user=postgres',
  'app_schema'
)::jsonb;

SELECT pgclone.preflight(
  'host=source-server dbname=prod user=postgres',
  'app_schema'
)::jsonb;
  • pgclone.diff(conninfo, schema) 会报告只读 DDL drift,覆盖 tables、columns、indexes、constraints、triggers、views 和 sequences。
  • pgclone.preflight(conninfo, schema) 会在 clone 前检查 source 和 target 就绪状态,包括 connection、version、permission、capacity、naming-conflict、missing-role、missing-extension 和 tablespace 问题。
  • v4.3.0+ clone 默认在 source 上以 REPEATABLE READ READ ONLY 读取。多连接 schema、database 和 parallel-pool clones 共享一个 exported snapshot,从而在 live source 写入期间保持 parent/child 一致性。
  • 长时间 clone 会在 source 保持事务打开,可能延迟 vacuum cleanup 和 WAL recycling;当该代价比跨表一致性更重要时,可使用 {"consistent": false}

异步与进度

-- postgresql.conf
shared_preload_libraries = 'pgclone'

SELECT pgclone.schema_async(
  'host=source-server dbname=mydb user=postgres',
  'sales', true, '{"parallel":4}'
);

SELECT * FROM pgclone.jobs_view;
SELECT pgclone.progress(1);
SELECT pgclone.cancel(1);
  • pgclone.table_async(...)pgclone.schema_async(...) 在 background workers 中运行。
  • pgclone.jobs_viewpgclone.progress_detail()pgclone.resume()pgclone.clear_jobs() 提供任务跟踪和恢复。
  • v4.3.2 将 snapshot-keeper resilience fixes 移植到 async/background-worker 路径,包括 keepalive injection 和面向网络 source connection 的 timeout protection。

注意事项

  • 上游要求 PostgreSQL 14+。
  • usage guide 说明安装和使用该扩展需要 superuser 权限。
  • 异步功能需要 shared_preload_libraries = 'pgclone';worker-pool parallelism 也依赖 max_worker_processes
  • 若必须绕过 source-side snapshot 问题,一致性异步 clone 仍可使用 {"consistent": false} 退出一致快照模式。

最后修改 2026-05-18: routine extension update (ac43610)