This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the databases category.
Last Updated: 2025-01-18
Web apps that interact with postgres (or other DBs) often have the ability to log their interactions with whatever database they use. But sometimes this isn't sufficient (or you might distrust its perspective) and you want to check how the picture appears from the database's point of view.
How can one do this, given that the database is usually a daemon?
On macos:
tail -f /usr/local/var/log/postgres.log
Note that you probably will not see the queries in the logs at first. This is
because you need to change log_statement = 'all'
in the postgres.conf
file, which is
located in the same directory as I gave for the data argument (-D
) above.
The default for log_statement
is none
which means it won't log many of your
SQL statements.
postgres -D /usr/local/var/postgres
runs postgres in the foreground. This can
be useful is you're using something like foreman
to run all processes related
to your system via one parent process with unified logging.
This provides the advantages of option 2, but without the need to mess with your postgres daemon (e.g. switching it off) and potentially intefering with other programs on your machine.
On macos:
log_level=info
process_name=postgres
log stream --$log_level --predicate "process == '$process_name'"