What is pg_drop_events?

The pg_drop_events is a PostgreSQL extension that logs transaction ids of drop table, drop column, drop materialized view statements to aid point in time recovery: To perform point in time recovery in case of a disaster whereby a table or a table column was mistakenly dropped, you simply specify the xact_id you get from the table pg_drop_events as the recovery_target_xid. See below user guide.

How pg_drop_events works?

pg_drop_events uses event trigger to track what statement, what transaction and which user drops a table or a table column.

Documentation

  1. Supported PostgreSQL Versions
  2. Installation
  3. Setup
  4. User Guide

Supported PostgreSQL Versions

The pg_drop_events should work on the latest version of PostgreSQL but is only tested with these PostgreSQL versions:

| Distribution | Version | Supported | | ————————|––––––––|––––––––––| | PostgreSQL | Version 9.5 | :heavy_check_mark: | | PostgreSQL | Version 9.6 | :heavy_check_mark: | | PostgreSQL | Version 10 | :heavy_check_mark: | | PostgreSQL | Version 11 | :heavy_check_mark: | | PostgreSQL | Version 12 | :heavy_check_mark: | | PostgreSQL | Version 13 | :heavy_check_mark: | | PostgreSQL | Version 14 | :heavy_check_mark: |

Installation

Installing from source code

You can download the source code of pg_drop_events from this GitHub page or using git:

git clone git@github.com:bolajiwahab/pg_drop_events.git

Compile and install the extension. Depending on your distribution, you might need to add sudo.

cd pg_drop_events
make clean && make install

Setup

Create the extension using the CREATE EXTENSION command.

CREATE EXTENSION pg_drop_events;
CREATE EXTENSION

User-Guide

This document describes the configuration, key features and usage of pg_drop_events extension.

For how to install and set up pg_drop_events, see README.

After you’ve installed, create the pg_drop_events extension using the CREATE EXTENSION command.

CREATE EXTENSION pg_drop_events;
CREATE EXTENSION

Usage

Example :

postgres=# CREATE SCHEMA t;
CREATE SCHEMA

postgres=# CREATE TABLE t.t1(a int);
CREATE TABLE

postgres=# CREATE TABLE t.t2();
CREATE TABLE

postgres=# CREATE TABLE t.t3();
CREATE TABLE

postgres=# DROP TABLE t.t3;
NOTICE:  table t.t3 dropped by transaction 1085.
DROP TABLE

postgres=# ALTER TABLE t.t1 DROP COLUMN a;
NOTICE:  table column t.t1.a dropped by transaction 1088.
ALTER TABLE

postgres=# DROP SCHEMA t CASCADE;
NOTICE:  drop cascades to 2 other objects
DETAIL:  drop cascades to table t.t2
drop cascades to table t.t1
NOTICE:  table t.t2 dropped by transaction 1089.
NOTICE:  table t.t1 dropped by transaction 1089.
DROP SCHEMA

postgres=# SELECT pid,username,query,xact_id,wal_position,object_name,object_type,xact_start FROM pg_drop_events;
  pid  | username |              query              | xact_id | wal_position | object_name | object_type  |          xact_start
-------+----------+---------------------------------+---------+--------------+-------------+--------------+-------------------------------
   729 | postgres | drop TABLE tab ;                |     884 | 2/7255F498   | public.tab  | table        | 2021-05-17 19:57:22.435495+08
 12540 | postgres | DROP TABLE t.t3;                |    1085 | 2/729E7920   | t.t3        | table        | 2021-05-17 20:49:21.727209+08
 12540 | postgres | ALTER TABLE t.t1 DROP COLUMN a; |    1088 | 2/729F7778   | t.t1.a      | table column | 2021-05-17 20:50:29.168078+08
 12540 | postgres | DROP SCHEMA t CASCADE;          |    1089 | 2/729F7988   | t.t2        | table        | 2021-05-17 20:51:10.929153+08
 12540 | postgres | DROP SCHEMA t CASCADE;          |    1089 | 2/729F7988   | t.t1        | table        | 2021-05-17 20:51:10.929153+08

Point in time recovery (PITR)

To perform point in time recovery, you need access to pg_drop_events data. We have this mapping of options and the respective PostgreSQL recovery options:

pg_drop_events.xact_id      => recovery_target_xid
pg_drop_events.time         => recovery_target_time
pg_drop_events.wal_position => recovery_target_lsn

For reference, see https://www.postgresql.org/docs/13/runtime-config-wal.html

Author

[Bolaji K. Wahab @bolajiwahab]

Copyright and License

Copyright (c) 2021 Bolaji Wahab.

This module is free software; you can redistribute it and/or modify it under the PostgreSQL License.

Permission to use, copy, modify, and distribute this software and its documentation for any purpose, without fee, and without a written agreement is hereby granted, provided that the above copyright notice and this paragraph and the following two paragraphs appear in all copies.

In no event shall Bolaji K. Wahab be liable to any party for direct, indirect, special, incidental, or consequential damages, including lost profits, arising out of the use of this software and its documentation, even if Bolaji K. Wahab has been advised of the possibility of such damage.

Bolaji K. Wahab specifically disclaims any warranties, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. The software provided hereunder is on an “as is” basis, and Bolaji K. Wahab has no obligations to provide maintenance, support, updates, enhancements, or modifications.