block_copy_command
通过可配置的 ProcessUtility hook 阻止 COPY 命令
仓库
rustwizard/block_copy_command
https://github.com/rustwizard/block_copy_command
源码
block_copy_command-0.1.5.tar.gz
block_copy_command-0.1.5.tar.gz
概览
| 扩展包名 | 版本 | 分类 | 许可证 | 语言 |
|---|---|---|---|---|
block_copy_command | 0.1.5 | SEC | BSD 3-Clause | Rust |
| ID | 扩展名 | Bin | Lib | Load | Create | Trust | Reloc | 模式 |
|---|---|---|---|---|---|---|---|---|
| 7405 | block_copy_command | 否 | 是 | 是 | 是 | 否 | 否 | - |
Requires shared_preload_libraries = block_copy_command.
版本
| 类型 | 仓库 | 版本 | PG 大版本 | 包名 | 依赖 |
|---|---|---|---|---|---|
| EXT | PIGSTY | 0.1.5 | 1817161514 | block_copy_command | - |
| RPM | PIGSTY | 0.1.5 | 1817161514 | block_copy_command_$v | - |
| DEB | PIGSTY | 0.1.5 | 1817161514 | postgresql-$v-block-copy-command | - |
构建
您可以使用 pig build 命令构建 block_copy_command 扩展的 RPM / DEB 包:
pig build pkg block_copy_command # 构建 RPM / DEB 包
安装
您可以直接安装 block_copy_command 扩展包的预置二进制包,首先确保 PGDG 和 PIGSTY 仓库已经添加并启用:
pig repo add pgsql -u # 添加仓库并更新缓存
使用 pig 或者是 apt/yum/dnf 安装扩展:
pig install block_copy_command; # 当前活跃 PG 版本安装
pig ext install -y block_copy_command -v 18 # PG 18
pig ext install -y block_copy_command -v 17 # PG 17
pig ext install -y block_copy_command -v 16 # PG 16
pig ext install -y block_copy_command -v 15 # PG 15
pig ext install -y block_copy_command -v 14 # PG 14
dnf install -y block_copy_command_18 # PG 18
dnf install -y block_copy_command_17 # PG 17
dnf install -y block_copy_command_16 # PG 16
dnf install -y block_copy_command_15 # PG 15
dnf install -y block_copy_command_14 # PG 14
apt install -y postgresql-18-block-copy-command # PG 18
apt install -y postgresql-17-block-copy-command # PG 17
apt install -y postgresql-16-block-copy-command # PG 16
apt install -y postgresql-15-block-copy-command # PG 15
apt install -y postgresql-14-block-copy-command # PG 14
预加载配置:
shared_preload_libraries = 'block_copy_command';
创建扩展:
CREATE EXTENSION block_copy_command;
用法
- 来源:README
block_copy_command 安装一个会拦截 COPY 语句的 ProcessUtility hook。库加载后,该 hook 在集群范围内生效;CREATE EXTENSION 只是在某个数据库中登记元数据。
启用扩展
shared_preload_libraries = 'block_copy_command'
CREATE EXTENSION block_copy_command;
阻断规则
默认情况下,非超级用户不能执行 COPY TO 或 COPY FROM:
COPY my_table TO STDOUT;
COPY my_table FROM STDIN;
COPY (SELECT * FROM my_table) TO '/tmp/out.csv';
文档中的优先级如下:
block_copy_command.blocked_roles:始终阻断,即使是超级用户。block_copy_command.block_program = on:对所有用户阻断COPY ... PROGRAM。block_copy_command.enabled = off:允许不在blocked_roles中的角色执行COPY。- 其他情况下,超级用户会绕过方向阻断。
block_copy_command.block_to和block_copy_command.block_from控制对非超级用户的导出/导入阻断。
主要配置
block_copy_command.enabled:非超级用户阻断的总开关。block_copy_command.block_to:阻断COPY TO。block_copy_command.block_from:阻断COPY FROM。block_copy_command.block_program:对所有用户阻断COPY TO/FROM PROGRAM。block_copy_command.hint:给被阻断命令的错误追加自定义HINT。block_copy_command.blocked_roles:逗号分隔的始终阻断角色列表。block_copy_command.audit_log_enabled:将拦截事件写入审计表。
审计与注意事项
允许和被阻断的尝试都会被拦截;扩展定义了 block_copy_command.audit_log,并会把被阻断事件写入服务器日志。README 提到一个重要限制:被阻断的审计行是在抛出错误前插入的,因此会随事务一起回滚。实际使用中,PostgreSQL 服务器日志才是被阻断 COPY 尝试的权威记录。