Tune connection pools
Use connection pools helps to both alleviate connection management overhead and decrease development tasks for data access. Each time an application attempts to access a backend store (such as a database), it requires resources to create, maintain, and release a connection to that datastore. To mitigate the strain this process can place on overall application resources, the application server enables administrators to establish a pool of backend connections that applications can share on an application server. Connection pooling spreads the connection overhead across several user requests, thereby conserving application resources for future requests.
Connection pooling can improve the response time of any application that requires connections, especially Web-based applications. When we make a request over the web to a resource, the resource accesses a data source. Because you connect and disconnect frequently with applications on the Internet, the application requests for data access can surge to considerable volume. Consequently, the total overhead for a datastore can quickly become high for Web-based applications, causing performance to deteriorate. When connection pooling capabilities are used, however, web applications can realize performance improvements of up to 20 times the normal results.
Avoid trouble: Connection pooling is not supported in an application client. The application client calls the database directly and does not go through a data source. To use the getConnection() request from the application client, configure the JDBC provider in the application client deployment descriptors, using Rational Application Developer or an assembly tool. The connection is established between application client and the database. Application clients do not have a connection pool, but we can configure JDBC provider settings in the client deployment descriptors.gotcha
- Prevent a connection deadlock.
Deadlock can occur if the application requires more than one concurrent connection per thread, and the database connection pool is not large enough for the number of threads. Suppose each of the application threads requires two concurrent database connections and the number of threads is equal to the maximum connection pool size. Deadlock can occur when both of the following conditions are true:
- Each thread has its first database connection, and all are in use.
- Each thread is waiting for a second database connection, and none would become available since all threads are blocked.
To prevent the deadlock in this case, increase the maximum connections value for the database connection pool by at least one. This ensures that at least one of the waiting threads obtains a second database connection and avoids a deadlock scenario.
For general prevention of connection deadlock, code the applications to use only one connection per thread. If we code the application to require C concurrent database connections per thread, the connection pool must support at least the following number of connections, where T is the maximum number of threads:
T * (C - 1) + 1
The connection pool settings are directly related to the number of connections that the database server is configured to support. If we increase the maximum number of connections in the pool and the corresponding settings in the database are not increased accordingly, the application might fail. The resulting SQL exception errors are displayed in the following locations:
the stderr.log file
- the SYSOUT of the servant
One of the most common causes of connection deadlock is the use of the same connection pool by both servlets and by Enterprise JavaBeans (EJBs), and where the servlet directly or indirectly invokes the bean. For example, a servlet that obtains a JMS connection from the connection pool, sends a message to a Message Driven Bean (MDB) and waits for a reply. The MDB is configured to use the same connection pool as the servlet, therefore, another connection from the pool is required for the MDB to send a reply to the servlet. Servlets and enterprise beans do not share the same connection pool. This is a classic case of concurrent (C) threads, where C=2 and T is the maximum size of the servlet and EJB thread pools.
- Disable connection pooling.
- For relational resource adapters (RRAs), add the disableWASConnectionPooling custom property for the data sources.
- Click JDBC > Data sources.
- Click on the name of the data source to configure.
- Click Custom properties under the Additional Properties heading.
- Click New.
- Complete the required fields with the following information:
- Name: disableWASConnectionPooling
- Value: true
- For other resource adapters, consult with the binding specifications for that resource adapter to configure the applications to disable connection pooling.
- Programmatically disable connection pooling through the resource adapter.
- The application server leverages the following code to detect the javax.resource.NotSupportedException exception and disable connection pooling:
_managedFactory.matchManagedConnections(s,subject,cri); // 169059 174269 } catch(javax.resource.NotSupportedException e){
- Enable deferred enlistment.
In the application server environment, deferred enlistment refers to the technique in which the application server waits until the connection is used before the connection is enlisted in the application's unit of work (UOW) scope.
Consider the following illustration of deferred enlistment:
- An application component that uses deferred enlistment calls the getConnection method from within a global transaction.
- The application component does not immediately use the connection.
- When the application issues the call for initial use of the connection, the transaction manager intercepts the call.
- The transaction manager enlists the XA resource for the connection and calls the XAResource.start method.
- The connection manager associated with the XA resource sends the call to the database.
Given the same scenario, but the application component does not use deferred enlistment, the component container immediately enlists the connection in the transaction. Thus the application server incurs, for no purpose, an additional load of all of the overhead associated with that transaction. For XA connections, this overhead includes the two phase commit (2PC) protocol to the resource manager.
Deferred enlistment offers better performance in the case where a connection is obtained, but not used, within the UOW scope. The technique saves the cost of transaction participation until the UOW in which participation must occur.
Check with the resource adapter provider if we need to know if the resource adapter provides this functionality. The application server relational resource adapter automatically supports deferred enlistment.
Incorporating deferred enlistment in our code:
The JEE Connector Architecture (JCA) Version 1.5 and later specification calls the deferred enlistment technique lazy transaction enlistment optimization. This support comes through a marker interface (LazyEnlistableManagedConnection) and a method on the connection manager (LazyEnlistableConnectionManager()):
package javax.resource.spi; import javax.resource.ResourceException; import javax.transaction.xa.Xid; interface LazyEnlistableConnectionManager { // application server void lazyEnlist(ManagedConnection) throws ResourceException; } interface LazyEnlistableManagedConnection { // resource adapter }
- Control connection pool sharing.
We can use the defaultConnectionTypeOverride, or globalConnectionTypeOverride connection pool custom property for a particular connection factory or data source to control connection sharing:
- The defaultConnectionTypeOverride property changes the default sharing value for a connection pool. Enable you to control connection sharing for direct queries. If resource references are configured for this data source or connection factory the resource reference's configurations take precedence over the defaultConnectionTypeOverride property settings. For example, if an application is doing direct queries and unshared connections are needed, set the defaultConnectionTypeOverride property to unshared.
- The value specified for the globalConnectionTypeOverride custom property takes precedence over all of the other connection sharing settings. For example if you set this property to unshared, all connection requests are unshared for both direct queries and resource reference lookups. This property provides you with a quick way to test the consequences of moving all connections for a particular data source or connection factory to unshared or shared without changing any resource reference setting.
If we specify values for both the defaultConnectionTypeOverride and the globalConnectionTypeOverride properties, only the values specified for the globalConnectionTypeOverride property are used to determine connection sharing type.
To add these new custom properties to the settings for a data source or connection factory connection pool, a new connection pool custom property must be created. To add one of these properties to a data source, use the administrative console. Click Resources > JDBC > Data sources, select the data source from the list, and click Additional properties > Connection pool properties > Connection pool custom properties > New. For other J2C or JMS connection factories, navigate to the connection factory definition in the administrative console. Then select Additional Properties > Connection pool > Connection pool custom properties > New. Now specify defaultConnectionTypeOverride or globalConnectionTypeOverride in the Name field and shared or unshared in the Value field.
Important: The properties must be set in the Connection pool custom properties and NOT the general Custom propeties on the data source or connection factory.
- Automatically perform a mitigation action if a connection pool cannot establish a connection to its configured resource manager.
By using the failureNotificationActionCode and failureThreshold properties, a connection pool can be configured so that when a connection factory is unable to establish a connection to its configured resource manager an autonomous mitigation action is taken by the WAS for z/OS runtime, to minimize the end user impact of the failure. When a connection factory is able to re-establish a connection to the configured resource manager, the autonomous mitigation action is reversed. One example of this type of mitigation action is that the runtime can issue a "pause listeners" command for the server with the failed resource, preventing new work from being accepted by the server. When combined with a high-availability front end, new work can be routed to other servers in a cluster.
Notification is sent to the z/OS runtime when a particular connection factory or data source has reached a specified or default failure threshold value. The failure notification includes a configured action code that determines how the runtime responds to the failure notification. See the topic, Connection pool custom properties, for action code definitions.
To use these properties, define them as new custom properties of the connection pool. This can be done through the administrative console as follows: Click JDBC providers > Data sources > Connection pools > Custom Properties > New. Then specify failureNotificationActionCode or failureNotification in the Name field and the appropriate value in the Value field.
To learn more about the settings for these custom properties, see the topic, Connection pool custom properties.
- Discard connections.
Reap time and unused timeout settings do not cause the idle or unused connections to be discarded if the servant region is idle. This situation might cause some DB2 connections to be held longer than is necessary.
If you prefer to have the connections discarded at the time specified by a combination of reaper time and unused timeout settings, even if this preference might cause an idle servant region to become active again, we can add the nondeferredreaper custom property to the JDBC driver provider data source settings. When we add this custom property, connections are discarded at the time specified by a combination of reaper time and unused timeout settings.
To add this custom property to the JDBC driver provider data source settings, in the administrative console, click Resources > JDBC providers > DB2 Universal JDBC Driver Provider > Data sources > data_source > Custom properties > New. Then specify nondeferredreaper in the Name field, true in the Value field, and java.lang.Boolean in the Type field. This new setting does not go into effect until you restart the server that is using this data source.
Avoid trouble: Activating an idle servant region for the sole purpose of discarding unused connection, might cause additional and sometimes undesirable CPU usage. Also, the following warning message might be logged and should be ignored:
DSRA8200W: DataSource Configuration: DSRA8020E: Warning: The property 'nondeferredreaper' does not exist on the DataSource classcom.ibm.db2.jcc.DB2ConnectionPoolDataSource.gotcha
- Purge connection pools based on the purge policy.
When the connection pool error detection model is configured to exception mapping, the stale connection exception indicates that the connection is no longer valid.
Typically, when a StaleConnectionException results from the exception mapping process a connection error event is fired and subsequently the connection pool gets purged. However, in this case, the SCE is instantiated, the existing code does not have the functionality to fire the connection error event and the pool does not get purged When connections are terminated on the database side when requesting a new connection, the driver throws a XAException. If the errorDetectionModel=ExceptionMapping results, a ConnectionErrorEvent will be fired so that the connection pool gets purged based on the purge policy.
To add this custom property to the JDBC driver provider data source settings, in the administrative console, click Resources > JDBC providers > DB2 Universal JDBC Driver Provider > Data sources > data_source > Custom properties > New. Then specify fireCEEventOnSCE in the Name field, true in the Value field, and java.lang.Boolean in the Type field. This new setting does not go into effect until you restart the server that is using this data source.
The WebSphere RRA code has been changed so that the pool is purged properly upon a StaleConnectionException when using ExceptionMapping as the errorDetection model.
Subtopics
Related concepts
Connection pooling Transaction type and connection behavior
Related tasks
Configure Java EE Connector connection factories in the administrative console Disable statement pooling
Connection pool properties Connection and connection pool statistics Connection pool custom properties