mirror of
https://github.com/postgres/postgres.git
synced 2025-06-26 12:21:12 +03:00
In libpq for Windows, call WSAStartup once and WSACleanup not at all.
The Windows documentation insists that every WSAStartup call should have a matching WSACleanup call. However, if that ever had actual relevance, it wasn't in this century. Every remotely-modern Windows kernel is capable of cleaning up when a process exits without doing that, and must be so to avoid resource leaks in case of a process crash. Moreover, Postgres backends have done WSAStartup without WSACleanup since commit4cdf51e64
in 2004, and we've never seen any indication of a problem with that. libpq's habit of doing WSAStartup during connection start and WSACleanup during shutdown is also rather inefficient, since a series of non-overlapping connection requests leads to repeated, quite expensive DLL unload/reload cycles. We document a workaround for that (having the application call WSAStartup for itself), but that's just a kluge. It's also worth noting that it's far from uncommon for applications to exit without doing PQfinish, and we've not heard reports of trouble from that either. However, the real reason for acting on this is that recent experiments by Alexander Lakhin show that calling WSACleanup during PQfinish is triggering the symptom we occasionally see that a process using libpq fails to emit expected stdio output. Therefore, let's change libpq so that it calls WSAStartup only once per process, during the first connection attempt, and never calls WSACleanup at all. While at it, get rid of the only other WSACleanup call in our code tree, in pg_dump/parallel.c; that presumably is equally useless. Back-patch of HEAD commit7d00a6b2d
. Discussion: https://postgr.es/m/ac976d8c-03df-d6b8-025c-15a2de8d9af1@postgrespro.ru
This commit is contained in:
@ -91,21 +91,6 @@
|
||||
</para>
|
||||
</warning>
|
||||
|
||||
<note>
|
||||
<para>
|
||||
On Windows, there is a way to improve performance if a single
|
||||
database connection is repeatedly started and shutdown. Internally,
|
||||
libpq calls <function>WSAStartup()</function> and <function>WSACleanup()</function> for connection startup
|
||||
and shutdown, respectively. <function>WSAStartup()</function> increments an internal
|
||||
Windows library reference count which is decremented by <function>WSACleanup()</function>.
|
||||
When the reference count is just one, calling <function>WSACleanup()</function> frees
|
||||
all resources and all DLLs are unloaded. This is an expensive
|
||||
operation. To avoid this, an application can manually call
|
||||
<function>WSAStartup()</function> so resources will not be freed when the last database
|
||||
connection is closed.
|
||||
</para>
|
||||
</note>
|
||||
|
||||
<variablelist>
|
||||
<varlistentry id="libpq-pqconnectdbparams">
|
||||
<term><function>PQconnectdbParams</function><indexterm><primary>PQconnectdbParams</primary></indexterm></term>
|
||||
|
Reference in New Issue
Block a user