Логически журнал WAL можно представить в виде непрерывного потока записей. Каждая запись имеет номер, называемый LSN (Log Sequence Number). Это 64-разрядное число - смещение записи в байтах относительно начала журнала.
Текущую позицию показывает функция pg_current_xlog_location:
=> SELECT pg_current_xlog_location();
pg_current_xlog_location -------------------------- D/37111578 (1 row)
Позиция записывается как два 32-разрядных числа через косую черту.
Запомним позицию в переменной psql:
=> SELECT pg_current_xlog_location() AS pos1 \gset
Выполним теперь какие-нибудь операции и посмотрим, как изменилась позиция.
=> CREATE TABLE t(n integer);
CREATE TABLE
=> INSERT INTO t SELECT gen.id FROM generate_series(1,1000) AS gen(id);
INSERT 0 1000
=> SELECT pg_current_xlog_location();
pg_current_xlog_location -------------------------- D/3713B08C (1 row)
=> SELECT pg_current_xlog_location() AS pos2 \gset
Удобно смотреть не на абсолютные числа, а на разницу в байтах:
=> SELECT :'pos2'::pg_lsn - :'pos1'::pg_lsn;
?column? ---------- 170772 (1 row)
Физически журнал хранится в файлах по 16 МБ в отдельном каталоге:
postgres$ ls -l -t $PGDATA/pg_xlog | head
total 770052 -rw------- 1 postgres postgres 16777216 июл 22 23:38 000000010000000D00000037 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000064 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D0000005A -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000052 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000060 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000063 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000065 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D00000051 -rw------- 1 postgres postgres 16777216 июл 22 23:26 000000010000000D0000005D
PostgreSQL удаляет файлы, не требующиеся для восстановления, по мере необходимости.
Конец демонстрации.