BUG #17538: Dynamically updating log_hostname not affect the disconnection log - Mailing list pgsql-bugs

From PG Bug reporting form
Subject BUG #17538: Dynamically updating log_hostname not affect the disconnection log
Date
Msg-id 17538-74a88f3ab5b55670@postgresql.org
Whole thread Raw
Responses Re: BUG #17538: Dynamically updating log_hostname not affect the disconnection log  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-bugs
The following bug has been logged on the website:

Bug reference:      17538
Logged by:          Parachute Parachute
Email address:      teng_wang13@163.com
PostgreSQL version: 14.2
Operating system:   Ubuntu 18.04
Description:

As per the manual,
log_hostname (boolean)
By default, connection log messages only show the IP address of the
connecting host. Turning this parameter on causes logging of the host name
as well. 

The parameter could be updated on the fly. However, dynamically updating
log_hostname did not affect the disconnection log. I start up Postgres
server with log_hostname set 'no', which means not logging of the host name
in connection log. Then I connected to Postgres with root 'wang' using:

> ./psql -U wang -h localhost -p 5432

In the logfile, connection log messages only show the IP address (127.0.0.1)
of the connecting host, rather than the host name (localhost).

Then, I update log_hostname to 'yes' in postgresql.conf, and send SIGHUP
signal to reload configuration files.

I saw the logs showing the parameter was updated:
2022-07-03 10:50:54.477 UTC [5955] LOG:  received SIGHUP, reloading
configuration files
2022-07-03 10:50:54.478 UTC [5955] LOG:  parameter "log_hostname" changed to
"yes"

After I disconnected to Postgres, connection log messages kept showing the
IP address (127.0.0.1), which expected to show the host name (localhost).
This means updating log_hostname did not take effect.



The full logfile:

2022-07-03 10:49:08.191 UTC [5955] LOG:  database system is ready to accept
connections
2022-07-03 10:50:08.905 UTC [5972] LOG:  connection received: host=127.0.0.1
port=37828
2022-07-03 10:50:08.905 UTC [5972] LOG:  connection authorized: user=wang
database=wang application_name=psql
2022-07-03 10:50:54.477 UTC [5955] LOG:  received SIGHUP, reloading
configuration files
2022-07-03 10:50:54.478 UTC [5955] LOG:  parameter "log_hostname" changed to
"yes"
2022-07-03 10:51:24.416 UTC [5972] LOG:  disconnection: session time:
0:01:15.510 user=wang database=wang host=127.0.0.1 port=37828



**Suggest to fix:
in src/backend/tcop/postgres.c
static void log_disconnections(int code, Datum arg),

update 'port->remote_host' based on log_hostname as the method
BackendInitialize(Port *port) does.


pgsql-bugs by date:

Previous
From: PG Bug reporting form
Date:
Subject: BUG #17537: Dynamically updating statement_timeout not affect the insert query right now.
Next
From: Tom Lane
Date:
Subject: Re: BUG #17537: Dynamically updating statement_timeout not affect the insert query right now.