1:org.apache.activemq.ActiveMQConnectionFactory
JMS连接工厂,该对象负责产生连接,但是不管理连接,当我们使用spring的org.springframework.jms.core.JmsTemplate发送消息时,如果使用该工厂类获取连接,默认情况下每次请求会重新建立一次连接,连接无法复用
2:org.apache.activemq.pool.PooledConnectionFactory
JMS连接池工厂,该对象默认配置会为每个用户[username,password]维持一个连接,给每个连接缓存500个session,每个session维护着一个消息的上下文处理,大概就是说我们的应用可以保证同时500个线程使用一个ActiveMQConnection发送消息
<bean id= "pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop" >
<property name= "connectionFactory">
<bean class="org.apache.activemq.ActiveMQConnectionFactory" >
<property name= "brokerURL" value="${jms.tcp}" />
<property name= "useAsyncSend" value="true" />
</bean>
</property>
</bean >
3:org.springframework.jms.connection.CachingConnectionFactory
spring封装的一个缓存连接工厂,功能和PooledConnectionFactory差不多,但是该工厂给每个连接只缓存了1个session,这个可以自行设置。
<bean id= "amqConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory" >
<property name= "brokerURL" value ="${jms.tcp}"/>
<property name= "useAsyncSend" value ="true"/>
<property name= "producerWindowSize" value="1024" />
</bean >
<bean id="connectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory" >
<constructor-arg ref= "amqConnectionFactory" />
<property name= "exceptionListener" ref="jmsExceptionListener" />
<property name= "sessionCacheSize" value ="100" />
</bean >
一篇Spring和ActiveMQ结合使用的介绍:http://codedependents.com/2009/10/16/efficient-lightweight-jms-with-spring-and-activemq/