Class ConnectionFactoryImpl
java.lang.Object
org.postgresql.core.ConnectionFactory
org.postgresql.core.v3.ConnectionFactoryImpl
ConnectionFactory implementation for version 3 (7.4+) connections.
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final intprivate static final Stringprivate static final Logger -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprivate static StringConvert Java time zone to postgres time zone.private static ISSPIClientcreateSSPI(PGStream pgStream, String spnServiceClass, boolean enableNegotiate) private static voiddoAuthentication(PGStream pgStream, String host, String user, Properties info) private static PGStreamenableGSSEncrypted(PGStream pgStream, GSSEncMode gssEncMode, String host, Properties info, int connectTimeout) private static PGStreamenableSSL(PGStream pgStream, SslMode sslMode, Properties info, int connectTimeout) private static StringgetAuthenticationMethodName(int authReq) private static List<ConnectionFactoryImpl.StartupParam> getParametersForStartup(String user, String database, Properties info) private static booleanisPrimary(QueryExecutor queryExecutor) Since PG14 there is GUC_REPORT ParamStatusin_hot_standbywhich is set to "on" when the server is in archive recovery or standby mode.private static voidopenConnectionImpl(HostSpec[] hostSpecs, Properties info) Implementation ofConnectionFactory.openConnection(HostSpec[], Properties)for a particular protocol version.private static voidrunInitialQueries(QueryExecutor queryExecutor, Properties info) private static voidsendStartupPacket(PGStream pgStream, ProtocolVersion protocolVersion, List<ConnectionFactoryImpl.StartupParam> params) private PGStreamtryConnect(Properties info, SocketFactory socketFactory, HostSpec hostSpec, SslMode sslMode, GSSEncMode gssEncMode) Methods inherited from class ConnectionFactory
closeStream, openConnection
-
Field Details
-
LOGGER
-
AUTH_REQ_OK
private static final int AUTH_REQ_OK- See Also:
-
AUTH_REQ_KRB4
private static final int AUTH_REQ_KRB4- See Also:
-
AUTH_REQ_KRB5
private static final int AUTH_REQ_KRB5- See Also:
-
AUTH_REQ_PASSWORD
private static final int AUTH_REQ_PASSWORD- See Also:
-
AUTH_REQ_CRYPT
private static final int AUTH_REQ_CRYPT- See Also:
-
AUTH_REQ_MD5
private static final int AUTH_REQ_MD5- See Also:
-
AUTH_REQ_SCM
private static final int AUTH_REQ_SCM- See Also:
-
AUTH_REQ_GSS
private static final int AUTH_REQ_GSS- See Also:
-
AUTH_REQ_GSS_CONTINUE
private static final int AUTH_REQ_GSS_CONTINUE- See Also:
-
AUTH_REQ_SSPI
private static final int AUTH_REQ_SSPI- See Also:
-
AUTH_REQ_SASL
private static final int AUTH_REQ_SASL- See Also:
-
AUTH_REQ_SASL_CONTINUE
private static final int AUTH_REQ_SASL_CONTINUE- See Also:
-
AUTH_REQ_SASL_FINAL
private static final int AUTH_REQ_SASL_FINAL- See Also:
-
IN_HOT_STANDBY
- See Also:
-
-
Constructor Details
-
ConnectionFactoryImpl
public ConnectionFactoryImpl()
-
-
Method Details
-
createSSPI
private static ISSPIClient createSSPI(PGStream pgStream, String spnServiceClass, boolean enableNegotiate) -
tryConnect
private PGStream tryConnect(Properties info, SocketFactory socketFactory, HostSpec hostSpec, SslMode sslMode, GSSEncMode gssEncMode) throws SQLException, IOException - Throws:
SQLExceptionIOException
-
openConnectionImpl
Description copied from class:ConnectionFactoryImplementation ofConnectionFactory.openConnection(HostSpec[], Properties)for a particular protocol version. Implemented by subclasses ofConnectionFactory.- Specified by:
openConnectionImplin classConnectionFactory- Parameters:
hostSpecs- at least one host and port to connect to; multiple elements for round-robin failoverinfo- extra properties controlling the connection; notably, "password" if present supplies the password to authenticate with.- Returns:
- the new, initialized, connection, or
nullif this protocol version is not supported by the server. - Throws:
SQLException- if the connection could not be established for a reason other than protocol version incompatibility.
-
getParametersForStartup
private static List<ConnectionFactoryImpl.StartupParam> getParametersForStartup(String user, String database, Properties info) -
log
-
createPostgresTimeZone
Convert Java time zone to postgres time zone. All others stay the same except that GMT+nn changes to GMT-nn and vise versa. If you provide GMT+/-nn postgres uses POSIX rules which has a positive sign for west of Greenwich JAVA uses ISO rules which the positive sign is east of Greenwich To make matters more interesting postgres will always report in ISO- Returns:
- The current JVM time zone in postgresql format.
-
enableGSSEncrypted
private static PGStream enableGSSEncrypted(PGStream pgStream, GSSEncMode gssEncMode, String host, Properties info, int connectTimeout) throws IOException, PSQLException - Throws:
IOExceptionPSQLException
-
enableSSL
private static PGStream enableSSL(PGStream pgStream, SslMode sslMode, Properties info, int connectTimeout) throws IOException, PSQLException - Throws:
IOExceptionPSQLException
-
sendStartupPacket
private static void sendStartupPacket(PGStream pgStream, ProtocolVersion protocolVersion, List<ConnectionFactoryImpl.StartupParam> params) throws SQLException, IOException - Throws:
SQLExceptionIOException
-
getAuthenticationMethodName
-
doAuthentication
private static void doAuthentication(PGStream pgStream, String host, String user, Properties info) throws IOException, SQLException - Throws:
IOExceptionSQLException
-
runInitialQueries
private static void runInitialQueries(QueryExecutor queryExecutor, Properties info) throws SQLException - Throws:
SQLException
-
isPrimary
Since PG14 there is GUC_REPORT ParamStatusin_hot_standbywhich is set to "on" when the server is in archive recovery or standby mode. In driver's lingo such server is calledHostRequirement.secondary. Previouslytransaction_read_onlywas used as a workable substitute. Howevertransaction_read_onlycould have been manually overridden on the primary server by database user leading to a false positives: ie server is effectively read-only but technically is "primary" (not in a recovery/standby mode).This method checks whether
in_hot_standbyGUC was reported by the server during initial connection:in_hot_standbywas reported and the value was "on" then the server is a replica and database is read-only by definition, false is returned.in_hot_standbywas reported and the value was "off" then the server is indeed primary but database may be in read-only mode nevertheless. We proceed to conservativelyshow transaction_read_onlysince users may not be expecting a readonly connection fortargetServerType=primary- If
in_hot_standbyhas not been reported we fallback to pre v14 behavior.
Do not confuse
hot_standbyandin_hot_standbyParamStatuses- Throws:
SQLExceptionIOException- See Also:
-