pgclone
在不同环境间克隆 PostgreSQL 数据库、模式、表和函数
概览
| 扩展包名 | 版本 | 分类 | 许可证 | 语言 |
|---|---|---|---|---|
pgclone | 4.3.2 | ETL | PostgreSQL | C |
| ID | 扩展名 | Bin | Lib | Load | Create | Trust | Reloc | 模式 |
|---|---|---|---|---|---|---|---|---|
| 9590 | pgclone | 否 | 是 | 是 | 是 | 否 | 否 | - |
| 相关扩展 | db_migrator pglogical repmgr pgactive |
|---|
preload for async/progress
版本
| 类型 | 仓库 | 版本 | PG 大版本 | 包名 | 依赖 |
|---|---|---|---|---|---|
| EXT | PIGSTY | 4.3.2 | 1817161514 | pgclone | - |
| RPM | PIGSTY | 4.3.2 | 1817161514 | pgclone_$v | - |
| DEB | PIGSTY | 4.3.2 | 1817161514 | postgresql-$v-pgclone | - |
构建
您可以使用 pig build 命令构建 pgclone 扩展的 RPM / DEB 包:
pig build pkg pgclone # 构建 RPM / DEB 包
安装
您可以直接安装 pgclone 扩展包的预置二进制包,首先确保 PGDG 和 PIGSTY 仓库已经添加并启用:
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 支持
columns、where、conflict,以及indexes、constraints、triggers等对象开关。 - 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_view、pgclone.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}退出一致快照模式。