From 3d1a1eeddb24580b5b3d6fc0e50a68d467696d49 Mon Sep 17 00:00:00 2001 From: Bruce Momjian Date: Fri, 6 Feb 2009 18:18:54 +0000 Subject: [PATCH] Document ways to avoid libpq WSACleanup() overhead on Windows. Andrew Chernow --- doc/src/sgml/libpq.sgml | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/doc/src/sgml/libpq.sgml b/doc/src/sgml/libpq.sgml index 0a4379a76b..75a0e3edd5 100644 --- a/doc/src/sgml/libpq.sgml +++ b/doc/src/sgml/libpq.sgml @@ -1,4 +1,4 @@ - + <application>libpq</application> - C Library @@ -63,6 +63,21 @@ The PQstatus function should be called to check whether a connection was successfully made before queries are sent via the connection object. + + + + On Windows, there is a way to improve performance if a single + database connection is repeated started and shutdown. Internally, + libpq calls WSAStartup() and WSACleanup() for connection startup + and shutdown, respectively. WSAStartup() increments an internal + Windows library reference count which is decremented by WSACleanup(). + When the reference count is just one, calling WSACleanup() frees + all resources and all DLLs are unloaded. This is an expensive + operation. To avoid this, an application can manually call + WSAStartup() so resources will not be freed when the last database + connection is closed. + +