0

0

postgresql事件触发器如何用于审计_postgresql事件触发体系

舞夢輝影

舞夢輝影

发布时间:2025-12-03 21:10:02

|

813人浏览过

|

来源于php中文网

原创

PostgreSQL事件触发器用于审计DDL操作,通过创建日志表、编写触发函数并绑定到ddl_command_end或sql_drop事件,可记录结构变更;需注意其不捕获DML、可能受超级用户绕过及性能影响。

postgresql事件触发器如何用于审计_postgresql事件触发体系

PostgreSQL 事件触发器(Event Trigger)是一种特殊类型的触发器,它不绑定在具体表上,而是响应数据库级别的 DDL(数据定义语言)事件,例如 CREATEALTERDROP 等操作。这使得事件触发器非常适合用于审计数据库结构变更,实现对 PostgreSQL 事件触发体系的监控与记录。

事件触发器的基本原理

事件触发器由两部分组成:事件触发器函数和事件触发器本身。函数使用 PL/pgSQL 或其他过程语言编写,用于定义在特定事件发生时执行的操作;触发器则绑定到某一类事件上,如 ddl_command_startddl_command_endsql_drop

常见的事件包括:

  • ddl_command_start:在每个 DDL 命令开始执行前触发
  • ddl_command_end:在每个 DDL 命令成功执行后触发
  • sql_drop:在对象被删除时触发,可获取将被删除的对象信息

这些事件让管理员可以精确掌握谁在何时执行了何种结构变更,是构建审计系统的核心工具

使用事件触发器实现审计功能

要实现对 DDL 操作的审计,通常需要创建一个日志表来存储操作记录,并编写触发器函数将相关信息写入该表。

1. 创建审计日志表

CREATE TABLE ddl_audit_log (
    id SERIAL PRIMARY KEY,
    username TEXT,
    command_tag TEXT,
    object_type TEXT,
    object_name TEXT,
    event TEXT,
    sql_command TEXT,
    timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

2. 编写事件触发器函数

CREATE OR REPLACE FUNCTION log_ddl_events()
RETURNS event_trigger AS $$
DECLARE
    obj record;
BEGIN
    FOR obj IN SELECT * FROM pg_event_trigger_ddl_commands()
    LOOP
        INSERT INTO ddl_audit_log (
            username, command_tag, object_type,
            object_name, event, sql_command
        ) VALUES (
            current_user,
            obj.command_tag,
            obj.object_type,
            obj.object_identity,
            'ddl_command_end',
            current_query()
        );
    END LOOP;
END;
$$ LANGUAGE plpgsql;

这个函数通过调用 pg_event_trigger_ddl_commands() 获取当前 DDL 命令的详细信息,并插入到审计表中。

3. 创建事件触发器

多个迹象表明你还是PHP菜鸟
多个迹象表明你还是PHP菜鸟

我愿意把本文归入我的“编程糗事”系列。尽管在正规大学课程中,接触到软件工程、企业级软件架构和数据库设计,但我还是时不时地体会到下述事实带给我的“罪恶”感,当然,都是我的主观感受,并且面向Eclipse:   你是PHP菜鸟,如果你:   1. 不会利用如phpDoc这样的工具来恰当地注释你的代码   2. 对优秀的集成开发环境如Zend Studio或Eclipse PDT视而不见   3

下载
CREATE EVENT TRIGGER audit_ddl ON ddl_command_end
EXECUTE FUNCTION log_ddl_events();

这样,每次有 DDL 操作完成,就会自动记录到 ddl_audit_log 表中。

高级审计场景:捕获 DROP 操作

如果还需要记录被删除的对象(即使它们已不存在),可以结合 sql_drop 事件触发器使用。

示例:

CREATE OR REPLACE FUNCTION log_dropped_objects()
RETURNS event_trigger AS $$
DECLARE
    obj record;
BEGIN
    FOR obj IN SELECT * FROM pg_event_trigger_dropped_objects()
    LOOP
        INSERT INTO ddl_audit_log (
            username, command_tag, object_type,
            object_name, event
        ) VALUES (
            current_user,
            'DROP',
            obj.object_type,
            obj.object_identity,
            'sql_drop'
        );
    END LOOP;
END;
$$ LANGUAGE plpgsql;

CREATE EVENT TRIGGER audit_drop ON sql_drop EXECUTE FUNCTION log_dropped_objects();

该机制能确保即使对象已被删除,其删除行为仍可追溯。

注意事项与限制

使用事件触发器进行审计时需注意以下几点:

  • 事件触发器无法捕获 DML 操作(如 INSERT、UPDATE、DELETE),需使用常规行级或语句级触发器进行 DML 审计
  • 某些超级用户操作可能绕过触发器,需结合日志(log_statement = 'ddl')进行补充
  • 触发器函数运行在事务内部,若函数出错可能导致 DDL 失败,应确保其健壮性
  • 避免在触发器函数中执行复杂逻辑或远程调用,以免影响数据库性能

合理配置后,PostgreSQL 的事件触发体系能提供强大而灵活的结构变更审计能力,帮助组织满足合规要求并提升数据库安全性。

基本上就这些。

相关专题

更多
数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

269

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

210

2023.12.29

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

158

2023.10.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

973

2023.11.02

postgresql常用命令有哪些
postgresql常用命令有哪些

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。更详细的postgresql常用命令,大家可以访问下面的文章。

196

2023.11.16

postgresql常用命令介绍
postgresql常用命令介绍

postgresql常用命令有l、d、d5、di、ds、dv、df、dn、db、dg、dp、c、pset、show search_path、ALTER TABLE、INSERT INTO、UPDATE、DELETE FROM、SELECT等。想了解更多postgresql的相关内容,可以阅读本专题下面的文章。

268

2023.11.20

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

351

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2075

2023.08.14

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

52

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.7万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号