ActiveMQ使用

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/


你可能感兴趣的:(ActiveMQ使用)