Archive logging not cleaning up pg_wal directory

Started by Justin Swanhart12 months ago4 messagesgeneral
Jump to latest
#1Justin Swanhart
greenlion@gmail.com

Hi,

I have the following in my postgresql.conf for archive logging:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && cp
%p /var/lib/postgresql/prod_archive_logs/%f'

This command is properly copying the log files to my archive directory but
they remain in the `pg_wal` directory after they are copied, consuming
hundreds of gigs of space. Am I supposed to create a cron job to clean out
the `pg_wal` directory periodically (keep only 1 day of logs I guess?)

I tried to use mv:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && mv
%p /var/lib/postgresql/prod_archive_logs/%f'

When I did this the archives were moved away to the archive directory but
when I tried to set up replication the server could not find the archived
log to replicate from so I changed it to "cp" and now have this problem.

What am I missing?

Regards,

--Justin

#2Laurenz Albe
laurenz.albe@cybertec.at
In reply to: Justin Swanhart (#1)
Re: Archive logging not cleaning up pg_wal directory

On Thu, 2025-04-10 at 08:28 -0400, Justin Swanhart wrote:

I have the following in my postgresql.conf for archive logging:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && cp %p /var/lib/postgresql/prod_archive_logs/%f'

This command is properly copying the log files to my archive directory but they remain in the `pg_wal`
directory after they are copied, consuming hundreds of gigs of space.  Am I supposed to create a cron
job to clean out the `pg_wal` directory periodically (keep only 1 day of logs I guess?)

I tried to use mv:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && mv %p /var/lib/postgresql/prod_archive_logs/%f'

When I did this the archives were moved away to the archive directory but when I tried to set up
replication the server could not find the archived log to replicate from so I changed it to "cp" and now have this problem.

What am I missing?

Something else is blocking WAL removal:
https://www.cybertec-postgresql.com/en/why-does-my-pg_wal-keep-growing/

Since you mention replication, my money is on a stale replication slot.

Yours,
Laurenz Albe

#3Ron
ronljohnsonjr@gmail.com
In reply to: Justin Swanhart (#1)
Re: Archive logging not cleaning up pg_wal directory

On Thu, Apr 10, 2025 at 8:29 AM Justin Swanhart <greenlion@gmail.com> wrote:

Hi,

I have the following in my postgresql.conf for archive logging:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && cp
%p /var/lib/postgresql/prod_archive_logs/%f'

This command is properly copying the log files to my archive directory but
they remain in the `pg_wal` directory after they are copied, consuming
hundreds of gigs of space. Am I supposed to create a cron job to clean out
the `pg_wal` directory periodically (keep only 1 day of logs I guess?)

No. Definitely not.

I tried to use mv:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f && mv
%p /var/lib/postgresql/prod_archive_logs/%f'

When I did this the archives were moved away to the archive directory but
when I tried to set up replication the server could not find the archived
log to replicate from so I changed it to "cp" and now have this problem.

What am I missing?

PG retains WAL files when it thinks it needs them. "Orphaned replication
slot" is the typical reason.

Maybe you tried to set up replication at some point in the past, but
then forgot to drop the slot?

--
Death to <Redacted>, and butter sauce.
Don't boil me, I'm still alive.
<Redacted> lobster!

#4Justin Swanhart
greenlion@gmail.com
In reply to: Laurenz Albe (#2)
Re: Archive logging not cleaning up pg_wal directory

Thank you very much. I had a stale replication slot. I removed it and the
logs were cleaned up immediately.

--Justin

On Thu, Apr 10, 2025 at 8:48 AM Laurenz Albe <laurenz.albe@cybertec.at>
wrote:

Show quoted text

On Thu, 2025-04-10 at 08:28 -0400, Justin Swanhart wrote:

I have the following in my postgresql.conf for archive logging:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f &&

cp %p /var/lib/postgresql/prod_archive_logs/%f'

This command is properly copying the log files to my archive directory

but they remain in the `pg_wal`

directory after they are copied, consuming hundreds of gigs of space.

Am I supposed to create a cron

job to clean out the `pg_wal` directory periodically (keep only 1 day of

logs I guess?)

I tried to use mv:
archive_command='test ! -f /var/lib/postgresql/prod_archive_logs/%f &&

mv %p /var/lib/postgresql/prod_archive_logs/%f'

When I did this the archives were moved away to the archive directory

but when I tried to set up

replication the server could not find the archived log to replicate from

so I changed it to "cp" and now have this problem.

What am I missing?

Something else is blocking WAL removal:
https://www.cybertec-postgresql.com/en/why-does-my-pg_wal-keep-growing/

Since you mention replication, my money is on a stale replication slot.

Yours,
Laurenz Albe