Fuse 6 is no longer supported
As of February 2025, Red Hat Fuse 6 is no longer supported. If you are using Fuse 6, please upgrade to Red Hat build of Apache Camel.このコンテンツは選択した言語では利用できません。
6.6. Generic XA-Aware Connection Pool Library
Overview
リンクのコピーリンクがクリップボードにコピーされました!
				The generic XA-aware connection pool library is provided via the 
org.apache.activemq.jms.pool component. The library enables third-party JMS providers to participate in XA transactions managed by any JTA transaction manager—Apache Geronimo in particular—and to recover properly from system and application failures.
			
				When an application uses the JMS bridge or the camel JMS component with a third-party JMS provider, this library enables it to leverage the shared pooled implementation at both ends of the bridge or the camel route.
			
Note
org.apache.activemq.pool extends org.apache.activemq.jms.pool.
				
				The library contains three different pooled connection factories: 
				
			
- PooledConnectionFactory- PooledConnectionFactoryis a simple generic connection factory that pools connection, session, and message producer instances, so they can be used with tools, such as Apache Camel and Spring's JMSTemplate and MessageListenerContainer. Connections, sessions, and producers are returned to the pool for later reuse by the application.
- XaPooledConnectionFactory- XaPooledConnectionFactoryis a generic XA pooled connection factory that automatically enlists the XA resource for each transaction and pools JMS connections, sessions and message producers.
- JcaPooledConnectionFactory- JcaPooledConnectionFactoryis a generic XA pooled connection factory that works with the Geronimo transaction manager (Aries) and provides for proper recovery after a system or application failure using the- GenericResourceManager. It also automatically enlists the XA resource for each transaction and pools JMS connections, sessions and message producers.
Dependencies
リンクのコピーリンクがクリップボードにコピーされました!
				Maven users need to add a dependency on 
activemq-jms-pool to their pom.xml file as shown here:
			<dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-jms-pool</artifactId> <version>x.x.x</version> <!-- Use same version as your activemq core --> <dependency>
<dependency>
   <groupId>org.apache.activemq</groupId>
   <artifactId>activemq-jms-pool</artifactId>
   <version>x.x.x</version>  <!-- Use same version as your activemq core  -->
<dependency>PooledConnectionFactory
リンクのコピーリンクがクリップボードにコピーされました!
				The 
PooledConnectionFactory has one required and nine optional parameters:
			| Parameter | Required | Description | 
|---|---|---|
| connectionFactory | Yes | Specifies the underlying JMS connectionFactory. | 
| blockIfSessionPoolIsFull | No | 
								Controls the behavior of the internal session pool when it is full.
							 
 
								Note:  maximumActiveSessionPerConnectioncontrols the size of the session pool. | 
| createConnectionOnStartup | 
								Specifies whether a connection will be created immediately on a call to start(). This is useful for warming up the pool on startup.
							 
								Note: Any exception that occurs during startup is logged at  WARNlevel and ignored.
								Defaults to true.
							 | |
| expiryTimeout | No | 
								Specifies the time, in milliseconds, at which connections are allowed to expire, regardless of load or  idleTimeout.
								Provides a simple way to achieve load balancing when used with the failover protocol (see Failover in the Transport Reference). Since failover works only when a connection is initially made, a pooled connection doesn't get another chance to load balance, unless expiry is forced on the pool.
							 
								If your application has no need to load balance frequently—for example, when a destination's producers and consumers are colocated on the same broker—set this parameter to a large number.
							 
								Defaults to 0 (disabled).
							 | 
| idleTimeout | No | 
								Specifies the time, in milliseconds, newly created connections can remain idle before they are allowed to expire. On expiring, a connection is closed and removed from the pool.
							 
								Note: Connections are normally tested on each attempt to borrow one from the pool. So if connections are infrequently requested, a connection instance could remain in the pool much longer than its configured setting.
							 
								Defaults to 30*1000 .
							 | 
| maxConnections | No | 
								Specifies the maximum number of connections to use. Each call to createConnection creates a new connection, up to  maxConnections.
								Defaults to 1.
							 | 
| maximumActiveSessionPerConnection | No | 
								Specifies the maximum number of active sessions allowed per connection. Once this maximum has been reached and a new session is requested, the connection either throws an exception or blocks until a session becomes available, according to  blockIfSessionPoolIsFull.
								Defaults to 500.
							 | 
| numConnections | No | 
								Specifies the number of connections currently in the pool.
							 | 
| timeBetweenExpirationCheckMillis | No | 
								Specifies the number of milliseconds to sleep between each run of the idle connection eviction thread. 
								 
 
								Defaults to -1, so no eviction thread will ever run.
							 | 
| useAnonymousProducers | No | 
								Specifies whether sessions will use one anonymous MessageProducer for all producer requests or create a new MessageProducer for each producer request.
							 
 | 
XaPooledConnectionFactory
リンクのコピーリンクがクリップボードにコピーされました!
				The 
XaPooledConnectionFactory extends the PooledConnectionFactory, implementing three additional optional parameters:
			| Parameter | Required | Description | 
|---|---|---|
| transactionManager | No | Specifies the JTA transaction manager to use. | 
| tmFromJndi | No | Resolves a transaction manager from JNDI using the specified tmJndiName. | 
| tmJndiName | No | 
								Specifies the name of the transaction manager to use when resolving one from JNDI.
							 
								Defaults to  java:/TransactionManager. | 
Note
					When no transaction manager is specified, the 
XaConnecionPool class reverts to behaving as a non XA-based connection.
				JcaPooledConnectionFactory
リンクのコピーリンクがクリップボードにコピーされました!
				The 
JcaPooledConnectionFactory pool extends theXaPooledConnectionFactory, implementing one additional required parameter:
			| Parameter | Required | Description | 
|---|---|---|
| name | Yes | 
								Specifies the name of the resource manager that the JTA transaction manager will use to detect whether two-phase commits must be employed.
							 
								The resource manager name must uniquely identify the broker.
							 
								Note: To start the recovery process, the  GenericResourceManagermust also be configured. | 
Examples
リンクのコピーリンクがクリップボードにコピーされました!
- PooledConnectionFactoryThis example (Example 6.1) shows a simple pool that configures some connection parameters for a standalone ActiveMQ broker. In this scenario, you can use either the activemq-specific poolorg.apache.activemq.poolor the generic poolorg.apache.activemq.jms.pool.Example 6.1. Simple pooled connection factory configured using Blueprint Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- XaPooledConnectionFactoryThis example (Example 6.2) uses two data sources, one standalone ActiveMQ broker and one standalone HornetMQ broker, to perform XA transactions, in which data is consumed from the HornetMQ broker and produced to the ActiveMQ broker. The HornetMQ broker is configured to use the generic poolorg.apache.activemq.jms.pool, while the ActiveMQ broker is configured to use the activemq-specific poolorg.apache.activemq.pool. This example uses the default settings for the optional parameters.Example 6.2. XA pooled connection factory configured programmatically Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- JcaPooledConnectionFactoryThis example (Example 6.3) shows the configuration of an XA application that uses theJcaPooledConnectionFactory, allowing a remote third-party JMS broker to participate in XA transactions with an ActiveMQ broker deployed in JBoss Fuse.A class specific to the Apache Geronimo transaction manager is used to register the pool with the transaction as required to enable recovery via theGenericResourceManager. Both thetransactionManagerand XAConnectionFactory (ActiveMQXAConnectionFactory) are defined and passed as properties toJcaPooledConnectionFactory, and theGenericResourceManageris configured to recover transactions upon a system or application failure.Example 6.3. JCA pooled connection factory configured using Blueprint Copy to Clipboard Copied! Toggle word wrap Toggle overflow