Ce contenu n'est pas disponible dans la langue sélectionnée.
2.8. Integration with Spring and Camel
Overview
Copier lienLien copié sur presse-papiers!
				Spring supports a useful abstraction, 
JmsTemplate, which allows you to hide some of the lower level JMS details when sending messages and so on. One thing to bear in mind about JmsTemplate, however, is that it creates a new connection, session, and producer for every message it sends, which is very inefficient. It is implemented like this in order to work inside an EJB container, which typically provides a special JMS connection factory that supports connection pooling.
			
				If you are not using an ESB container to manage your JMS connections, we recommend that you use the pooling JMS connection provider, 
org.apache.activemq.pool.PooledConnectionFactory, from the activemq-pool artifact, which pools JMS resources to work efficiently with Spring's JmsTemplate or with EJBs.
			Creating a pooled connection factory
Copier lienLien copié sur presse-papiers!
				The 
PooledConnectionFactory is implemented as a wrapper class that is meant to be chained with another connection factory instance. For example, you could use a PooledConnectionFactory instance to wrap a plain Red Hat JBoss A-MQ connection factory, or to wrap an ActiveMQSslConnectionFactory, and so on.
			Example
Copier lienLien copié sur presse-papiers!
				For example, to instantiate a pooled connection factory, 
jmsFactory, that works efficiently with the Spring JmsTemplate instance, myJmsTemplate, define the following bean instances in your Spring configuration file:
			
				In the preceding example, the pooled connection factory is chained with a plain 
ActiveMQConnectionFactory instance that opens connections to the tcp://localhost:61616 broker endpoint.